次の関数はスレッドセーフですか? そして、それがスレッドセーフでない場合、その funImpl を非静的にすることで実際にオーバーヘッドがあるのでしょうか? それとも、コンパイラは実際にその関数オブジェクト関数をインライン化し、関数オブジェクトの作成を完全にスキップしますか?
int myfun(std::array<int, 10> values)
{
static const auto funImpl = [&]() -> int
{
int sum = 0;
for (int i = 0; i < 10; ++i)
{
sum += values[i];
}
return sum;
};
return funImpl();
}
編集:関数シグネチャを次から編集しました:
int myfun(const std::array<int, 10>& values)
に:
int myfun(std::array<int, 10> values)
値のスレッド セーフについて質問しているのではなく、関数ローカル静的変数 funImpl のスレッド セーフについて質問していることは明らかです。