两次创建对齐的结构数据时出现 C++ 分段错误 [已解决]
C++ segmentation fault when creating aligned struct data twice [SOLVED]
我正在尝试编写一些对性能至关重要的 C++ 代码。
因此我正在使用 AVX 内在函数并且需要将我的数据对齐到 32 字节。
我正在使用一个看起来与此类似的结构:(我注释掉了它的一部分以追踪问题)
struct Summation {
alignas(ALIGNMENT) float summation[HIDDEN_SIZE] {};
Summation() {
// std::memcpy(summation, inputBias, sizeof(float) * HIDDEN_SIZE);
}
Summation& operator=(const Summation& other) {
// std::memcpy(summation, other.summation, sizeof(float) * HIDDEN_SIZE);
return *this;
}
};
struct Evaluator {
Evaluator(){}
// inputs and outputs
bool inputMap[INPUT_SIZE] {};
// bias
alignas(32) float input_bias[HIDDEN_SIZE] {};
alignas(32) float hidden_bias {};
// weights
alignas(32) float input_weights[INPUT_SIZE][HIDDEN_SIZE] {};
alignas(32) float hidden_weights[HIDDEN_SIZE] {};
alignas(32) float activation[HIDDEN_SIZE] {};
std::vector<Summation> summations {};
编译这个没有问题,运行下面的工作没有任何问题:
nn::Evaluator ev1{};
当我尝试创建第二个 Evaluator 时出现问题:
nn::Evaluator ev1{};
nn::Evaluator ev2{};
-->
Process finished with exit code -1073741571 (0xC00000FD)
我将问题追查到
的创建
alignas(32) float input_weights[INPUT_SIZE][HIDDEN_SIZE] {};
但我不知道为什么这会在创建第二个 Evaluator 对象时导致问题,但仅适用于单个 Evaluator。我很高兴能得到任何帮助。
我已经找到问题了。事实证明它不是对齐而是堆栈上的分配。由于二维数组与包含的其他数据相比非常大,它在堆栈上分配了太多内存并导致堆栈溢出。
我正在尝试编写一些对性能至关重要的 C++ 代码。 因此我正在使用 AVX 内在函数并且需要将我的数据对齐到 32 字节。
我正在使用一个看起来与此类似的结构:(我注释掉了它的一部分以追踪问题)
struct Summation {
alignas(ALIGNMENT) float summation[HIDDEN_SIZE] {};
Summation() {
// std::memcpy(summation, inputBias, sizeof(float) * HIDDEN_SIZE);
}
Summation& operator=(const Summation& other) {
// std::memcpy(summation, other.summation, sizeof(float) * HIDDEN_SIZE);
return *this;
}
};
struct Evaluator {
Evaluator(){}
// inputs and outputs
bool inputMap[INPUT_SIZE] {};
// bias
alignas(32) float input_bias[HIDDEN_SIZE] {};
alignas(32) float hidden_bias {};
// weights
alignas(32) float input_weights[INPUT_SIZE][HIDDEN_SIZE] {};
alignas(32) float hidden_weights[HIDDEN_SIZE] {};
alignas(32) float activation[HIDDEN_SIZE] {};
std::vector<Summation> summations {};
编译这个没有问题,运行下面的工作没有任何问题:
nn::Evaluator ev1{};
当我尝试创建第二个 Evaluator 时出现问题:
nn::Evaluator ev1{};
nn::Evaluator ev2{};
-->
Process finished with exit code -1073741571 (0xC00000FD)
我将问题追查到
的创建alignas(32) float input_weights[INPUT_SIZE][HIDDEN_SIZE] {};
但我不知道为什么这会在创建第二个 Evaluator 对象时导致问题,但仅适用于单个 Evaluator。我很高兴能得到任何帮助。
我已经找到问题了。事实证明它不是对齐而是堆栈上的分配。由于二维数组与包含的其他数据相比非常大,它在堆栈上分配了太多内存并导致堆栈溢出。