在宏中引用类C++
Refer to class in C++ macro
我想写
struct Foo{
MY_MACRO
};
并将其扩展到
struct Foo{
void bar(Foo&){}
};
如何定义MY_MACRO?
我唯一能想到的是以下内容:
#define MY_MARCO(X) void bar(X&){}
struct Foo{
MY_MACRO(Foo)
};
这非常接近,但并不理想,因为我不想重复类名。
不幸的是,以下内容无法编译:
struct Foo{
void bar(decltype(*this)&){}
};
这与这个问题密切相关。答案是,您(还)不能编写使用您所在的类定义类型的东西。您必须编写一个宏,其中包含类定义的开始(即struct Foo)
和一些促进 typedef 的机制。
但是
您可以在static_assert中使用decltype(*this)
,即:
#include <type_traits>
struct Foo {
template <typename T>
void bar(T& t) {
static_assert(std::is_same<T&, decltype(*this)>::value,
"bar() only accepts objects of same type");
}
};
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在C++中返回常量引用是个好主意
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 何时在引用或唯一指针上使用移动语义
- 如何在c++中使用引用实现类似python的行为
- 编译C++时未定义的引用
- Ctypes wstring通过引用传递
- c++r值引用应用于函数指针
- 理解c++中的引用
- C++取消引用指针.为什么会发生变化
- 如何修复此错误:未定义对"距离(浮点数,浮点数,浮点数,浮点数,浮点数)"的引用
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 强制转换为引用类型
- 引用一个已擦除类型(void*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 如何引用基类的派生类?