使用参数包生成对象

问题描述

我希望创建一个可以根据命令实例化类的对象。我之所以要这样做,是因为我必须创建一个对象的实例,所有这些实例都具有从文件中读取的相同初始参数,但我只想加载这些参数一次。 我的解决方案是使用 lambdas,但感觉很脏:

#include <functional>

template <class GENERATED_TYPE,class... Args> requires requires(Args... data) {
    { new GENERATED_TYPE(data...) } -> std::same_as<GENERATED_TYPE*>;
}
class ObjectGenerator {
    public:
        ObjectGenerator(Args... data){ instance_generator = [data...](){ return new GENERATED_TYPE(data...); }; }
        ~ObjectGenerator(){}
        GENERATED_TYPE* getInstance() { return instance_generator(); }
    private:
        std::function<GENERATED_TYPE*()> instance_generator;
};

是否有更好的方法,通过以某种方式存储 Args... data,然后稍后使用存储的参数包?

解决方法

是否有更好的方法,通过以某种方式存储 Args... data,然后稍后使用存储的参数包?

不确定是否更好,但您可以将参数存储在 std::tuple 中,然后每次都使用 std::make_from_tuple 构造对象。那看起来像

#include <functional>
#include <tuple>

template <class GENERATED_TYPE,class... Args> requires requires(Args... data) {
    { new GENERATED_TYPE(data...) } -> std::same_as<GENERATED_TYPE*>;
}
class ObjectGenerator {
    public:
        ObjectGenerator(Args... data) : arguments(std::move(data)...) {}
        
        GENERATED_TYPE getInstance() { 
            return std::make_from_tuple<GENERATED_TYPE>(arguments); 
        }
    private:
        std::tuple<Args...> arguments;
};