假设Student类里有
char* a ="Tom";
char* b ="Rose";
如果有
Student* p;
那么
cout << p->a; // 输出Tom
cout << *(p->a); //输出T
这是为什么呢? a不是一个指针吗,如果是cout << p->a; 不是应该会输出a的地址吗
为什么cout << *(p->a); 只是输出T呢?
假设Student类里有
char* a ="Tom";
char* b ="Rose";
如果有
Student* p;
那么
cout << p->a; // 输出Tom
cout << *(p->a); //输出T
这是为什么呢? a不是一个指针吗,如果是cout << p->a; 不是应该会输出a的地址吗
为什么cout << *(p->a); 只是输出T呢?
3 回答2k 阅读✓ 已解决
2 回答3.9k 阅读✓ 已解决
2 回答3.2k 阅读✓ 已解决
1 回答3.2k 阅读✓ 已解决
1 回答2.7k 阅读✓ 已解决
3 回答3.4k 阅读
1 回答1.6k 阅读✓ 已解决
一个表示字符串的变量本质上就是指针,一个表达式两个意思,编译器肯定得有一个确定的逻辑来处理这种情况,不然就乱套了
实际上C++标准库中I/O类对
<<操作符
进行重载时的实现逻辑是:在遇到char类型指针
时会将其固定当作字符串来处理,输出指针所指的字符串。要想输出地址,强制转化为
无类型的指针
即可*(p->a)为啥是T
对一个
char类型指针
取值*
操作,当然是取得一个char的值咯