수업자료로 시간 단축 해보는 중에 궁금한게 생겨 질문드립니다.
300
작성한 질문수 1
안녕하세요 수강생입니다.
연습문제 보던중 재미있는 생각이나서 테스트중이었는데요.
수업자료에서의 방법으로 작업하면
총 100의 일이 있을때 코어가 4개면
1~25/26~50/51~75/76~100
이렇게 나누어진다 생각하였고
상대적으로 1~25이 빨리끝나고 76~100이 늦게 끝나니
시간적으로 손해가 생긴다 생각하였습니다.
그리하여 저는 CountPrime 함수 부분을 수정하였는데
start=i ,end=Max_NUMBER로 받아오고
(i는 main함수부의 for(int i=0;i<coreCount;i++)의 i입니다.)
추가로 coreCount를 받아와서
for ( int number = start; number<end; number+=coreCount)
로 구현하였습니다.
이러면 제 생각으로는
100개의 일을 4개의 코어가 나누어 일한다고 치면
코어1 : 1 5 9 13 17~~
코어2 : 2 6 10 14 18~~
코어3 : 3 7 11 15 19~~
코어4 : 4 8 12 16 20~~
이런 방식으로 나누어서 작업하고,
상대적으로 오래걸리는 76~100번대 일을
코어들이 골고루 나눠받은만큼
소요시간 역시 적게 걸릴것이라 예상했습니다.
그러나 결과적으로 소요시간은 같게나왔으며
생각하지못한 CPU 이용률에서 차이가 났습니다.
(기존방식 cpu 100% 수정시 cpu 60%)
참고로 Max값은 100,000,000으로 잡고 진행하였고
소요시간은 33초 ~ 34초 근처로 나왔습니다.
질문드리고 싶은것은 위 상황에서 소요시간 차이가 거의 나지않는 이유와
CPU 사용량에 차이가 나게되는 이유를 알고싶습니다.
답변 1
2
측정 시간은 굉장히 다양한 요소가 영향을 줄 수 있는데요.
가령 +1은 INC 명령어로 더 빠르게 처리 할 수 있기도 하고,
캐시 관련 부분에서 차이가 난 것일 수도 있고
정확한 이유는 저도 알 수 없습니다.
writeLock을 잡을때 꼭 empty 상태여야하는 이유?
0
63
2
Memory Pool에서 오버플로우 질문입니다.
0
94
2
포토폴리오 및 진로 관련하여 고민입니다.
0
168
1
포토폴리오 관련 고민입니다.
0
90
1
실무에서도 alloc, 스마트포인터 등을 구현해서 쓰는지 궁금합니다.
0
107
2
성능 테스트 결과
0
117
2
게임 서버 Stateful, Stateless 진로 고민
0
144
1
WaitOnAddress와 Sleep의 차이 질문
0
98
1
궁금한거 있습니다.
0
92
2
JobTimer 구동 스레드
0
116
2
TryPop() 동작 관련 질문
0
86
1
로드맵 C#서버 C++서버 방향성 질문
0
162
2
스레드 id를 출력할떄 메인스레드 id도 출력되나요?
0
81
1
생명주기를 위한 의도적 복사
0
94
2
락프리의 실무에서 사용 질문
0
154
2
32bit threadID와 16비트 상위 WriteFlag에 대해
0
109
2
mutex와 sleep 차이점
0
133
1
실무에서는 어떠한 코드 스타일을 사용하는지 궁금합니다
0
167
2
Stomp Allocator의 Release함수에 대한 질문입니다.
0
102
1
공부법 관련해서
0
190
2
MakeShared 함수 관련
0
118
1
지금까지 서버코어에서 만든 내용에 대해 궁금한 점이 있어서 질문 드립니다.
0
152
2
운영체제관련 질문입니다
0
144
1
send하려는 데이터 크기가 크면 memcpy에서 문제가 발생할 것 같습니다.
0
125
2





