免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5985 | 回复: 7
打印 上一主题 下一主题

[C++] 友元类访问私有变量的疑惑 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-09-17 08:53 |只看该作者 |倒序浏览
我们知道,友元类可以访问授权的私有变量, 那如果友元类自身含有和其同名的成员变量,该如何引用?
比如

class Test2
{
public:
    int c;
    int func(int xx);
private:
    int d;
};

class Test1
{
public:
    int a;
    int b;
    friend Test2;
private:
    int c;
};

上述两类中,Test2是Test1的友元,因此Test2可以引用Test1的私有成员 c;  但是因为自身也有c成员,
Test2.c 此时表示的是Test2的c 还是Test1的c?如何访问自身的c和Test1的c?


论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
2 [报告]
发表于 2014-09-17 09:02 |只看该作者
Test2.c 此时表示的是Test2的c 还是Test1的c?
---------------- 不谈c,如果是Test2.a,此时表示的是Test2的a 还是Test1的a?你没理解什么是『友元』,你问的问题和友元无关。

论坛徽章:
0
3 [报告]
发表于 2014-09-17 09:34 |只看该作者
Test2.a就是Test2的a成员, 友元不是可以直接引用授权类的私有成员吗?这里的直接引用是指在友元类中的成员函数中可带授权类的引用, 然后可以直接用授权类引用私有成员?
比如
class Test1;
class Test2
{
public:
    int c;
    int func(Test1 &);
private:
    int d;
};

class Test1
{
public:
    int a;
    int b;
    friend Test2::func(Test1 &);
private:
    int c;
};

int Test2::func(Test1 &test1)
{
    cout << test1.c << endl;
}

回复 2# bruceteen


   

论坛徽章:
0
4 [报告]
发表于 2014-09-17 10:11 |只看该作者
额, 有一点回答错了, Test2没有a成员回复 3# zouyp1989


   

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:032015年亚洲杯之中国
日期:2015-04-22 15:52:45
5 [报告]
发表于 2014-09-17 10:23 |只看该作者
本帖最后由 hanxin83 于 2014-09-17 10:24 编辑

你看一下怎么引用友元, 无非是能用对方的类名::静态变量, 或者对方的对象.私有变量.

总是会指明对方类型的, 怎么会和自己的成员混淆呢.

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
6 [报告]
发表于 2014-09-17 10:26 |只看该作者
以你的代码为例
int Test2::func(Test1 &test1)
{
    cout << test1.c << endl;
}
若 Test2 是 Test1 的友元,则在Test的成员函数中访问 test1.c 可也;否非,则不可也。就这么简单。

test2.c 中c肯定是test2的c,不管test2有没有c,有c则编译成功;无c则编译失败。
test1.c 中c肯定是test1的c,不管test1有没有c,有c则编译成功;无c则编译失败。
以上两点,和“友元”无丝毫关系。

论坛徽章:
9
摩羯座
日期:2013-08-15 15:18:48狮子座
日期:2013-09-12 18:07:47金牛座
日期:2013-09-16 13:23:09辰龙
日期:2013-10-09 09:03:27白羊座
日期:2013-10-17 13:32:44子鼠
日期:2014-04-23 15:09:38戌狗
日期:2014-09-17 11:37:542015年亚洲杯之韩国
日期:2015-03-26 10:16:442015亚冠之武里南联
日期:2015-08-18 14:55:52
7 [报告]
发表于 2014-09-17 10:27 |只看该作者
你的友元理解错了,它的意思是假设有个Test1 x变量,在其它地方x.c是不可访问的,因为c是private的;但是由于Test2是其友元,所以Test2::func(Test2的成员函数)里面可以直接访问能x.c。你应该发现了在Test2::func里面访问自己的c是直接写作c或者this->c,但Test1的c,是x.c,这两者是没有歧义的。
另外如果Test2从Test1继承,这样Test2就有两个c了,这种情况下,直接写c仍然被认为是Test2的c,只有Test1::c这样才表示Test1的c。
再另外,如果有个Test3从Test1和Test2多继承,而Test3自己没有c,这样Test3还是有两个c,这种情况下,直接写c过不了编译,会提示二义性,必须写Test1::c和Test2::c来表示。

论坛徽章:
0
8 [报告]
发表于 2014-09-17 10:47 |只看该作者
明白了,thanks everyone
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP