strlen与sizeof

刚刚遇到一个很有意思的事,我想给一个字符串动态分配空间,空间的大小使用sizeof来计算,然而结果却是无论输入的字符串多大,sizeof的计算结果总是8,换用strlen就可以正常使用了,代码如下:

 62                 printf("%s\n",optarg);
 63                 printf("%d\n",(int)strlen(optarg));
 64                 printf("%d\n",(int)sizeof(optarg));

optarg是 getopt_long(argc, argv, "m:a:k:v:i:o:f:h", arg_options, &option_index)返回的从命令行获得的参数
假如输入的参数是AES-128-CBC,那么得到下面结果:

AES-128-CBC
11
8

输入参数RC4,的到下面结果:

RC4
3
8

原来是对sizeof的理解错误,sizeof是一个运算符,计算传入参数分配得到的空间,也就是说,假如传入指针,计算这个指针所占用的空间,查阅getopt_long函数可以看到定义extern char *optarg;
strlen与sizeof的区别参考这里,主要却别如下:

一、sizeof

sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组、指针、类型、对象、函数等。
它的功能是:获得保证能容纳实现所建立的最大对象的字节大小。
由于在编译时计算,因此sizeof不能用来返回动态分配的内存空间的大小。实际上,用sizeof来返回类型以及静态分配的对象、结构或数组所占的空间,返回值跟对象、结构、数组所存储的内容没有关系。
具体而言,当参数分别如下时,sizeof返回的值表示的含义如下:

  • 数组——编译时分配的数组空间大小;
  • 指针——存储该指针所用的空间大小(存储该指针的地址的长度,是长整型,应该为4);
  • 类型——该类型所占的空间大小;
  • 对象——对象的实际占用空间大小;
  • 函数——函数的返回类型所占的空间大小。函数的返回类型不能是void。

二、strlen

strlen(...)是函数,要在运行时才能计算。参数必须是字符型指针(char*)。当数组名作为参数传入时,实际上数组就退化成指针了。
它的功能是:返回字符串的长度。该字符串可能是自己定义的,也可能是内存中随机的,该函数实际完成的功能是从代表该字符串的第一个地址开始遍历,直到遇到结束符NULL。返回的长度大小不包括NULL。

你可能感兴趣的:(strlen与sizeof)