作者cris122 (總是很多心事)
看板C_and_CPP
標題[問題] multi-thread 共用函數的問題
時間Thu Jan 21 11:22:39 2016
開發平台(Platform): (Ex: VC++, GCC, Linux, ...)
Linux
額外使用到的函數庫(Library Used): (Ex: OpenGL, ...)
gcc pthread
問題(Question):
一般在 multithread 共用函數時會Lock,
但請教在什麼情況下可以不用 Lock?
或者說在什麼情況下一定要 Lock?
寫了一個 sample 不 Lock 執行不會有錯誤
程式碼(Code):(請善用置底文網頁, 記得排版)
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <unistd.h>
pthread_t thread_id_1 = 0;
pthread_t thread_id_2 = 0;
int sum = 0;
void common(int x) {
sum += x;
}
void thread_func_1() {
int i;
for (i = 0; i < 100; i++) {
common(-1);
}
printf("thread1 end\n");
}
void thread_func_2() {
int i;
for (i = 0; i < 100; i++) {
common(1);
}
printf("thread2 end\n");
}
void thread_create_1() {
int rc = 0;
rc = pthread_create(&thread_id_1, NULL, (void *) &thread_func_1, NULL);
if (rc) {
fprintf(stderr, "ERROR; return code from pthread_create() is %d\n", rc);
return;
}
}
void thread_create_2() {
int rc = 0;
rc = pthread_create(&thread_id_2, NULL, (void *) &thread_func_2, NULL);
if (rc) {
fprintf(stderr, "ERROR; return code from pthread_create() is %d\n", rc);
return;
}
}
void thread_wait_1() {
if (thread_id_1 != 0) {
pthread_join(thread_id_1, NULL);
printf("thread 1 stopped\n");
}
}
void thread_wait_2() {
if (thread_id_2 != 0) {
pthread_join(thread_id_2, NULL);
printf("thread 2 stopped\n");
}
}
int main(void) {
thread_create_1();
thread_create_2();
thread_wait_1();
thread_wait_2();
printf("sum = %d\n", sum);
return EXIT_SUCCESS;
}
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 111.249.106.112
※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1453346562.A.A83.html
推 stupid0319: 等碰到BUG時就是Lock的時機!!! 01/21 12:05
→ Caesar08: 當多個thread對同個object執行任何改變狀態的操作時 01/21 12:09
→ Caesar08: 例如說sum就應該要是atomic才行 01/21 12:10
→ Caesar08: 因為你這邊只是單純++--,所以不會有錯誤 01/21 12:12
→ Caesar08: 但你sum最後的值不一定是0 01/21 12:13
→ Caesar08: 順帶一提,C11與C++11都有thread支援,沒必要的話,不需 01/21 12:14
→ Caesar08: 使用pthread 01/21 12:14
→ Caesar08: 更正我第一句: 當多個thread"可能同時"對同個object 01/21 12:18
→ Caesar08: 執行任何改變狀態的操作時 01/21 12:18
推 IKAFIRE: 不是不爆只是時候未到 01/21 12:27
→ hichcock: 推一樓 01/21 13:08
推 Clangpp: 基本上存取變更會遇到 但是要看他的值是不會 01/21 13:45
推 longlongint: 執行一億次試試看啊 01/21 17:07
推 littleshan: 即使只有一個thread寫入,只要有其它thread讀取 01/21 18:27
→ littleshan: 都有很高的機會造成race condition 01/21 18:27
→ kwk22: 推1F, 很低的機率遇到core dump時就會知道要lock了...XD 01/22 06:38
推 saxontai: C11的thread library有實作品了嗎?@@ 01/22 12:14
→ ah7675: 先去學完作業系統再回來寫 01/24 17:00