c – 为什么sizeof引用类型给你的sizeof的类型?

c – 为什么sizeof引用类型给你的sizeof的类型?,第1张

概述根据标准,在[expr.sizeof](5.3.3.2)中我们得到: 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 根据标准,在[expr.sizeof](5.3.3.2)中我们得到:

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的类型?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1252085.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存