Я впервые использую потоки и сталкиваюсь со странной ошибкой сегментации всякий раз, когда вызываемая функция принимает очень большие массивы.
#include <iostream>
#include <thread>
#include <cmath>
const int dimension = 100000; // Dimension of the array
// Create a simple function of an array
void absolut(double *vec) {
double res = 0.;
for (int i = 0; i < dimension; i++) {
res += vec[i] * vec[i];
}
std::cout << std::sqrt(res) << std::endl;
}
int main() {
// Define arrays
double p[dimension], v[dimension];
for (int i = 1; i < dimension; i++) {
p[i] = 1./double(i);
v[i] = 1./double(i)/double(i);
}
// use multithreading
std::thread t1(absolut, p);
std::thread t2(absolut, v);
t1.join();
t2.join();
return 0;
}
Программа работает нормально, но если я увеличу dimension
массивов в 10 раз, я получу ошибку сегментации. Кто-нибудь знает, почему это происходит и как это исправить?
размер стека ограничен. Темы здесь не очень актуальны
Вы бы столкнулись с тем же, если бы удалили все потоки. Это одна из причин для создания минимальный воспроизводимый пример в первую очередь.
double p* = new double[dimension];
double v* = new double[dimension];
Я думаю, что это компилируется из-за ограничений размера, определенных компилятором, возможно, с использованием динамического распределения.
Спасибо, вместо этого я использовал std::vector
, но, видимо, все, что находится в куче, в порядке.
@tomtom1-4 -- Давай с std::vector
. Использование new[]/delete[]
больше не рекомендуется, если у вас нет для этого веских причин.
Код OP также компилируется. И это также может привести к сбою во время выполнения (хотя гораздо менее вероятно)
2 * 100000 * 8
байт помещаются в общий стек, в 10 раз меньше. Разместите их в куче, например, используйте для нихstd::vector
илиnew
.