pthread_rwlock使用錯誤
寫鎖之后讀鎖竟然沒有阻塞, 順利運行下去了.
據常理,寫鎖之后,試圖讀加鎖時會阻塞.
代碼如:
pthread_rwlock_t rwl;
cout << "init: " << pthread_rwlock_init(&rwl, NULL) << endl;
cout << "wrlock: " << pthread_rwlock_wrlock(&rwl) << endl;
cout << "rdlock: " << pthread_rwlock_rdlock(&rwl) << endl;
cout << "unlock: " << pthread_rwlock_unlock(&rwl) << endl;
cout << "unlock: " << pthread_rwlock_unlock(&rwl) << endl;
cout << "wrlock: " << pthread_rwlock_wrlock(&rwl) << endl; // DEAD!
cout << "unlock: " << pthread_rwlock_unlock(&rwl) << endl;
輸出為:
init: 0
wrlock: 0
rdlock: 35
unlock: 0
unlock: 0
程序會死鎖在接下來的寫鎖定上. 35錯誤號為EDEADLK, 意為出現死鎖.
仔細研究pthread讀寫鎖的文檔, 才發現原來如果一個線程寫鎖定后,
又調用pthread_rwlock_rdlock函數來讀鎖定,結果將無法預測。
Results are undefined if the calling thread currently owns a write lock on rwlock.
但是pthread_rwlock_rdlock()的man文檔卻對此沒有明確指出.
參考:
讀寫鎖 ( http://www.duangw.net/computer/history/pthread/rwlock.html )
pthread_rwlock_rdlock(3T) ( http://docs.hp.com/en/B2355-60103/pthread_rwlock_rdlock.3T.html )
不管怎樣, pthread_rwlock_rdlock()都應該判斷返回值,
因為有可能同時讀太多會返回EAGAIN.
這樣pthread_rwlock使用起來就麻煩許多.
查看了boost::thread, 它好像就沒用pthread的讀寫鎖.
(轉載請注明來源于金慶的專欄)
寫鎖之后讀鎖竟然沒有阻塞, 順利運行下去了.
據常理,寫鎖之后,試圖讀加鎖時會阻塞.
代碼如:
pthread_rwlock_t rwl;
cout << "init: " << pthread_rwlock_init(&rwl, NULL) << endl;
cout << "wrlock: " << pthread_rwlock_wrlock(&rwl) << endl;
cout << "rdlock: " << pthread_rwlock_rdlock(&rwl) << endl;
cout << "unlock: " << pthread_rwlock_unlock(&rwl) << endl;
cout << "unlock: " << pthread_rwlock_unlock(&rwl) << endl;
cout << "wrlock: " << pthread_rwlock_wrlock(&rwl) << endl; // DEAD!
cout << "unlock: " << pthread_rwlock_unlock(&rwl) << endl;
輸出為:
init: 0
wrlock: 0
rdlock: 35
unlock: 0
unlock: 0
程序會死鎖在接下來的寫鎖定上. 35錯誤號為EDEADLK, 意為出現死鎖.
仔細研究pthread讀寫鎖的文檔, 才發現原來如果一個線程寫鎖定后,
又調用pthread_rwlock_rdlock函數來讀鎖定,結果將無法預測。
Results are undefined if the calling thread currently owns a write lock on rwlock.
但是pthread_rwlock_rdlock()的man文檔卻對此沒有明確指出.
參考:
讀寫鎖 ( http://www.duangw.net/computer/history/pthread/rwlock.html )
pthread_rwlock_rdlock(3T) ( http://docs.hp.com/en/B2355-60103/pthread_rwlock_rdlock.3T.html )
不管怎樣, pthread_rwlock_rdlock()都應該判斷返回值,
因為有可能同時讀太多會返回EAGAIN.
這樣pthread_rwlock使用起來就麻煩許多.
查看了boost::thread, 它好像就沒用pthread的讀寫鎖.
(轉載請注明來源于金慶的專欄)