温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C++11中std::declval的实现机制浅析

发布时间:2020-09-12 14:49:57 来源:脚本之家 阅读:216 作者:呃仙儿 栏目:编程语言

本文主要给大家介绍了关于C++11中std::declval实现机制的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:

在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配合。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对亿速云的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI