24小时热门版块排行榜    

查看: 2108  |  回复: 11

我爱小虫子

新虫 (正式写手)

[求助] c++ 一道题目,关于cout 和printf的差异,不理解(p82) 已有4人参与

下面是主函数的代码,另外,A .B是我定义的两个类,分别含有数据成员ma,mb和mc,
我有疑惑的地方就在于用printf输出和我注释掉的地方,我要查看的是数据成员的偏移量,为什么用cout(注释掉的地方)没有任何输出,但是用printf却可以正确输出呢,不理解,求指教。。

int main()
{
  A a;
  B *pb=(B*)(&a);
  cout<<"&a:"<<&a<<endl;
  cout<<"&a.ma"<<&a.ma<<endl;
  printf("%p\n",&A::ma);
   printf("%p\n",&A::mb);
    printf("%p\n",&B::mc);

/*  
  cout<<"&A::ma"<<&A::ma<<endl;
  cout<<"&A::mb"<<&A::mb<<endl;
  cout<<"&B::mc"<<&B::mc<<endl; */
  pb->print();
}
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
回帖支持 ( 显示支持度最高的前 50 名 )

rbs

木虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
我爱小虫子: 金币+7, ★★★★★最佳答案, 非常感谢,理解了 2014-04-01 19:01:57
第一:你的描述有错误。用cout不是没有任何输出,而是有一个“1”的输出
第二:&A::ma实际上是一个指向成员的指针类型,而不是一个普通指针类型。如果你使用VS2010编译器的话,写成cout<<(int)(&A::ma)<<endl即可,编译器就会告诉你:
error C2440: “类型转换”: 无法从“int A::* ”转换为“int”
但是如果你用gcc4.9.8做类型转换就不会报错,而且会输出你想要的结果,也就是偏移量。编译器有区别原因我只能猜测为制造者的因素,而非C++标准的因素。
所以,你在5楼的说法是不对的,因为cout是没有针对成员指针进行重载的。因此对于cout<<&A::ma这样的代码,编译器只好将&A::ma转换成其能够匹配的类型。成员指针类型将被转化为bool型,且非空指针(空指针不是指向0位置的指针,而是不指向任何位置的指针)都将被转为true,而用cout输出true自然就是1。关于成员指针向bool转换,无论C++98标准,还是11标准,4.10节都说的非常清楚。
8楼2014-03-31 22:47:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

isityou

金虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
能否把A写出来,如果不复杂的话
2楼2014-03-30 23:16:43
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wenguilong

金虫 (小有名气)

【答案】应助回帖


感谢参与,应助指数 +1
我爱小虫子: 金币+1, 有帮助, 谢谢 2014-04-01 19:02:29
需要做输出说明吧,就像%p一样
3楼2014-03-31 09:13:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

我爱小虫子

新虫 (正式写手)

引用回帖:
2楼: Originally posted by isityou at 2014-03-30 23:16:43
能否把A写出来,如果不复杂的话

好的,下面是完整程序
#include<iostream>
using namespace std;
class A{
public:
        A(){
     ma=1;
         mb=2;
        }
        ~A(){};
        void print(){cout<<ma<<mb<<endl;}
        int ma,mb;
};

class B{
public:
        B(){mc=3;}
        ~B(){}
        void print(){cout<<mc<<endl;}

        int mc;
};


int main()
{
  A a;
  B *pb=(B*)(&a);
/* cout<<"&a:"<<&a<<endl;
  cout<<"&a.ma"<<&a.ma<<endl;
  printf("%p\n",&A::ma);
   printf("%p\n",&A::mb);
    printf("%p\n",&B::mc); */

  cout<<"&A::ma"<<&A::ma<<endl;
  cout<<"&A::mb"<<&A::mb<<endl;
  cout<<"&B::mc"<<&B::mc<<endl;
  pb->print();
}
谢谢关注。望解答
4楼2014-03-31 17:58:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

我爱小虫子

新虫 (正式写手)

引用回帖:
3楼: Originally posted by wenguilong at 2014-03-31 09:13:57
需要做输出说明吧,就像%p一样

cout不是能够自动识别吗
5楼2014-03-31 17:58:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
我爱小虫子: 金币+2, 有帮助, 谢谢 2014-04-01 19:02:41
static_cast<void*>()来强制转换为void *
CODE:
cout << "&A::ma " << static_cast<void*>(&a.ma) << endl;
  cout << "&A::mb " << static_cast<void*>(&a.mb) << endl;
  cout << "&B::mc " << static_cast<void*>(&pb->mc) << endl;

matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
6楼2014-03-31 18:56:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wenguilong

金虫 (小有名气)

引用回帖:
5楼: Originally posted by 我爱小虫子 at 2014-03-31 17:58:46
cout不是能够自动识别吗...

楼下已经说了
7楼2014-03-31 21:46:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

我爱小虫子

新虫 (正式写手)

引用回帖:
8楼: Originally posted by rbs at 2014-03-31 22:47:23
第一:你的描述有错误。用cout不是没有任何输出,而是有一个“1”的输出
第二:&A::ma实际上是一个指向成员的指针类型,而不是一个普通指针类型。如果你使用VS2010编译器的话,写成cout<<(int)(&A:: ...

大神,您好像看错了啊,那个1不是cout的输出啊,那是最后的一句pb-->print()啊!

[ 发自手机版 http://muchong.com/3g ]
9楼2014-03-31 23:47:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

rbs

木虫 (小有名气)

引用回帖:
9楼: Originally posted by 我爱小虫子 at 2014-03-31 23:47:37
大神,您好像看错了啊,那个1不是cout的输出啊,那是最后的一句pb-->print()啊!
...

你再仔细看看。

» 本帖已获得的红花(最新10朵)

10楼2014-04-01 08:23:24
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 我爱小虫子 的主题更新
信息提示
请填处理意见