c – 是&decltype(object):: memfn滥用?

c – 是&decltype(object):: memfn滥用?,第1张

概述我有这样的课: class Test {public: bool bar(int &i, char c) // some arguments are passed by ref, some are by value {/*...*/} bool foo(/*...*/) {}}; 而且我不想重复调用bar1 / bar2等,然后一次又一次地检查返回值,所以我写了 我有这样的课:

class Test {public:    bool bar(int &i,char c) // some arguments are passed by ref,some are by value    {/*...*/}    bool foo(/*...*/)    {}};

而且我不想重复调用bar1 / bar2等,然后一次又一次地检查返回值,所以我写了一个宏和可变参数模板来处理这些事情

#define help_macro(object,memfn,...) help_func(#object "." #memfn,\        object,&decltype(object)::memfn,##__VA_ARGS__)template<class T,typename Func,typename... Args>voID help_func(char const * name,T &&object,Func memfn,Args&&... args){    auto ret = (object.*memfn)(forward<Args>(args)...);    cout<<name<<":\t"        <<(ret ? "OK" : "Oops")  // maybe I'll throw an exception here          <<endl;}

并像这样使用它

int i = 0;Test t;help_macro(t,bar,i,'a');

它适用于g -4.7 / Debian,但ICC13.0 / Win拒绝编译它(一个非常奇怪的错误信息)

main.cpp(37): error : type name is not allowed
help_macro(t,‘a’);
^
main.cpp(37): error : expected a “)”
help_macro(t,‘a’);
^

我为ICC启用了C 11,并确认ICC13支持可变参数模板和decltype
我是否错误地使用它或者是ICC的问题?

解决方法 编辑:实际上已经费心去测试我的理论,结果证明我错了,在那种情况下,decltype(t)是Test,可以通过static_assert(std :: is_same< decltype(t),Test> :: value,“不是参考“)

所以ICC(或它使用的EDG前端)可能只是不能正确支持在嵌套名称说明符中使用decltype,这已被DR 743更改

使用std :: decay会让ICC接受它,因此是一个有用的解决方法.

原创,错误,答案:

我认为ICC就在这里,decltype(对象)实际上是Test&并且引用类型不能包含成员,因此& decltype(t):: memfn格式不正确.

代码可以简化为:

struct Test {    voID foo() {}};int main(){  Test t;  auto p = &decltype(t)::foo;}

哪个G和Clang接受,但ICC拒绝,正确恕我直言.

您可以使用std :: remove_reference或std :: decay来修复它

#include <type_traits>// ...Test t;auto p = &std::decay<decltype(t)>::type::foo;
总结

以上是内存溢出为你收集整理的c – 是&decltype(object):: memfn滥用?全部内容,希望文章能够帮你解决c – 是&decltype(object):: memfn滥用?所遇到的程序开发问题。

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

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

原文地址: https://outofmemory.cn/langs/1230796.html

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

发表评论

登录后才能评论

评论列表(0条)

保存