字符数组和字符串的sizeof( )和strlen()
C语言开发基础教程(Dev-C++) 第7章 字符串

✎
7.1.2 字符串
小提示:'\0'字符 字符串其实就是一个以空字符'\0'结尾的字符数组,在定义存储字符 串的数组时,要手动在数组末尾加上'\0',或者直接使用字符串对数 组进行初始化。
✎
7.1.2 字符串
字符数组的输出: 字符数组可以通过%s格式化输出,直接输 出数组名。 char char_array[6] = {"hello"}; printf("%s", char_array); //结果为hello
✎
7.2.1 常见的输入函数
2、getchar()函数 getchar()函数用于从标准输入中读取一个字符,其函数声明如下: int getchar(void); getchar()没有参数,可直接使用,其返回值为读取到的字符。
✎
7.2.1 常见的输入函数
3、gets()函数 gets()函数用于读取一个字符串,其函数声明如下: char *gets(char *str); gets()函数读取换行符之前的所有字符(不包括换行符本身),并在字 符串的末尾添加一个空字符‘\0’用来标记字符串的结束,读取到的字 符串会以指针形式返回。
✎
第7章 字符串
·字符数组与字符串 · 字符串指针 · 字符串的输入输出
· 字符串操作函数 · 数字与字符串转换 · 阶段案例
✎
7.1 字符数组和字符串
字符数组是由字符类型的元素所组成 的数组,字符串就存储在字符数组中, 在访问字符数组时,可使用下标法读 取指定位置的字符,也可使用%s格式 将字符数组中的元素以字符串的形式 全部输出。
✎
7.3.1 字符串比较函数
c语言字符串数组定义的几种方式

C语言中,字符串数组是一个很常见的数据类型。
在定义字符串数组的过程中,有几种方式可以使用,每种方式都有其特点和适用场景。
接下来,我将从浅入深地介绍这几种方式,并对其进行全面评估。
1. 使用字符数组来定义字符串数组在C语言中,可以使用字符数组来定义字符串数组。
例如:```char strArray[3][20] = {"hello", "world", "c语言"};```这种方式是最基础的定义字符串数组的方法。
它的优点是简单直接,容易理解和使用,适用于简单的场景。
但缺点是不够灵活,每个字符串的长度都是固定的,不能动态调整。
2. 使用指针数组来定义字符串数组除了使用字符数组,还可以使用指针数组来定义字符串数组。
例如:```char *strArray[3] = {"hello", "world", "c语言"};```这种方式相比于字符数组更加灵活,每个字符串的长度可以动态调整。
但要注意的是,需要手动管理每个字符串的内存空间,避免出现内存泄漏等问题。
3. 动态分配内存来定义字符串数组另一种方式是动态分配内存来定义字符串数组。
这种方式可以在运行时动态申请和释放内存,非常灵活。
例如:```char **strArray;strArray = (char **)malloc(3 * sizeof(char *));for (int i = 0; i < 3; i++) {strArray[i] = (char *)malloc(20 * sizeof(char));}strcpy(strArray[0], "hello");strcpy(strArray[1], "world");strcpy(strArray[2], "c语言");```这种方式虽然灵活,但需要手动管理内存,容易出现内存泄漏和指针错误等问题,需要谨慎使用。
字符串的sizeof长度及strlen长度

字符串的sizeof长度及strlen长度在C/C++中,字符串是以零('\0')结尾的。
⽐如,对于下⾯的字符串:"hello"在最后⼀个字符'd'后⾯,还有⼀个我们⾁眼看不见的'\0'字符,作为该字符串的结束符。
所以,"Hello"其在内存中的存储形式为:'H' 'e' 'l' 'l' 'o' '\0'最后有⼀个我们看不见的'\0'。
明⽩了字符串的结尾⽅式,那么如何计算字符串的长度呢?⽐如:例题1:char str1[]="12345678";char str2[]={'1','2','3','4','5','6','7','8'};char str3[]={'1','2','3','\0','5','6','7','8'};sizeof(str1)=?sizeof(str2)=?sizeof(str3)=?strlen(str1)=?strlen(str2)=?strlen(str3)=?分析:str1是⼀个字符数组,由字符串"12345678"进⾏初始化。
由于"12345678"含有⼀个结尾字符'\0',所以str1数组共有9个字符。
因此sizeof(str1)=9。
str2也是⼀个字符数组,它的长度由'1','2','3','4','5','6','7','8'8个字符初始化,并没有指明零字符。
C++中数字与字符串之间的转换scanfstring总结(复习必读)

