字符数组 一般以\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个长度的内存
到底存了啥呢。。。
为啥每次输出都是烫烫烫的乱码
有没有人解答一下,学不会了