C语言之sizeof与strlen的使用及区别

先上一个例子:

C语言之sizeof与strlen的使用及区别_第1张图片

结果: 

C语言之sizeof与strlen的使用及区别_第2张图片

1、sizeof与strlen

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

问题1:sizeof(c) = ?

问题2:strlen(c) = ?

问题3:执行free(c);之后会有什么后果?

解答1:8

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

解答3:段错误

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

A 2     B 4       C 100       D 200        E 400 

答案:D

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

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

3、下列程序在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

C语言之sizeof与strlen的使用及区别_第3张图片

为什么在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语言本身决定。 

4、sizeof与strlen的区别本质上而言

不同点:

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

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

相同点:

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

你可能感兴趣的:(C语言之sizeof与strlen的使用及区别)