重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
本文主要给大家介绍了关于C++11中std::declval实现机制的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:
10年积累的成都网站建设、网站设计经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有环翠免费网站建设让你可以放心的选择与我们合作。
在vs2013中,declval定义如下
template <_Ty> typenamea dd_rvalue_reference<_Ty>::type declval() _noexcept;
其中,add_rvalue_reference
为一个traits,定义为
template <_Ty> struct add_rvalue_reference { typedef _Ty&& type; }
可见,declval被定义为一个函数,并且只有申明,没有实现(在gcc 版本中似乎有实现,但是也不能在运行时调用——通过静态断言实现)。那么,问题来了,为什么这样定义呢,为什么不直接使用模板参数指定的,揣测原因如下:
通过函数返回值,实际上是等同于实例化了这个类型的一个对像,进而可以用这个对像调用成员方法,成员变量。这个方法最妙的地方在于不论类型的构造如何定义甚至有无构造都能获得这个类型的一个对像的引用实例。
其实,也有其它方法可以得到类似的效果。
class Klass { public: int m_a; //parameter defined //member function }
假如有上的一个类,可以通过下面的方法引用到成员变量m_a:
((Klass*)0)->m_a;
这也是在c语言中获取结构体成员的地址偏移量的常用技巧,但是有魔鬼数字和类型强转,不如declval来得优雅。
当然这一切都只能是在编译期蹦哒。declval常和c++11新引入的decltype配合。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对创新互联的支持。