인프런 커뮤니티 질문&답변
과제질문입니다 // TODO: use promise
해결된 질문
작성
·
253
0
안녕하세요
마지막에
cout << "Future" << endl;
{
const auto sta = chrono::steady_clock::now();
unsigned long long sum = 0;
vector<std::future<int>> futures;
futures.resize(n_threads);
const unsigned n_per_thread = n_data / n_threads; // assumes remainder = 0
for (unsigned t = 0; t < n_threads; ++t)
futures[t] = std::async(dotProductFuture, std::ref(v0), std::ref(v1),
t * n_per_thread, (t + 1) * n_per_thread);
for (unsigned t = 0; t < n_threads; ++t)
sum += futures[t].get();
const chrono::duration<double> dur = chrono::steady_clock::now() - sta;
cout << dur.count() << endl;
cout << sum << endl;
cout << endl;
}
이 코드를 쓰레드와 함께해서 사용해보고 promise 사용해보라고 하셨는데
// TODO: use divide and conquer strategy for std::thread
// TODO: use promise
cout << "Thread future" << endl;
{
const auto sta = chrono::steady_clock::now();
vector<thread> threads;
threads.resize(n_threads);
std::promise<int> p;
auto f = p.get_future();
const unsigned n_per_thread = n_data / n_threads; // assumes remainder = 0
for (unsigned t = 0; t < n_threads; ++t)
threads[t] = std::thread(dotProductEx1, std::ref(v0), std::ref(v1),
t * n_per_thread, (t + 1) * n_per_thread, move(p));
for (unsigned t = 0; t < n_threads; ++t)
threads[t].join();
const chrono::duration<double> dur = chrono::steady_clock::now() - sta;
int i = f.get();
cout << dur.count() << endl;
cout << i << endl;
cout << endl;
}
void dotProductEx1(const vector<int> &v0, const vector<int> &v1,
const unsigned i_start, const unsigned i_end, std::promise<int> &&p)
{
int sum = 0; // local sum
for (unsigned i = i_start; i < i_end; ++i)
sum += v0[i] * v1[i]; //
p.set_value(sum);
}
이렇게 해봤는데
런타임에러가 나네요 ㅜㅜ
어떻게 해야할지 좀 알려주시면 감사하겠습니다
너무헷갈리네요..
답변 1
6
스레드는 vector 사용해서 n_thread 개수 만큼의 스레드들을 사용하고 계신데
이에 반하여 promise와 future 객체는 딱 한개씩만 선언하셨어요 std::promise<int> p; auto f = ..이렇게요..!
스레드는 여러개인데 각 스레드들에 단 하나의 promise, future 객체를 적용하셔서 런타임 에러가 난 것 같아요.
스레드가 여러개라면 promise 객체도 여러개여야겠죠? 각 스레드마다 약속할 수 있는 것들이 다 다를테니까요. 하는일도 각각 다 다르니까!
이렇게 고쳐보시면 어떨까 싶어요. promise, future 객체도 numThread 개수의 배열(vector)로 선언해주고 각 스레드에게 배정할 수 있게 해주세요.






감사합니다!!!!^^