#include <iostream>struct foo{ std::string &str; foo(std::string &other) : str(other) {} voID operator()(std::string &some) const { str += some; }};int main(){ std::string ext("Hello"); foo a{ ext }; std::string more(" world!"); a(more); cout << a.str; return 0;}解决方法 类成员函数的const限定符表示该成员函数(例如,foo :: operator()const)不能从客户端的角度更改对象的状态(即,它是抽象状态).这不是说对象的原始位不会改变.
它是for C编译器将对象视为原始位,除非它们可以解析the problem of aliasing.在您的情况下,编译器不能.这是由于存在非常数别名(即std :: string& str)的事实,因此对象的状态是可修改的.
也就是说,在对象a上调用operator()不改变a的状态(即,尽管ext已经改变,但str仍然是ext的别名).
上面也解释了为什么用指向常量的指针(即,std :: string * const str)指向一个对象不能保证对象不被修改.它只保证对象不会通过该指针进行更改.
总结以上是内存溢出为你收集整理的c – 为什么可以通过const成员函数修改引用成员?全部内容,希望文章能够帮你解决c – 为什么可以通过const成员函数修改引用成员?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)