코드 실행속도가 너무 느립니다.
208
작성한 질문수 7
강의를 보고 따라한 아래 코드의 실행속도가 강사님에 비해 너무나 느립니다. 실행환경의 문제인가요??
#include<iostream>
#include<thread>
#include<atomic>//나눌 수 없다는 뜻. 쓰레드에서 연산이 한번에 이루어지도록 함
#include<mutex>
#include<chrono>
using namespace std;
mutex mtx;
int main()
{
//atomic<int> shared_memory(0);
int shared_memory(0);
auto count_func = [&]() {
for (int i = 0; i < 1000; ++i)
{
//cout << shared_memory << endl;
this_thread::sleep_for(chrono::milliseconds(1));
//doSomething;
//mtx.lock();
//std::lock_guard lock(mtx);//unlock필요없음
std::scoped_lock lock(mtx);
shared_memory++;
//shared_memory.fetch_add(1);
//mtx.unlock();
//shared memory의 값을 더할 떄의 과정
//1.shared memory값을 cpu로 가져옴
//2.1더함
//3.sharedmemory에 결과 저장
//값을 읽어들었을 때, 값이 바뀌면 더하기가 씹혀버림 => 잘못된 결과
//해결법
//1. atomic 사용
//2. fetchadd
//3. mutex lock
}
};
thread t1 = thread(count_func);
thread t2 = thread(count_func);
t1.join();
t2.join();
std::cout << "After" << endl;
std:: cout << shared_memory << endl;
return 0;
}
답변 1
1
안녕하세요, 질문&답변 도우미 Soobak 입니다.
실행 환경에 따라서 결과가 달라질 수는 있습니다.
한 번, 다른 프로그램, 프로세스 등이 자원을 많이 사용하고 있지는 않은지 확인해보세요.
추가적으로, 제가 질문자님께서 첨부해주신 코드를 통해 컴파일 및 프로그램을 실행했을 때는 강의와 동일하게 결과가 출력되네요.
강의자료는 어디서 받을 수 있죠?
1
16
2
교재 있나요?
1
136
2
11:11 부근에 Something::temp와 Something::getValue의 앞에 &를 붙이는 이유가 뭔가요? (함수 이름은 포인터(주소)가 아닌가요?)
1
90
3
using namespace std; 선언 후에 std::를 하는 이유가 궁금합니다
1
101
2
cstr직접구현
0
115
3
BubbleSort
1
77
2
숙제 마지막 부분
1
78
2
강의와 똑같이 진행했는데 링킹 에러가 발생합니다.
1
94
2
수업할때 레퍼런스로 사용하는 도서는 어떤 도서인가요??
1
163
2
공변반환형 관련 문의 드립니다.
1
89
2
170강 유니크 포인터에대해 질문있습니다
1
80
1
섹션 5 퀴즈의 답이 이상합니다
1
83
2
이중포인터와 배열이 이해가 안됩니다.
1
158
2
5분 17~5분 34초 객체 잘림 질문
1
78
1
Resource.h 코드 알려주세요
1
71
1
char name[] 배열의 길이와 관련해 일부 궁금점이 생겨서 질문합니다
1
94
2
화면좌측 숫자 보이기
1
114
1
화면 좌측 숫자 보이기
0
66
1
처음 c++ 수강하려는데요. 비주얼스튜디오 2022 다운로드해서 설치하면 되는건가요??
1
137
3
46강 string 버퍼 질문입니다
1
80
2
프로그래머스 수열과 구간 쿼리 2 문제 질문입니다.
1
123
2
[] 범위 검사시 assert 사용 관련 질문
1
89
2
Lecture 클래스 멤버변수 명명 관련
0
91
2
프로그래머스의 대소문자 바꿔서 출력하기 문제를 푸는데요
0
73
1





