sizeof与strlen区别?char c[] = “abc\0cba”;

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/weibo1230123/article/details/82822976

一、sizeof与strlen


char c[] = “abc\0cba”;

问题1:sizeof(c) = ?
问题2:strlen(c) = ?
问题3:执行free(c);之后会有什么后果?

解答1:8
解答2:3   (判断字符串a的长度,这个长度不包括"\0")
解答3:段错误


二、 short a[100],sizeof(a)返回? 


A 2     B 4       C 100       D 200        E 400 

答案:D

段错误:指访问的内存超出了系统所给这个程序的内存空间。

汇编语言的程序设计是分4个段来设计的,即用来放数据的数据段DS,临时存放数据的堆栈段SS、存放程序代码的代码段、存放附加数据的附加段,每一段的最大存储空间为64KB,跳转指令、程序调用指令在转移到地址没有超过64KB地址空间范围的叫段内转移,超出64KB地址空间范围的叫段间转移。这就是段内和段间的含义。 

三:下列程序在 32 位 linux 或 unix 中的结果是什么?

void func(char *str)
{
	printf(" %d", sizeof(str));
	printf(" %d", strlen(str));
}

int main() 
{
	char a[] = "123456789";
	printf(" %d", sizeof(a));
	printf(" %d", strlen(a));
	func(a);

	getchar();
	return 0;
}

 结果: 10 9 4 9

C/C++里数组作为参数时传递的实际上是指向数组第一个元素的指针,因此sizeof(str)返回的是指针的大小,即4。所有的指针大小都是4。

下列程序在 64 位 linux 或 unix 中的结果是什么?

结果: 10 9 8 9

扫描二维码关注公众号,回复: 3369150 查看本文章

为什么在64位系统中指针的大小是8,而32位的却是4? 

64位系统,这个位数指的是CPU 里面的通用寄存器的数据宽度为64位,也就是说一个地址占二进制位数是64,所以sizeof(double *)==sizeof(int *)==sizeof(char *)==64/8==8

32位系统,同理,他的一个地址占32位二进制空间,sizeof(double *)==sizeof(int *)==sizeof(char *)==32/8==4
其实明白了两个系统的寻址原理就能明白,大体就是这个原因。地址跟系统有关,但是基本数据类型占的大小是由C语言本身决定。 

四:sizeof与strlen的区别本质上而言:

不同点:

(1)sizeof是一个运算符,它用类型作为参数,而strlen只是C库提供的一个函数,他用来计算以’/0’结果的字符串的长度,即它的参数只能是char*。

(2)strlen的结果要在运行的时候才能计算出来,是用来计算字符串的实际长度,而sizeof的结果是在编译的时候就计算过的,是类型或变量占内存的大小。 注意:sizeof计算的是类型或者变量占内存的大小。

相同点:

(1)它们相同的地点就只是返回值,都是一个size_t类型的值。

猜你喜欢

转载自blog.csdn.net/weibo1230123/article/details/82822976