存储任意引用的 C++ 包装类,但本身不是类模板,可以使用 C++ 的模板特化和类型擦除技术来实现。
首先,我们需要定义一个包装类,该类将存储任意类型的引用,但本身不是类模板。我们可以使用 std::any
类型来实现这个功能。
#include <any>
class AnyRefWrapper {
public:
template<typename T>
AnyRefWrapper(T& ref) : m_ref(std::ref(ref)) {}
void* get_address() const {
return &(std::any_cast<std::reference_wrapper<void>>(m_ref).get());
}
private:
std::any m_ref;
};
在上面的代码中,我们使用了 std::any
类型来存储任意类型的引用。我们还定义了一个 get_address()
方法,该方法返回引用的地址。
接下来,我们可以使用这个包装类来存储任意类型的引用。
int main() {
int a = 42;
std::string b = "hello";
AnyRefWrapper wrapper_a(a);
AnyRefWrapper wrapper_b(b);
std::cout << "Address of a: "<< wrapper_a.get_address()<< std::endl;
std::cout << "Address of b: "<< wrapper_b.get_address()<< std::endl;
return 0;
}
在上面的代码中,我们创建了两个 AnyRefWrapper
对象,一个用于存储 int
类型的引用,另一个用于存储 std::string
类型的引用。我们可以使用 get_address()
方法获取这些引用的地址。
需要注意的是,由于我们使用了 std::any
类型来存储引用,因此在使用 get_address()
方法时需要小心,因为如果 std::any
中存储的不是引用类型,那么 get_address()
方法将返回无效的地址。
总之,我们可以使用 C++ 的模板特化和类型擦除技术来实现一个存储任意引用的 C++ 包装类,但本身不是类模板。
领取专属 10元无门槛券
手把手带您无忧上云