友链
sizeof不是函数,就是一个一元运算符,只不过用起来象个函数而已
对于数据类型,sizeof会计算出该数据类型的大小,比如sizeof(int)就是4
但是如果是指针的话
比如
char* a[16];
sizeof(a)的值就是16
char** a[16];
sizeof(a)的值就是64
以前我一直以为
char a[16];
sizeof(a)因该是4,因为a其实就是一个指针,在32位操作系统中,一个指针(内存地址)长度就是32bit即4字节
但是事实证明他会计算出这个指针所指向的内存空间(未分配)的大小,而不是指针类型的大小
下面再来看这个:
可以从上图中看到,不管是char*还是char**,sizeof都是4,也就是指针的长度
你可能会问,那么这前后到底有什么区别呢
其实很简单,区别就是char cliIp[16]分配了一块静态内存
而如果是使用malloc分配的动态内存,就不会有这个效果:
你可能又会问了,为什么同样都是内存,使用malloc分配的内存就不会被计算出来呢
那是因为sizoef是一个编译时的运算符,sizoef(xxx)的值并不是在程序运行的时候才被计算出来,而是在编译的时候就已经计算出来了,请看下面的反编译代码
可以看到这里直接把0x10h(16进制,即10进制的16)作为参数传给了printf函数
这个0x10h是硬编码到程序指令中的,而不是存储在任何寄存器或者内存中
但是malloc只有在程序运行起来之后才会分配内存,这也就是原因所在了