在这里首先要明确啥是handles,这里所说的handles就是通常所说的引用、指针或者迭代器等具有指代性质的标签。那么题目所说的意思就是你返回的那个handles不要涉及对象内部的东西。
在叙述此原则的过程中作者举了一个矩形Rectangular的例子,说举行的四个顶点存储在一个结构体中,Rectangular提供了两个公有接口upperleft和lowerright它们返回的是该矩形左上角和右下角的顶点的坐标结构体,并且是以引用的形式返回的。因为用户只需知道这些顶点的坐标而无需对这些顶点进行操作,因此这俩接口都是常函数。但是矛盾出现了,常函数的作用是不允许用户去修改,但是这两个常函数却返回了Rectangular的私有成员。另外常函数只是说在常函数体内不进行更改数据成员的操作,它返回的东西并不一定是常量。既然如此用户就很有可能通过这俩接口去改变Rectangular类原本私有成员,这是极其不符合该程序的初衷和封装性原则的。
所以作者在这里说“成员变量的封装性最多等于其返回引用的访问级别”是很有道理的。作者还说非公有的成员函数也是内部数据,这不是废话嘛,我早就知道啊。作者想表达是啥呢,就是从访问级别上来讲,不要让那些访问级别高的成员函数返回指向访问级别低的成员函数的handles,不过在我看来,具体来讲就是不要让公有接口返回任何非公有的成员的handles。
那么这原则中所提及的问题是怎么解决的呢?正如我所说的,常函数只是在函数体内不能对数据成员更改,但是它返回的东西并不一定不能被更改,所以呢,那么就把返回值也设成const就OK了。
尽管如此呢还是有个问题存在,那就是函数虽然返回了const成员不能被更改,但是作为右值的语句结束以后,它的生命期就结束了,那右值的东西被析构掉左值不就成了空吊子。
所以返回只想对象内部成分的handles总是危险的,
作者最后总结道:能不用handles只想对象内部就不用,这样可以增加封装性,最好在const函数的返回类型上也加个const,也尽量避免空吊的出现。
原则28:避免返回handles指向对象的内部成分
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 《Effective C++ 中文版 第三版》读书笔记 ** 条款 28:避免返回 handle 指向对象内部成分...