C++中数字与字符串之间的转换scanfstring总结(复习必读) 1 string的scanf读⼊操作C++⾥⾯控制台输⼊直接使⽤cin操作就可以了;或者getline(istringstream,string);字符和数字加减就是字符的ASCII码和数字直接加减。
只有内置类型int,float,char,double,bool可以直接赋值,scanf读⼊string不能直接使⽤scanf直接赋值,因为string是⼀个类class,有专门的初始化函数,不能使⽤scanf,同理gets接收的也是⼀个char指针。
编程语⾔⾃带的sizeof也是⼀样,不能对string进⾏直接操作。
string s;s.resize(100);scanf("%s",&s[0]);或者:string s;char *c = new char(100);scanf("%s",c);//scanf("%s",&c[0]);s = c;//给⾸地址strlen是得到输⼊的有效字符串,⽽不是开辟的空间⼤⼩100.strlen所作的仅仅是⼀个计数器的⼯作,它从内存的某个位置(可以是字符串开头,中间某个位置,甚⾄是某个不确定的内存区域)开始扫描,直到碰到第⼀个字符串结束符'\0'为⽌,然后返回计数器值。
--就是指实际字符串或字符数组的实际长度(不是所占空间的字节数)。
char A[6]={'a','b','\0','d','e','r'};int i=strlen(A); //i为2,因为到’\0’结束,故实际A[]只有2个元素sizeof()string s;char *c = new char(100);scanf("%s",c);int len = strlen(c);s1.resize(len);//动态编译s1.assign(c,c + len);//copy(c,c + len,s1.begin());针对其他结构class X { int i; int j; char k; }; X x;cout<<sizeof(X)<<endl; 结果 12 ===》内存补齐cout<<sizeof(x)<<endl; 结果 12 同上解释⼀下,在class X中,成员中最⼤的所占的空间为int类型所占的空间4个字节,故内存补齐,最后结果为: ((int)(实际成员所占内存空间的和/4)+1)*4*所以不能通过sizeof(string) / sizeof(string[0])得到实际char元素个数,不管string等于多少,最后的结果都是28;因为string是⼀个class。
strlen总结

strlen(C语言函数)strlen所作的仅仅是一个计数器的工作,它从内存的某个位置(可以是字符串开头,中间某个位置,甚至是某个不确定的内存区域)开始扫描,直到碰到第一个字符串结束符'\0'为止,然后返回计数器值(长度不包含'\0')。
头文件:cstring string.h功能:计算给定字符串的长度区别sizeofstrlen(char*)函数求的是字符串的实际长度,它求得方法是从开始到遇到第一个'\0',如果你只定义没有给它赋初值,这个结果是不定的,它会从aa首地址一直找下去,直到遇到'\0'停止。
char aa[10];cout<<strlen(aa)<<endl; //结果是不定的char aa[10]={'\0'}; cout<<strlen(aa)<<endl; //结果为0char aa[10]="jun"; cout<<strlen(aa)<<endl; //结果为3(此处不完全正确,结果可能是不定的,如果编译器将其他的非零字符串放在aa[10]的内存地址后,strlen结果还是不定的,MSP430在IAR编译测试过)(但是在vc6中结果为3,编译器会在“处自动添上\0。
)char aa[5]="hello";cout<<strlen(aa)<<endl; //结果5(此处不完全正确,理由如上,因为实际内存中,hello后面不一定是空(即\0))(还应视编译器而定)而sizeof()返回的是变量声明后所占的内存数,不是实际长度,此外sizeof不是函数,仅仅是一个取字节运算符,strlen是函数。
sizeof(aa) 返回10int a[10]; sizeof(a) 返回40 (根据语言int型c 是四个字节c++是四个java 是两个)⒈sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型。
C语言字符串替换:字符,字符串,字符数组详解

C语⾔字符串替换:字符,字符串,字符数组详解⽬录案例描述案例分析必备知识1,字符数组(1)字符数组的定义(2)字符数组的初始化2,字符串概念(1)字符串的概念(2)⽤字符初始化字符数组(3)获取字符串的长度3,字符串与指针4,字符数组与字符指针总结案例描述字符串替换是处理字符串时最常见的操作之⼀,也是学习字符串必须掌握的知识。
本案例要求通过编程实现字符串“Good moring”到“Good evening”的转换。
案例分析我们需要从字符串中被替换的位置开始,将要替换的内容逐个复制到原字符串中,直到字符串结束或者替换的字符串结束为⽌。
为了顺利完成案例,需要先学习字符数组,字符串,字符指针等基础知识。
必备知识1,字符数组字符数组是存放字符数据的数组,其中每⼀个元素都是单个字符(1)字符数组的定义字符数组定义的语法格式如下:char 数组名[常量表达式];char 数组名[常量表达式1][常量表达式2]在上述语法中,分别列举了定义⼀维字符数组和⼆维字符数组的⽅法。
⽰例代码如下:char ch[6];(2)字符数组的初始化在数组定义的同时也可以对数组中的元素进⾏赋值,这个过程称为数组的初始化,⽰例代码如下:char c[5] = {'h','e','l','l','o'};注意字符数组的初始化很简单,但要注意以下⼏点。
(1)元素个数不能多于字符数组的⼤⼩,否则编译器会出错(2)如果初始项少于数组长度,则空余元素均会被赋值为空字符(‘\0')(3)如果没有指定数组⼤⼩,则编译器会根据初始项的个数为数组分配长度(4)也可以初始化⼆维数组(和整型数组基本⼀致)2,字符串概念(1)字符串的概念字符串是由数字、字母、下划线和空格等各种字符组成的⼀串字符,是个常量,字符串的末尾都默认有⼀个'\0'作为结束符。
"abcde"" "上⾯这两⾏都是字符串,只不过第⼆个字符串中的字符都是空格字符串在各种编程语⾔中都是⾮常重要的数据类型,但是C语⾔中没有字符串的固定类型,通常⽤字符数组的形式来存储和处理字符串,这种字符数组必须以'\0'结尾。
strlen和sizeof的题目

任务名称:strlen和sizeof的区别及用法详解一、背景介绍在编程过程中,我们常常会涉及到字符串的长度计算以及数据类型的大小计算,这时就会用到两个关键字:strlen和sizeof。
虽然这两个关键字都与计算长度有关,但它们使用的场景和计算方式却略有不同,本文将对它们的区别进行详细讨论。
二、strlen关键字2.1 strlen的定义及作用strlen是一个C语言标准库函数,其函数原型为size_t strlen(const char *s)。
它的作用是计算字符串的长度,即字符串中字符的个数。
2.2 strlen的使用方法使用strlen函数需要引用头文件<string.h>。
它的参数是一个指向字符串的指针,返回值是一个无符号整型数。
下面是一个使用strlen函数的简单示例:#include <stdio.h>#include <string.h>int main() {char str[] = "Hello World";size_t len = strlen(str);printf("字符串的长度为:%zu\n", len);return 0;}2.3 strlen的注意事项•传入的参数必须是以null结尾的字符串,即字符串的最后一个字符必须是null字符\0。
•字符串长度不包括null字符本身。
•如果传入的参数是一个空指针,则strlen函数的行为是未定义的。
•如果传入的参数不是以null结尾的字符串,strlen函数可能会访问到非法内存,导致程序崩溃或产生不确定的结果。
三、sizeof关键字3.1 sizeof的定义及作用sizeof是一个操作符,可以计算数据类型或变量的大小,即所占用的字节数。
它返回一个size_t类型的值,表示数据类型或变量所占用的字节数。
3.2 sizeof的使用方法sizeof操作符的参数可以是数据类型、变量或表达式。
架构师面试中常见的数据结构与算法题(60题)

架构师面试题 -常见的数据结构与算法 数组(共30题,含答案)1.矩阵中的⾏列数可以是不相等的,这样的说法正确吗?A.正确B.不正确2.对矩阵压缩存储是为了A.⽅便运算B.⽅便存储C.提⾼运算速度D.减少存储空间3.⼀维数组与线性表的区别是A.前者⻓度固定,后者⻓度可变B.后者⻓度固定,前者⻓度可变C.两者⻓度均固定D.两者⻓度均可变4.在以下的叙述中,正确的是A.线性表的顺序存储结构优于链表存储结构B.⼆维数组是其数据元素为线性表的线性表C.栈的操作⽅式是先进先出D.队列的操作⽅式是先进后出5.顺序存储⽅式插⼊和删除时效率太低,因此它不如链式存储⽅式好。
A.TB.F6.数组是⼀种线性结构,因此只能⽤来存储线性表A.对B.错7.设有⼀个⼆维数组A[m][n],假设A[0][0]存放位置在644(10),A[2][2]存放位置在676(10),每个元素占⼀个空间,问A[3][3](10)存放在什么位置?脚注(10)表示⽤10进制表示A.688B.678C.692D.6968.定义了⼀维int 型数组a[10] 后,下⾯错误的引⽤是A.a[0] = 1;B.a[0] = 5*2;C.a[10] = 2;D.a[1] = a[2] * a[0];9.在⼀个⻓度为n的顺序表中删除第i个元素,要移动_______个元素。
如果要在第i个元素前插⼊⼀个元素,要后移_________个元素。
A.n-i,n-i+1B.n-i+1,n-iC.n-i,n-iD.n-i+1,n-i+110.已知10*12 的⼆维数组A ,以⾏序为主序进⾏存储,每个元素占1 个存储单元,已知A[1][1] 的存储地址为420 ,则A[5][5] 的存储地址为A.470B.471C.472D.47311.取线性表的第i个元素的时间同i的⼤⼩有关。
A.TB.F12.若要定义⼀个具有5 元素的整型数组,以下错误的定义语句是A.int a[5] = {0};B.int a[] = {0, 0, 0, 0, 0};C.int a[2+3];D.int i = 5, a[i];13.⻓度为n 的⾮空顺序表,若在第i个位置插⼊新的元素X,则i的取值范围是1≤i≤n+1,需要移动的元素个数为A.iB.n-i-1C.n-iD.n-i+114.设有⼀个10阶的对称矩阵A,采⽤压缩存储⽅式,以⾏序为主存储,a11为第⼀元素,其存储地址为1,每个元素占⼀个地址空间,则a85的地址为A.13B.33C.18D.4015.设⼀维数组中有n个数组元素,则读取第i个数组元素的平均时间复杂度为A.O(n)B.O(nlog2n)C.O(1)D.O(n2)16.定义语句"double * array [8]"的含义正确的是A.array是⼀个指针,它指向⼀个数组,数组的元素时是双精度实型B.array是⼀个数组,数组的每⼀个元素是指向双精度实型数据的指针CC语⾔中不允许这样的定义语句D.以上都不对17.有⼀个⽤数组C[1..m]表示的环形队列,m为数组的⻓度。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
目录
一、数组或字符串的长度
1、sizeof()---求所占的字节数
(1)、对于整型字符型数组
(2)、对于整型或字符型指针
2、strlen()---字符数组或字符串所占的字节数
(1)、针对字符数组
(2)、针对字符指针
3、sizeof()与strlen()区别
4、c++中的字符串string的长度
一、数组或字符串的长度
1、sizeof()---求所占的字节数
(1)、对于整型字符型数组
int A[]={1,4,5,2,8,6,0};
//求整型数组A所占的字节数
int i=sizeof(A); //i表示整型数组A所占的总空间的字节数
cout<<” i=sizeof(A)= ”<<i<<endl;
i=sizeof(A)/sizeof(int); //此时i表示数字数组的元素个数
char B*+=,‘a’,’e’,’s’,’r’,’q’};
//求字符数组的所占的字节数
i=sizeof(B);
cout<<i<<endl; //结果为5*sizeof(char)=5
//求字符数组的元素个数
i=szieof(B)/sizeof(char); //结果为5
char C*+=”abcde”;
i=sizeof(C); //i为字符数组C所占的字节空间,为6,最后一个为’\0’
cout<<i<<endl;
(2)、对于整型或字符型指针
int *p;
int A[]={1,2,3,4,5,6,7,8};
p=A;
inti=sizeof(*p); //此时i就是p所指的整型数组A的第一个元素A[0]的所占字节数 cout<<i<<endl;
i=sizeof(P); // p为整形指针,大小为定值为4
cout<<*p<<endl; //输出A[0]即1
cout<<p<<endl; //输出的结果为整型指针所指向的地址 0x……
char *p;
char B*+=,‘a’,’s’,’e’,’r’-;
p=B; //字符指针赋值,或char *p=B;这样为字符指针初始化赋值
i=sizeof(p); //p为字符指针,指针的大小为定值,为4
cout<<i<<endl;
i=sizeof(*p); //这是指B[0]所占空间的大小
cout<<i<<endl; //结果为1
注意:
cout<<*p<<endl; //输出结果为字符a
cout<<p<<endl;
cout<<hex<<(int)&(*p)<<" "<<&B<<endl; //输出结果两者相同
cout<<hex<<(int)p<<" "<<&B<<endl; //输出结果两者相同
2、strlen()---字符数组或字符串所占的字节数
strlen所作的仅仅是一个计数器的工作,它从内存的某个位置(可以是字符串开头,中间某个位置,甚至是某个不确定的内存区域)开始扫描,直到碰到第一个字符串结束符'\0'为止,然后返回计数器值。
--就是指实际字符串或字符数组的实际长度(不是所占空间的字节数)。
(1)、针对字符数组
char A[6]={'a','b','\0','d','e','r'};
inti=strlen(A); //i为2,因为到’\0’结束,故实际A[]只有2个元素
cout<<i<<endl;
char *str="abcde";
i=strlen(str); //i为5
cout<<i<<endl;
//char A[6]={"abcdef"}; //error C2117: 'abcdef' : array bounds overflow
(2)、针对字符指针
char C[]={"abcdef"};
char *p1=C;
i=strlen(p1); //结果为6
cout<<i<<endl;
char D[]={'a','c','q','f','w'};
i=strlen(D); //这样,由于没指定D的内存分配大小,用strlen求其长度会造成错误。
//如果为char D[5]={'a','c','q','f','w'};这样再用strlen求其长度也会造成错误,当D[]之中的数//大于5才不会造成错误。
cout<<i<<endl;
(3)、针对其他结构
class X
{
inti;
int j;
char k;
};
X x;
cout<<sizeof(X)<<endl; 结果 12 ===》内存补齐
cout<<sizeof(x)<<endl; 结果 12 同上
解释一下,在class X中,成员中最大的所占的空间为int类型所占的空间4个字节,故内存补齐,最后结果为: ((int)(实际成员所占内存空间的和/4)+1)*4
(4)、有关空类
一个空类占多少空间?多重继承呢?
可以自己编写一个程序简单测一下:
#include <iostream>
using namespace std;
class A
{
};
class A2
{
};
class B:public A
{
};
class C:public virture B
{
};
class D:public A,public A2
{
};
int main()
{
cout<<"sizeof(A): "<<sizoef(A)<<endl;
cout<<"sizeof(B): "<<sizeof(B)<<endl;
cout<<"sizeof(C): "<<sizeof(C)<<endl;
cout<<"sizeof(D): "<<sizeof(D)<<endl;
return 0;
}
结果:1 1 4 1
表明空类所占空间为1个字节,单一继承的空类空间也为1,多重继承的空类空间还是1,但虚继承涉及虚表(虚指针),所以sizeof(C)为4。
3、sizeof()与strlen()区别
sizeof()返回的是变量声明后所占的内存数,不是实际长度,此外sizeof不是函数,仅仅是一个操作符,strlen是函数。
4、c++中的字符串string的长度
string str1=”xxxxx”;
inti=str1.length();
cout<<”i=str1.length()= ”<<i<<endl; //结果为5,因为5个x
i=tr1.size();
cout<<”str1.size()= ”<<i<<endl;
对于c++中的size()和lengt()没有区别,下面是它们的代码
size_type __CLR_OR_THIS_CALL length() const
{ // return length of sequence
return (_Mysize);
}
size_type __CLR_OR_THIS_CALL size() const
{ // return length of sequence
return (_Mysize);
}
为了兼容等,这两个函数一样。
length是因为沿用C语言的习惯而保留下来的,string类最初只有length,引入STL之后,为了兼容又加入了size,它是作为STL容器的属性存在的,便于符合STL的接口规则,以便用于STL的算法。
string类的size()/length()方法返回的是字节数,不管是否有汉字。