程序代码:
1>
------ 已启动全部重新生成: 项目: 111111, 配置: Debug Win32 ------
1>正在删除项目“111111”(配置“Debug|Win32”)的中间文件和输出文件
1>正在编译...
1>stdafx.cpp
1>c:\users\administrator\desktop\111111\111111\stdafx.cpp(15) : error C2664: “strlen”: 不能将参数 1 从“int [10]”转换为“const char *”
1> 与指向的类型无关;转换要求 reinterpret_cast、C 样式转换或函数样式转换
1>生成日志保存在“file://c:\Users\Administrator\Desktop\111111\111111\Debug\BuildLog.htm”
1>111111 - 1 个错误,0 个警告
========== 全部重新生成: 0 已成功, 1 已失败, 0 已跳过 ==========
上面贴出来这是调试的结果,编译不通过,可能是我用的是.cpp ,楼上已经说了。
strlen所作的仅仅是一个计数器的工作,它从内存的某个位置(可以是字符串开头,中间某个位置,甚至是某个不确定的内存区域)开始扫描,直到碰到第一个字符串结束符'\0'为止,然后返回计数器值(长度不包含'\0')。
strlen的结果要在运行的时候才能计算出来,
是用来计算字符串的长度,并不是类型占内存的大小。
如果你仅仅想要测试256所占用的内存大小,应该用 sizeof 函数 ,当你在定义
int a[10]
的时候,程序已经为整型数组 a 分配了内存: 10
。
下面举几个例子:
char* ss = "0123456789";
sizeof(ss) 结果 4 ===》ss是指向字符串常量的字符指针
sizeof(*ss) 结果 1 ===》*ss是第一个字符
char ss[] = "0123456789";
sizeof(ss) 结果 11 ===》ss是数组,计算到\0位置,因此是10+1
sizeof(*ss) 结果 1 ===》*ss是第一个字符
char ss[100] = "0123456789";
sizeof(ss) 结果是100 ===》ss表示在内存中的大小 100×1
strlen(ss) 结果是10 ===》strlen是个函数内部实现是用一个循环计算到\0为止之前
int ss[100] = "0123456789";
sizeof(ss) 结果 400 ===》ss表示再内存中的大小 100×4
strlen(ss) 错误 ===》strlen的参数只能是char* 且必须是以'\0'结尾的
char q[]="abc";
char p[]="a\n";
sizeof(q),sizeof(p),strlen(q),strlen(p);
结果是 4 3 3 2
不要用 strlen 去测整型数组,即便你的编译器能通过,但是这样的代码本身不够严谨,存在弊病,弄清楚原理是好事,但也要养成良好的编程习惯。
[此贴子已经被作者于2016-10-12 17:02编辑过]