c++ - 如何从同一个函数返回不同的类型?

标签 c++ templates c++11 metaprogramming boost-any

出于学习目的,我制作了自己的Any 类型。我不明白,如何根据条件返回 TypeType * 。这是我的类草图:

class any
{
public:
    template<class T>
    any(T & d)
    {
        data_container = new container_impl<T>(d);
    }

    template<class T>
    any(T* d)
    {
        is_pointer = true;
        data_container = new container_impl<T>(d);
    }

    bool check_is_pointer() const;

    template<class T>
    T a_cast(size_t id) const
    {
        auto real_id = data_container->get_id();

        if (real_id != id)
        {
            //throw new exeption
        }

        return static_cast<container_impl<T>&>(*data_container).get_data();
    }

private:
    class abstract_container
    {
    public:
        virtual ~abstract_container() { }
        virtual size_t get_id() const = 0;
    };

    template<typename T>
    class container_impl : public abstract_container
    {
    public:
        container_impl(T const& value)
        {
            data = value;
            id = type_id<T>();
            pointer_data = nullptr;
        }

        container_impl(T const* value)
        {
            pointer_data = value;
            id = type_id<T*>();
        }

        T get_data()
        {
            return data;
        }

        size_t get_id() const override
        {
            return id;
        }

    private:
        T data;
        T const* pointer_data;

        size_t id;
    };

    abstract_container *data_container = nullptr;
    bool is_pointer = false;
};

template<class T>
T any_cast(any const& obj)
{
    size_t id = type_id<T>();
    return obj.a_cast<T>(id);
}

template<class T>
T* any_cast(any const& obj)
{
    size_t id = type_id<T>();
    return obj.a_cast<T>(id);
}

如您所见,我想创建两个函数 any_cast,它们返回不同的类型。

最佳答案

您不能返回不同的类型。 Boost 执行此操作的方式实际上是使用不同的签名——请注意,两个不同的版本采用不同的参数。一个接受引用,另一个接受指针。

 template <typename T>   // this one will try to cast your any down to T
 T any_cast(any& );      // and return it if that succeeds, else throw

 template <typename T>   // this one will NOT throw, but will return
 T* any_cast(any* );     // a pointer instead

两个不同函数的用法示例:

any a = 5;
any_cast<double>(a); // throws

double* v = any_cast<double>(&a); // won't throw
assert(v == nullptr);

int* vi = any_cast<int>(&a); // succeeds
assert(*vi == 5);

关于c++ - 如何从同一个函数返回不同的类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27365297/

相关文章:

c++ - OpenMP 与 boost::directory_iterator 并行

c++ - G++ 模板实例化导致 "Undefined reference to"错误

c++ - 创建一个模板,该模板是具有多个变量的自定义数据类型的 vector

c++ - std::atomic_compare_exchange_weak 是线程不安全的设计吗?

c++ - 如何在数组 vector 上使用 std::find?

c++ - 为什么写入临时流失败?

c++ - boost asio - 缺陷代码的更改

c++ - Boost .ini 文件解析器 - 多个部分名称

c++ - 通过不返回引用来防止下标运算符赋值会导致运行时崩溃

c++ - 在 C++ 的父构造函数中调用重写的方法