首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

存储任意引用的 C++ 包装类,但本身不是类模板

存储任意引用的 C++ 包装类,但本身不是类模板,可以使用 C++ 的模板特化和类型擦除技术来实现。

首先,我们需要定义一个包装类,该类将存储任意类型的引用,但本身不是类模板。我们可以使用 std::any 类型来实现这个功能。

代码语言:cpp
复制
#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() 方法,该方法返回引用的地址。

接下来,我们可以使用这个包装类来存储任意类型的引用。

代码语言:cpp
复制
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++ 包装类,但本身不是类模板。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

领券