When applIEd to a reference or a reference type,the result is the size of the referenced type.
这似乎与引用未指定的事实一致[dcl.ref](8.3.2.4):
It is unspecifIEd whether or not a reference requires storage
但是,在语言中有这种矛盾似乎很奇怪.无论参考是否需要存储,能否确定参考使用的尺寸是否重要?看到这些结果似乎错了:
sizeof(vector<int>) == 24sizeof(vector<int>*) == 8sizeof(vector<int>&) == 24sizeof(reference_wrapper<vector<int>>) == 8
根据定义想要sizeof(T&)== sizeof(T)的原因是什么?
解决方法 这种选择是有些武断的,试图充分证明任何一种选择都会导致圆形的形而上学论证.引用的意图是对象本身的(别名);根据这个推理,他们都有相同的大小(和地址),这就是语言规定的意义.
抽象是泄漏的 – 有时引用有自己的存储,与对象分离,导致像您指出的异常.但是当我们需要处理一个“引用”作为对象的单独实体时,我们有指针.
总结以上是内存溢出为你收集整理的c – 为什么sizeof引用类型给你的sizeof的类型?全部内容,希望文章能够帮你解决c – 为什么sizeof引用类型给你的sizeof的类型?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)