| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4277 人关注过本帖
标题:strlen函数测整数256所占字节数为什么显示0?
只看楼主 加入收藏
书生牛犊
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:星夜征程
等 级:贵宾
威 望:10
帖 子:1101
专家分:5265
注 册:2015-10-27
收藏
得分:10 
你的编译环境中,char类型正好是一个1字节,2^8,可以表达256种不一样的组合方式,即在数值上为0-255.
而256已经溢出了,变成了0 .

再谈谈strlen,这个函数是计算字符串长度的,他是从给定地址开始遍历计数,直到遇到'\0'时停止。'\0'这个字符在数值上恰好等于0.
所以你对这个char[]数组执行strlen,结果输出0.

再说你后来又把数组改成了int类型。那么这就更离谱了。逻辑上就不通。编译能通过?

至于你纠结的0X100,它占几个字节我不知道,我只知道,至少需要9个位才能表达256。如果你只提供一个字节来存放它,就会产生溢出,除了低位的8个,其他都丢失了。如这段代码的结果就是256变成了0.

φ(゜▽゜*)♪
2016-10-12 15:35
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
回复 9楼 弟大勿勃
我想strlen的原理是这样的:通过检测字符串结束标志来判断字符串长度,字符串结束标志就是0。
如果你的strlen也能测int类数组的话,我觉得应该这样理解:一个int类型占4个字节,十进制数256分解成16进制数应该是0x00 00 01 00,由于intel类cpu规定的是小端序存储方式,0x00 00 01 00在内存中的存储顺序为00 01 00 00,很显然第一个字节为0,strlen自然判定所测字符串长度为0了。
要知道数组长度,应用关键字sizeeof。
2016-10-12 15:42
linlulu001
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:20
帖 子:944
专家分:4047
注 册:2016-4-13
收藏
得分:0 
255二进制数……0000 1111 1111
256二进制数……0001 0000 0000
而strlen的针对是char类型。那么这个char的二进制范围是:0000 0000-1111 1111。
所以strlen判断的也只是这几个位置上的二进制数。也就是常见的截取现象。
至于xzlxzlxzl说不能通过编译,他用的应该是.cpp,而非.c
2016-10-12 16:01
弟大勿勃
Rank: 2
等 级:论坛游民
帖 子:186
专家分:59
注 册:2014-4-17
收藏
得分:0 
回复 11楼 书生牛犊
这能通过。这里int型在内存中应该是占4个字节的,256这个整数转换成二进制10000 0000
存入内存中(4个字节中),肯定能存下嘛!为什么会丢失?
2016-10-12 16:29
鸿蒙之灵
Rank: 4
来 自:异次元裂缝
等 级:贵宾
威 望:11
帖 子:126
专家分:244
注 册:2016-8-22
收藏
得分:0 
程序代码:
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编辑过]


对待编程,要像对待情人一样
2016-10-12 16:36
弟大勿勃
Rank: 2
等 级:论坛游民
帖 子:186
专家分:59
注 册:2014-4-17
收藏
得分:0 
回复 12楼 xzlxzlxzl
小端序存储方式能给我讲讲吗?为什不是01 00 00 00呢?  
2016-10-12 16:59
鸿蒙之灵
Rank: 4
来 自:异次元裂缝
等 级:贵宾
威 望:11
帖 子:126
专家分:244
注 册:2016-8-22
收藏
得分:0 
回复 16楼 弟大勿勃

http://

小端序存储方式你可以参考这篇文章,我觉得不错。

对待编程,要像对待情人一样
2016-10-12 17:25
ehszt
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:40
帖 子:1745
专家分:3216
注 册:2015-12-2
收藏
得分:0 
应该是楼上说的遇到休止符'\0'了。你可以试试,不光256,32768打印出来也为0。而255,257,32767,32769都不为零。
还有512,1024,2048都一样是0.

[此贴子已经被作者于2016-10-12 18:12编辑过]

2016-10-12 17:39
弟大勿勃
Rank: 2
等 级:论坛游民
帖 子:186
专家分:59
注 册:2014-4-17
收藏
得分:0 
回复 18楼 ehszt
嗯嗯,二进制数10000 0000、10000 0000 0000也是为0。先吃个饭等会看看小端序啥的。
2016-10-12 17:53
forever74
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:CC
等 级:版主
威 望:58
帖 子:1692
专家分:4262
注 册:2007-12-27
收藏
得分:0 
抱歉,看错了。

[此贴子已经被作者于2016-10-12 20:48编辑过]


对宇宙最严谨的描述应该就是宇宙其实是不严谨的
2016-10-12 18:12
快速回复:strlen函数测整数256所占字节数为什么显示0?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016925 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved