sizeof 与 strlen
sizeof是算符,strlen是函数。
sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型,该类型保证能容纳实现所建立的最大对象的字节大小。
sizeof可以用类型做参数,strlen只能用char*做参数,且必须是以”\0”结尾。
数组做sizeof的参数不退化,但是传递给strlen就退化为指针了。
大部分编译程序在编译的时候sizeof就被计算过了,这就是sizeof(x)可以用来定义数组维数的原因。strlen的结果要在运行的时候才能计算出来,它用来计算字符串的长度,不是类型占内存的大小。
sizeof后如果是类型必须加括弧,如果是变量名可以不加括弧。这是因为sizeof是个操作符不是个函数。
在计算字符串数组的长度上有区别。例如:
char str[20] = “0123456789”;
int a = strlen(str);
int b = sizeof(str);
a计算的是以0x00结束的字符串的长度(不包括0x00结束符),这里结果是10。b计算的则是分配的数组strl20]所占的内存空间的大小,不受里面存储内容的改变而改变,这里结果是20。
如果要计算指针指向的字符串的长度,则一定要使用strlen。例如:
char *ss = “0123456789”;
int a = sizeof(ss);
int b = strlen(ss);
a计算的是ss指针占用的内存空间大小,这里结果是4。b计算的是ss指向的字符串的长度,这里结果是10。sizeof是算符,strlen是函数。
sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型,该类型保证能容纳实现所建立的最大对象的字节大小。
sizeof可以用类型做参数,strlen只能用char*做参数,且必须是以”\0”结尾。
数组做sizeof的参数不退化,但是传递给strlen就退化为指针了。
大部分编译程序在编译的时候sizeof就被计算过了,这就是sizeof(x)可以用来定义数组维数的原因。strlen的结果要在运行的时候才能计算出来,它用来计算字符串的长度,不是类型占内存的大小。
sizeof后如果是类型必须加括弧,如果是变量名可以不加括弧。这是因为sizeof是个操作符不是个函数。
在计算字符串数组的长度上有区别。例如:
char str[20] = “0123456789”;
int a = strlen(str);
int b = sizeof(str);
a计算的是以0x00结束的字符串的长度(不包括0x00结束符),这里结果是10。b计算的则是分配的数组strl20]所占的内存空间的大小,不受里面存储内容的改变而改变,这里结果是20。
如果要计算指针指向的字符串的长度,则一定要使用strlen。例如:
char *ss = “0123456789”;
int a = sizeof(ss);
int b = strlen(ss);
a计算的是ss指针占用的内存空间大小,这里结果是4。b计算的是ss指向的字符串的长度,这里结果是10。
内联函数与宏定义的区别
引入内联函数的主要目的是用它替代C中表达式形式的宏定义,解决程序中函数调用的效率问题。在C语言里可以使用宏定义,宏定义在形式及使用上像一个函数,但它使用预处理器实现,没有了参数压栈、代码生成等一系列的操作,因此效率很高。这种宏定义在形式上类似于一个函数,但在使用它时,只是做预处理器符号表中的简单替换,因此它不能进行参数有效性的检测,也就不能享受C++编译器严格类型检查的好处,另外它的返回值也不能被强制转换为可转换的合适类型,这样,它的使用就存在着一系列的隐患和局限性。
另外,在C++中引入了类及类的访问控制,这样,如果一个操作或者说一个表达式涉及类的保护成员或私有成员,你就不可能使用这种宏定义来实现(因为无法将this指针放在合适的位置)。
inline推出的目的是为了取代这种表达式形式的宏定义,消除了宏定义的缺点,同时又很好地继承了它的优点。
内联函数在编译时展开,宏在预编译时展开。
在编译的时候内联函数可以直接被嵌入到目标代码中,而宏只是一个简单的文本替换。
内联函数可以完成诸如类型检测、语句是否正确等编译功能,宏就不具有这样的功能。
宏不是函数,inline函数是函数。
宏在定义时要小心处理宏参数(一般情况是把参数用括号括起来),否则容易出现二义性。而内联函数定义时不会出现二义性。