考慮下面的代碼:
vector<int>v;

vector<int>::iterator first5(find(v.begin(),v.end(),5)); //
..(1)
if(first5!=v.end()) //
..(2)
doSomething();
假如在多線程環(huán)境中,當語句執(zhí)行到第(1)句時,另一個線程可能會奪取CPU的控制權(quán)并且改變v的值,比如往v里面插入一些元素。這樣v的所有的迭代器都將失效,包括first5.
要做到線程安全,必須從第1句到第3句保持鎖住狀態(tài)。
可以定義一個Lock類
template<typename Container>
class Lock
{
public:
Lock(const Container & container):c(container)
{
getMutexFor(c);
}
~Lock()
{
releaseMutexFor(c);
}
private:
const Container & c;
};
使用時:
vector<int>v;

{
Lock< vector<int> > Lock(v);
vector<int>::iterator first5(find(v.begin(),v.end(),5)); //
..(1)
if(first5!=v.end()) //
..(2)
doSomething();
}
這樣,當這個代碼段結(jié)束時,Lock會調(diào)用析構(gòu)函數(shù),釋放v的互斥鎖。
這樣實現(xiàn)比如下實現(xiàn)有很多優(yōu)點:
vector<int>v;

getMutexFor(v);
vector<int>::iterator first5(find(v.begin(),v.end(),5)); //
..(1)
if(first5!=v.end()) //
..(2)
doSomething();
releaseMutexFor(v);
1、更好的封裝性
2、防止releaseMutexFor(v)忘記寫,從而v的互斥鎖沒法釋放
3、C++保證,如果有異常,局部變量會被析構(gòu)。所以,即便在我們使用Lock對象時出現(xiàn)異常,互斥鎖依然可以正常釋放。但是如果用下面的實現(xiàn)方式,如果在執(zhí)行完getMutexFor(v)后出現(xiàn)異常,releaseMutexFor(v)就不會執(zhí)行了。