Почему добавление функции не влияет на поток С++ 11?
Я пытаюсь изучить поток С++ 11 и иметь следующий код:
#include <iostream>
#include <thread>
#include <vector>
#include <mutex>
#include <algorithm>
void add(int& i){
std::mutex some_mutex;
// std::cout << " I am " << std::endl;
std::lock_guard<std::mutex> guard(some_mutex);
i++;
}
int main(){
int i = 0;
std::vector<std::thread> vec_threads;
for(int i = 0; i < 10; i++){
vec_threads.push_back(std::thread(add,std::ref(i)));
}
std::for_each(vec_threads.begin(),vec_threads.end(),
std::mem_fn(&std::thread::join));
std::cout<< " i = " << i << std::endl;
return 0;
}
Я создал vector
, который содержит std::thread
, и я вызываю функцию add из каждого потока и передаю я по ссылке. После того, что я предположил, что поток будет делать (добавление i = i+1
), конечный результат не отражает то, что я хотел.
вывод: я = 0
ожидаемый выход: я = 10
Ответы
Ответ 1
Для получения правильного результата необходимо обмениваться файлами Mutex между потоками. И i
затеняется переменной цикла, замените ее на j
.
#include <iostream>
#include <thread>
#include <vector>
#include <mutex>
#include <algorithm>
void add(int& i, std::mutex &some_mutex){
// std::cout << " I am " << std::endl;
std::lock_guard<std::mutex> guard(some_mutex);
i++;
}
int main(){
int i = 0;
std::vector<std::thread> vec_threads;
std::mutex some_mutex;
for(int j = 0; j < 10; j++){
vec_threads.push_back(std::thread(add,std::ref(i), std::ref(some_mutex)));
}
std::for_each(vec_threads.begin(),vec_threads.end(),
std::mem_fn(&std::thread::join));
std::cout<< " i = " << i << std::endl;
return 0;
}