在計(jì)算機(jī)科學(xué)中,鎖是一種同步機(jī)制,用于在存在多線程的環(huán)境中實(shí)施對(duì)資源的訪問(wèn)限制。你可以理解成它用于排除并發(fā)的一種策略。
例子
if(lock == 0) {
lock = myPID;
}
上面這段代碼并不能保證這個(gè)任務(wù)有個(gè)鎖,因此它可以在同一時(shí)間被多個(gè)任務(wù)執(zhí)行。這個(gè)時(shí)候就有可能多個(gè)任務(wù)都檢測(cè)到lock是空閑的,因此兩個(gè)或者多個(gè)任務(wù)都將嘗試設(shè)置lock,而不知道其他的任務(wù)也在嘗試設(shè)置lock。這個(gè)時(shí)候就會(huì)出問(wèn)題了。
在iOS中,鎖分為遞歸鎖、條件鎖、分布式鎖、一般鎖
對(duì)于數(shù)據(jù)庫(kù)的鎖分類(lèi):
鎖的作用
這個(gè)比較通俗來(lái)講:就是為了防止在多線程(多任務(wù))的情況下對(duì)共享資源(臨界資源)的臟讀或者臟寫(xiě)。也可以理解為:執(zhí)行多線程時(shí)用于強(qiáng)行限制資源訪問(wèn)的同步機(jī)制,即并發(fā)控制中保證互斥的要求。