_______________字符串指针 相等__________????!!!#includestdio.hvoid main(){printf(Hello World!\n
_______________字符串指针 相等__________ ????!!!
#include<stdio.h>
void main()
{
printf("Hello World!\n");
char * a="hello world!\n";
char * b ="hello world!\n";
if(a==b)
printf("YES!\n");
else
printf("NO!\n");
}
上面是c++代码,在VS中跑显示”YES!“,而在VS命令提示中跑显示”NO!“。请问这是为什么?
另外,我想问的是在内存中a、b所指向的是存储在一个地方的同一字符串,那么这里的比较相等是指针相等,还是指针指向的内容相等? c++ 字符串指针比较?
[解决办法]不做保证 可以相等 也可以不等
没意义
[解决办法]是比较地址本身是否相同,不是比较其指向内容。
[解决办法]第五章 字符串字面量---一个特殊的数组
[解决办法]上面是c++代码,在VS中跑显示”YES!“,而在VS命令提示中跑显示”NO!“.
不明白,你这句话是什么意思.
我认为字符串字面量是内部链接,只要是同一个编译单元的,相同的字符串字面量.他们的存放地址值都是相同的.
但是如果你在编译单元A里有个"helloword" ,编译单元B也有个同样的"helloword"
他们的存放的地址值就可能不同了,我做过试验.
在vs下编译是相同的.
在gcc下编译就不同了.
感觉gcc更标准些.
[解决办法]比较指针里的地址吧。。
[解决办法]这里是比较地址的!相等!
可以答应地址出来看看,就明白了!
[解决办法]比较地址是对的
相等就未必了
[解决办法]去看看标准的条款,你就会知道你错在哪了。
[解决办法]还请大神显示呀!!!
[解决办法]Whether all string literals are distinct (that is, are stored in nonoverlapping objects) is implementationdefined.
标准并无规定是否在同一个编译单元,这是无所谓的。
[解决办法]标准是一回事,实现又是另一回事,没有哪个编译器完全实现了C++标准
[解决办法]标准是一回事,实现又是另一回事,没有哪个编译器完全实现了C++标准
但在这个问题上,编译器并无违反语言标准。
[解决办法]计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……
对学习编程者的忠告:
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步对应汇编一行!
VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”
但我又不得不承认:
有那么些人喜欢或者适合用“先具体再抽象”的方法学习和理解复杂事物;
而另一些人喜欢或者适合用“先抽象再具体”的方法学习和理解复杂事物。
而我本人属前者。
这辈子不看内存地址和内存值;只画链表、指针示意图,画堆栈示意图,画各种示意图,甚至自己没画过而只看过书上的图……能从本质上理解指针、理解函数参数传递吗?本人深表怀疑!
这辈子不种麦不收麦不将麦粒拿去磨面;只吃馒头、吃面条、吃面包、……甚至从没看过别人怎么蒸馒头,压面条,烤面包,……能从本质上理解面粉、理解面食吗?本人深表怀疑!!
提醒:
“学习用汇编语言写程序”
和
“VC调试(TC或BC用TD调试)时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习C和汇编的对应关系。”
不是一回事!
不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
有人说一套做一套,你相信他说的还是相信他做的?
其实严格来说这个世界上古往今来所有人都是说一套做一套,不是吗?
不要写连自己也预测不了结果的代码!
电脑内存或文件内容只是一个一维二进制字节数组及其对应的二进制地址;
人脑才将电脑内存或文件内容中的这个一维二进制字节数组及其对应的二进制地址的某些部分看成是整数、有符号数/无符号数、浮点数、复数、英文字母、阿拉伯数字、中文/韩文/法文……字符/字符串、汇编指令、函数、函数参数、堆、栈、数组、指针、数组指针、指针数组、数组的数组、指针的指针、二维数组、字符点阵、字符笔画的坐标、黑白二值图片、灰度图片、彩色图片、录音、视频、指纹信息、身份证信息……
十字链表交换任意两个节点C源代码(C指针应用终极挑战)http://download.csdn.net/detail/zhao4zhong1/5532495
[解决办法]其实就是编译器干嘛了。
a和b都是常量字符串,有些编译器会放到全局区。如果a和b所指向的字符串相同,编译器还有可能会只开辟一个字符串的内存,使得a和b的值相等。
[解决办法]其实我很纳闷,怎么可以用一个非零的常数数值来初始化指针呢?这样做不科学吧!