首页
学习
活动
专区
工具
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++ 包装类,但本身不是类模板。

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

相关·内容

  • 【C++】深入剖析C++11新特性

    在2003年C++标准委员会曾经提交了一份技术勘误表(简称TC1),使得C++03这个名字已经取代了C++98称为C++11之前的最新C++标准名称。不过由于C++03(TC1)主要是对C++98标准中的漏洞进行修复,语言的核心部分则没有改动,因此人们习惯性的把两个标准合并称为C++98/03标准。从C++0x到C++11,C++标准10年磨一剑,第二个真正意义上的标准珊珊来迟。相比于C++98/03,C++11则带来了数量可观的变化,其中包含了约140个新特性,以及对C++03标准中约600个缺陷的修正,这使得C++11更像是从C++98/03中孕育出的一种新语言。相比较而言,C++11能更好地用于系统开发和库开发、语法更加泛华和简单化、更加稳定和安全,不仅功能更强大,而且能提升程序员的开发效率,公司实际项目开发中也用得比较多,所以我们要作为一个重点去学习。C++11增加的语法特性非常篇幅非常多,我们这里没办法一 一讲解,所以本期博客主要讲解实际中比较实用的语法。

    04
    领券