c++诡异的字符数组

   日期:2020-07-06     浏览:96    评论:0    
核心提示:字符数组 一般以\\0结尾如果尝试不以\\0结尾 会发生什么呢?如图,在vscode里,环境是mingw64的 gdb,输出c2时,把c2和c1放在一起输出了,有点诡异去vs里调试一下如图,字符数组的地址值 应该是 首元素的地址运行时 c2 的输出 直接乱码了等等 应该是c2输出的时候 没有遇到\\0,所以直接往后找到了c1的\\0才结束那那些乱码是什么呢?每个字符在内存里应该长度是1,为啥中间隔了6个长度呢然后我想看看c2里每个元素的地址是撒子像这样 char* p = &c2

字符数组 一般以\0结尾
如果尝试不以\0结尾 会发生什么呢?

如图,在vscode里,环境是mingw64的 gdb,输出c2时,把c2和c1放在一起输出了,有点诡异

去vs里调试一下

如图,字符数组的地址值 应该是 首元素的地址
运行时 c2 的输出 直接乱码了
等等 应该是c2输出的时候 没有遇到\0,所以直接往后找到了c1的\0才结束
那那些乱码是什么呢?
每个字符在内存里应该长度是1,为啥中间隔了6个长度呢


然后我想看看c2里每个元素的地址是撒子
像这样

	char* p = &c2[0];
    char* p2 = &c2[1];
    char* p3 = &c2[2];

	cout << p << endl;
    cout << p2 << endl;
    cout << p3 << endl;

然后发现输出是这样的

然后我又去寻找原因
发现 c ++里 cout把char*当做 c字符串处理一直输出直到\0。
然后只能printf
像这样

    printf("%x\n", &c2[0]);
    printf("%x\n", &c2[1]);
    printf("%x\n", &c2[2]);
    printf("%x\n", &c1[0]);
    printf("%x\n", &c1[1]);

果然
俩数组在内存里是挨着的,但不是紧挨着的,这样的话输出c2才能找到c1的\0
这应该是vs的特性吧,在dev里输出c2只会输出abc
那c2[2] 到 c1[0] 这隔的3个长度的内存
到底存了啥呢。。。
为啥每次输出都是烫烫烫的乱码

有没有人解答一下,学不会了

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服