19.6 멀티쓰레딩 예제 실행시간 질문
228
작성한 질문수 86
강의 11:08초에 예제를 실행시킬 때 교수님께서는
0.08초 이런식으로 1초가 걸리지 않는 시간에 내적 결과값이 나옵니다
하지만 제 컴퓨터의 경우에는(8코어 16쓰레드 입니다) 결과 값이 도출되기까지 4분이 소요됩니다.
const unsigned n_threads = 4; 의 숫자를 키워봐도 시간이 빨라지지 않습니다.
ctrl+F5로 프로그램을 실행 시킨 후
CPU 이용률을 살펴 봐도 평상시처럼 5%대라고 나와 있습니다. CPU가 벡터 예제를 전혀 연산하지 않는 것 같습니다.
또한
비주얼 스튜디오 속도 빠르게 하기로 구글링 하여 프로젝트 속성-> C/C++-> 일반에서 다중 프로세서 컴파일에 예라고 설정을 변경 한 후 프로젝트를 빌드하면 CPU 이용률이 100%까지 치솟으며 빌드는 1초도 안되서 끝납니다.
빌드는 1초도 안되어서 실행파일을 형성 시키는데 정작 실행파일 자체는 3~4분이 걸리는 이 현상,
뭐가 문제인가요?
답변 3
0
3~4분 있으면 CPU 이용률이 30~40프로로 바뀌면서 연산을 시작하는(?) 느낌을 받습니다. 그런데 그마저도 시간을 측정하는 것에
따라 출력된 값이
4초 3초 30초 4초 이런식입니다.
또한 제가 디버그를 위해
cout << "std::inner_product" << endl;
{
const auto sta = chrono::steady_clock::now();
const auto sum = std::inner_product(v0.begin(), v0.end(), v1.begin(), 0ull);
const chrono::duration<double> dur = chrono::steady_clock::now() - sta;
//계산한 시간 출력
cout << dur.count() << endl;
cout << sum << endl;
cout << endl;
}
이 코드의 맨 위 cout에 중단점을 찍은 후 F11로 한 줄 씩 실행을 눌러봐도 디버그가 작동을 하지 않습니다. 즉 디버깅 또한 먹히지 않는 상황입니다. 동일한 코드인데 어떤점이 문제인가요?
변수가 메모리에 저장되는 것을 알려주는 강의가 어떤강의였죠
1
464
1
메모리 주소 10진수로 출력
1
653
1
클래스 템플릿 특수화에서 boolalpha로 표현된 리턴값에 대해 질문이 있습니다.
1
498
1
여러가지 리턴 타입에 관한 강의가 어떤 걸까요?
1
534
1
메모리 주소에 관한 질분
0
679
1
인터페이스 클래스에서 reportError의 매개변수에 대해 궁금한 것이 있습니다.
0
549
1
형변환 오버로딩에서 const 관련 질문이 있습니다.
0
443
1
Digit 뒤에 reference를 사용하는 이유
0
510
1
4.2 전역 변수, 정적 변수, 내부 연결, 외부 연결
0
322
1
dat파일이...
0
538
1
TODO:대입 연산자 오버로딩에 대한 소스코드입니다.
0
643
1
복사 생성자 관련 질문이 있습니다.
0
454
1
수업 중 궁금한점이 있습니다.
1
389
1
라이브러리자체가 이해가 되지 않습니다.
0
561
1
마지막 예제 질문
0
302
1
증감연산자 위치에 따른 수행 순서 질문입니다.
0
374
1
단항 연산자 오버로딩에서 return 부분에 질문이 있습니다.
1
410
1
friend함수 관련 질문이 있습니다.
0
311
1
operator+ 정의부분에서 궁금한 것이 있습니다.
0
447
1
3분 17초 질문
0
350
1
함수에 값을 대입한다는 개념이 이해가 되지 않습니다.
0
447
1
int getvalue() const에서 const는 왜 뒤에 붙는건가요?
0
443
2
const Something &st에서 const를 빼면 안되나요?
0
300
1
friend함수는 다른 클래스의 멤버함수로 쓸 수 없나요??
1
492
1





