浅谈C语言中的sizeof()和strlen()的区别
作者:zhaocx111222333
sizeof()和strlen()经常会被初学者混淆,但其中有有很大区别:
sizeof()
1. sizeof()【操作数所占空间的字节数大小】是一种c中的基本运算符。
可以以类型、指针、数组和函数等作为参数。
返回值类型为unsigned int
运算值在编译的时候就出结果,所以可以用来定义数组维数。
char a[5]="123"; int b=sizeof(a);//b=5 int c=strlen(a);//c=3
sizeof()是一种单目操作符,是用来计算你所使用的操作数所占的空间字节大小。
// 证明返回无符号整形案例: int i=0; int main(){ i--; if(i>sizeof(i)){ printf(">"); }else{ printf("<"); } }
结果是>
i在main函数里为-1,由于sizeof(int)是无符号整形,c语言发生隐式类型转换。会把-1直接看成有符号的数字,符号位会当做数字来算,是一个很大的值。
strlen
2.strlen()[计算字符串的长度]是一种函数。
'\0’作为终止符;
strlen的结果运行的时候才出来(不是编译期求值),是计算字符串长度的。
其参数必须是字符型指针(char*)。
头文件为#include<string.h>
size_t strlen(const char *str)//size_t()
以下是一些具体的实例(vs2013 设置为32位):
int main() { char *p = "hello"; char arr1 []= "hello"; char arr2[] = { 'h', 'e', 'l', 'l', 'o' }; printf("%d\n", sizeof( p)); //结果4,因为指针变量的所占空间大小仅仅和操作系统位数有关32-4,64-8 printf("%d\n", sizeof(arr1)); //结果6,字符串默认以\0结尾,sizeof()包含\0的计算 printf("%d\n", sizeof(arr2)); //结果为5,因为为字符型表示,并不含有\0(仅仅字符串有\0) printf("%d\n", strlen( p)); //结果为5,strlen求的是字符串的长度,不包含\0 printf("%d\n", strlen(arr1)); //结果为5,strlen求的是字符串的长度,不包含\0 printf("%d\n", strlen(arr2)); //因为字符型不包含\0,但字符串需要找到\0才可结束,所以在'o'之后继续向后读取直到找到\0,所以是一个随机值
结果如上;
设置为32位操作系统
补一个注意事项:
#include <stdio.h> int main() { int arr[] = {1,2,(3,4),5};//整型数组 printf("%d\n", sizeof(arr)); return 0; }
注意数组的数据类型,char只占一个字节,而int 数据类型四个字节哦,别忘了*4。前面的例子是char的。
#include <stdio.h> int main() { char arr[] = {1,2,(3,4),5};//字符型 printf("%d\n", sizeof(arr)); return 0; }
大量案例(想深入了解可以看)
补充几个题:
1.(花括号int的sizeof())
#include <stdio.h> #include <stdlib.h> #include <string.h> int main() { int arr[] = { 1, 2, 3, 4 }; printf("%d\n", sizeof(arr)); // 16 printf("%d\n", sizeof(arr + 0)); // 4 求 sizeof(int*) printf("%d\n", sizeof(*arr)); // 4, 求 sizeof(int) printf("%d\n", sizeof(arr + 1)); // 4, 求 sizeof(int*) printf("%d\n", sizeof(arr[1])); // 4, 求 sizeof(int) printf("%d\n", sizeof(&arr));// 4, 求 sizeof(int(*)[4]); printf("%d\n", sizeof(*&arr));// 16, 求 sizeof(int[4]); printf("%d\n", sizeof(&*arr));// 4, 求 sizeof(int*) printf("%d\n", sizeof(&arr + 1)); // 4, 求 sizeof(int(*)[4]) printf("%d\n", sizeof(&arr[0])); // 4, 求 sizeof(int*) printf("%d\n", sizeof(&arr[0] + 1)); // 4, 求 sizeof(int*) system("pause"); return 0; }
花括号定义不带’\0’,所以求strlen就是未定义行为,所以就只有sizeof().
2.(花括号char的sizeof())
#include <stdio.h> #include <stdlib.h> #include <string.h> int main() { char arr[] = { 'a', 'b', 'c', 'd', 'e', 'f' }; printf("%d\n", sizeof(arr)); // 6, sizeof(char[6]) printf("%d\n", sizeof(arr + 0)); // 4, sizeof(char*) printf("%d\n", sizeof(*arr)); // 1, sizeof(char) printf("%d\n", sizeof(arr + 1)); // 4 printf("%d\n", sizeof(arr[1]));// 1, sizeof(char) printf("%d\n", sizeof(&arr));// 4, sizeof(char(*)[6]) printf("%d\n", sizeof(*&arr)); // 6, sizeof(char[6]) printf("%d\n", sizeof(&*arr));// 4, sizeof(char*) printf("%d\n", sizeof(&arr[1] + 1)); // 4, sizeof(char*) printf("%d\n", sizeof(&arr + 1)); // 4, sizeof(char(*)[6]); system("pause"); return 0; }
花括号定义不带’\0’,所以求strlen就是未定义行为,所以就只有sizeof().
3.(字符串char的sizeof()和strlen)
char arr[] = "abcdef"; printf("%d\n", sizeof(arr)); // 7, sizeof(char[7]); printf("%d\n", sizeof(arr + 0)); // 4, sizeof(char*) printf("%d\n", sizeof(*arr)); // 1, sizeof(char) printf("%d\n", sizeof(arr[1])); // 1, sizeof(char) printf("%d\n", sizeof(&arr[0] + 1)); // 4, sizeof(char*) printf("%d\n", sizeof(&arr)); // 4 sizeof(char(*)[7]) printf("%d\n", sizeof(*&arr)); // 7 sizeof(char[7]) printf("%d\n", sizeof(&*arr)); // 4 sizeof(char*) printf("%d\n", sizeof(&arr + 1)); // 4 sizeof(char(*)[7]) printf("%d\n", strlen(arr)); // 6 printf("%d\n", strlen(arr + 1)); // 5 printf("%d\n", strlen(&arr + 1)); //类型不匹配 printf("%d\n", strlen(&arr)); // 类型不匹配 printf("%d\n", strlen(&arr[0])); // 6 printf("%d\n", strlen(*&arr)); // 6 printf("%d\n", strlen(&*arr)); // 6 printf("%d\n", strlen(&arr[1] + 1));//4
strlen中类型不匹配是因为他们的数据类型不是char*.
4.(指针定义的sizeof()和strlen)
这个例题其实有点偏题了,涉及到指针和数组的隐式转化(感兴趣的可以去看我的博客–指针基础总结详解(里面有指针和数组的讲解))
char* p = "abcdef"; printf("%d\n", sizeof(p)); // 4 sizeof(char*) printf("%d\n", sizeof(p + 1)); // 4 sizeof(char*) printf("%d\n", sizeof(*p)); // 1 sizeof(char) printf("%d\n", sizeof(p[0])); // 1 sizeof(char) printf("%d\n", sizeof(&p)); // 4 sizeof(char**) printf("%d\n", sizeof(&p[1] + 1)); // 4 sizeof(char*) printf("%d\n", sizeof(*&p)); // 4 sizeof(char*) printf("%d\n", sizeof(&*p)); // 4 sizeof(char*) printf("%d\n", strlen(p)); // 6 printf("%d\n", strlen(p + 1)); // 5 printf("%d\n", strlen(*p)); // 类型不匹配 printf("%d\n", strlen(p[1])); // 类型不匹配 printf("%d\n", strlen(&p)); // 类型不匹配. printf("%d\n", strlen(&p[1] + 1)); // 4 printf("%d\n", strlen(*&p)); // 6 printf("%d\n", strlen(&*p)); // 6
strlen中类型不匹配是因为他们的数据类型不是char*.
5.(花括号二维数组int的sizeof())
int arr[3][4] = { 0 }; printf("%d\n", sizeof(arr)); // 48 sizeof(int[3][4]) printf("%d\n", sizeof(arr[0])); // 16 sizeof(int[4]) // arr[0] int[4], 再 + 1, 就把 int[4] 转成 int* 了 printf("%d\n", sizeof(arr[0] + 1)); // 4 sizeof(int*) printf("%d\n", sizeof(&arr[0] + 1)); // 4 sizeof(int(*)[4]) printf("%d\n", sizeof(arr[0][0])); // 4 sizeof(int) printf("%d\n", sizeof(*arr[0])); // 4, sizeof(int) // arr 是二维数组 int[3][4] => int(*)[4] => * => int[4] printf("%d\n", sizeof(*arr)); // 16 sizeof(int[4]) // arr + 1 => int(*)[4] => * => int[4] printf("%d\n", sizeof(*(arr + 1))); // 16 sizeof(int[4]) // arr => int[3][4] => int(*)[4] => * => int[4] => +1 => int* printf("%d\n", sizeof(*arr + 1)); // 4 arr[0] => int[4] => & => int(*)[4] => +1 => int(*)[4] printf("%d\n", sizeof(&arr[0] + 1)); // 4 sizeof(int(*)[4]) printf("%d\n", sizeof(*(arr[0] + 1))); // 4 arr[0] => int[4] => +1 => int* => * => int
到此这篇关于浅谈C语言中的sizeof()和strlen()的区别的文章就介绍到这了,更多相关C语言 sizeof()和strlen()内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!