有没有办法将指定不同类的 std::make_unique 传递到函数中

Is there a way to pass std::make_unique with different classes specified into a function

本文关键字:unique make 函数 std 同类 有没有      更新时间:2023-10-16

所以我有这个示例代码。这里总共使用了 4 个类似银行账户的类,其中 Account 是抽象基类。支票账户和储蓄账户派生自账户抽象类,信托账户派生自储蓄账户。我不会在这里详细介绍类的内部工作原理,因为它对问题没有意义。我想使用trycatch以及从包含异常警告的std::exception派生的类来实现简单的异常处理。我可以编写一个函数来为 n 个对象执行此操作,但前提是它们是 Account 的相同子类。但是,我想向向量添加 3 个不同的子类,但我想不出自动化它的方法。

#include <iostream>
#include <memory>
#include <vector>
#include "checking_account.h"
#include "trust_account.h"
#include "account_util.h"
int main() {
std::vector<std::unique_ptr<Account>> accounts{};    //A vector of unique_ptr to Account objects that I will be adding new Objects to
std::unique_ptr<Account> 
try {
accounts.push_back(std::make_unique<CheckingAccount>("Joe", 200));
}
catch (const std::exception &ex) {
std::cout << ex.what() << std::endl;
}
try {
accounts.push_back(std::make_unique<TrustAccount>("John", -300, 0.1));
}
catch (const std::exception &ex) {
std::cout << ex.what() << std::endl;
}
try {
accounts.push_back(std::make_unique<SavingsAccount>("Jane", 150, 0.2));
}
catch (const std::exception &ex) {
std::cout << ex.what() << std::endl;
}
return 0;
}

我想让函数看起来像那样

void create_account(std::vector<std::unique_ptr<Account>> &accounts, CLASS, CLASS_ARGS) {
try {
accounts.push_back(std::make_unique<CLASS>(CLASS_ARGS));
}
catch (const std::exception &ex) {
std::cout << ex.what() << std::endl;
}
}

但我现在知道这怎么可能看起来了。 有没有办法创建指向类的指针?(一个类而不是一个类的对象,我认为有一种方法可以制作一个指向函数的指针并将其作为参数传递,但我也不知道它是如何工作的(。

使create_account()成为一个模板化函数,例如:

template<typename T, typename... ArgTypes>
void create_account(std::vector<std::unique_ptr<Account>> &accounts, ArgTypes&&... args)
{
try {
accounts.push_back(std::make_unique<T>(std::forward<ArgTypes>(args)...));
}
catch (const std::exception &ex) {
std::cout << ex.what() << std::endl;
}
}
int main() {
std::vector<std::unique_ptr<Account>> accounts;
create_account<CheckingAccount>(accounts, "Joe", 200);
create_account<TrustAccount>(accounts, "John", -300, 0.1);
create_account<SavingsAccount>(accounts, "Jane", 150, 0.2);
return 0;
}