sizeof和strlen是两个不同的C语言函数。
1. sizeof是C语言的一个运算符,用于获取数据类型或变量的字节大小。它返回一个无符号整数,表示对象或类型所占用的字节数。例如,sizeof(int)将返回4,表示int类型占用4个字节。
示例:
```c
int num;
printf("int类型占用的字节数:%zu\n", sizeof(int));
printf("num变量占用的字节数:%zu\n", sizeof(num));
```
1、sizeof是运算符,其值在编译时即计算好了,参数可以是数组、指针、类型、对象、函数等。
2、strlen()是函数,要在运行时才能计算,参数必须是字符型指针(char*)。当数组名作为参数传入时,
实际上数组就退化成指针了。
char arr[10] = "What?"; int len_one = strlen(arr); int len_two = sizeof(arr); cout << len_one << " and " << len_two << endl; 输出结果为:5 and 10
eg2、char * parr = new char[10]; int len_one = strlen(parr); int len_two = sizeof(parr); int len_three = sizeof(*parr); cout << len_one << " and " << len_two << " and " << len_three << endl; 输出结果:23 and 4 and 1
点评:第一个输出结果23实际上每次运行可能不一样,这取决于parr里面存了什么(从parr[0]开始知道遇到第一个NULL结束);
第二个结果实际上本意是想计算parr所指向的动态内存空间的大小,但是事与愿违,sizeof认为parr是个字符指针,因此返回的是该指针所占的空间(指针的存储用的是长整型,所以为4);
第三个结果,由于*parr所代表的是parr所指的地址空间存放的字符,所以长度为1
sizeof和strlen是两个常用的编程函数,它们在功能和使用上有一些区别:
1.功能:sizeof是一个运算符,用于获取某个类型或变量在内存中所占的字节数。而strlen是一个函数,用于获取字符串的长度,不包括结束字符'\0'。
2.参数:sizeof的参数可以是类型、变量、数组或结构体等,而strlen的参数是一个字符串。
3.返回值:sizeof返回的是字节数,而strlen返回的是字符数。
4.处理方式:sizeof在编译时计算结果,而strlen在运行时计算结果。
5.空指针处理:sizeof可以安全地应用于空指针,返回的大小为指针本身的大小。而strlen不能直接应用于空指针,否则会导致未定义行为。
综上所述,sizeof和strlen在功能、参数、返回值、处理方式和空指针处理上存在显著差异。在使用时需要根据具体情况选择合适的函数。
到此,以上就是小编对于sizeof函数和strlen函数的区别的问题就介绍到这了,希望介绍的1点解答对大家有用,有任何问题和不懂的,欢迎各位老师在评论区讨论,给我留言。
sqlserver如何导入excel数据如何能把excel大量数据快...
Ubuntu系统下可以做什么1+xweb中级考核内容包括什么Ub...
五张表关联查询语句SQL怎么写从多个表中查询数据的sql语句SQL一...
数学问题复合函数有没有同奇异偶这个性质奇异函数平衡原理奇异函数平衡法...
周期函数excel剩余周数函数公式excel月份星期函数公式周期函数...
用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式。
语法
REPLACE ( ''string_replace1'' , ''string_replace2'' , ''string_replace3'' )
参数
''string_replace1''
待搜索的字符串表达式。string_replace1 可以是字符数据或二进制数据。
''string_replace2''
待查找的字符串表达式。string_replace2 可以是字符数据或二进制数据。
在SQL Server中,REPLACE函数用于替换字符串中出现的指定子字符串。它接受三个参数:原字符串,要被替换的子字符串和替换后的子字符串。
该函数会查找原字符串中的所有匹配项,并将其替换为指定的字符串。如果原字符串中不存在要替换的子字符串,则不会发生任何更改。使用REPLACE函数可以轻松地进行字符串替换操作,例如将某些特定字符替换为其他字符或将一部分文本替换为其他文本。这在数据清洗和字符串处理中非常有用。
12。replace('string" class="zf_thumb" width="48" height="48" title="SqlServer中REPLACE函数的使用,sql替换字符串函数" />