我在线程练习项目中遇到了一个实现问题。我知道我想要实现什么,但我不知道如何实现。我是 std::future 和 std::async 主题的新手,所以我什至不确定是否可以按照我想象的方式实现。
我有一个具有此功能的NuclearPP 类(它应该是正确的)。
const error_codes::PPErrorCode& NuclearPowerPlant::Operation(const float& power_required, float&
power_generated)
{
error_codes::PPErrorCode power_plant_error_code = error_codes::success;
float energy_required_per_core = power_required / (float)operating_generators_;
for (const auto& core_it : reactor_cores_)
{
//Threaded call of each core's GenerateEnergy(energy_required_per_core, power_generated)
}
//Error handling per core with param power_plant_error_code
return power_plant_error_code;
}
我还有一个 NPPCore 类,它有一个产生能量的函数:
const error_codes::NPPCoreErrorCode& GenerateEnergy(const float& energy_required_per_core, float&
produced_energy)
{
//Compliacted stuff which adds the generated energy to the shared resource "produced_energy" received as a param
}
我的问题是:如何为每个 core_it->GenerateEnergy(energy_required_per_core, power_generated) 启动一个线程。
非常感谢转发。如果您需要更多信息,请随时询问。
兄弟,史蒂夫