时间:2021-06-03 09:09:27 | 栏目:C代码 | 点击:次
前言
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()是一种单目操作符,是用来计算你所使用的操作数所占的空间字节大小。
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; }
大量案例(想深入了解可以看)
2020年11月19日补充:
补充几个题:
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)
这个例题其实有点偏题了,涉及到指针和数组的隐式转化(感兴趣的可以去看我的博客?C指针基础总结详解(里面有指针和数组的讲解))
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