讀寫鎖使用場景 忽然想不通了,Java里的讀寫鎖里的讀鎖有什么用?
忽然想不通了,Java里的讀寫鎖里的讀鎖有什么用?讀寫鎖:reentrantreadwritelock如果許多線程從數(shù)據(jù)結(jié)構(gòu)中讀取數(shù)據(jù),而很少有線程修改數(shù)據(jù),則使用讀寫鎖。分別獲取讀鎖和寫鎖:reen
忽然想不通了,Java里的讀寫鎖里的讀鎖有什么用?
讀寫鎖:reentrantreadwritelock如果許多線程從數(shù)據(jù)結(jié)構(gòu)中讀取數(shù)據(jù),而很少有線程修改數(shù)據(jù),則使用讀寫鎖。分別獲取讀鎖和寫鎖:reentrantreadwritelock rrwl=new reentrantreadwritelock()readlock readl=rrwl.readLock文件()WriteLock writeL=rrwl.writeLock文件()讀鎖和讀鎖不是互斥的,讀鎖和寫鎖是互斥的,寫鎖和寫鎖是互斥的。它用于優(yōu)化性能和提高讀寫速度。
多個線程可以讀一個變量,只有一個線程可以對這個變量進行寫,到底要不要加鎖?
下面簡要說明以下原因:
鎖定是因為操作不是原子的。讓我們用操作一來解釋它。看下面兩個圖。
我這個操作需要
看上面的第二個圖,你能很清楚地理解這個過程嗎?
鎖定是為了確保上述三個步驟是原子操作。
回到問題上來,只有一個線程要寫,沒有競爭,所以不需要鎖定。
但是,如果你看第一張圖片,因為主內(nèi)存和本地內(nèi)存的存在
在一個線程寫入后,其他線程無法立即看到它。這就是可見性問題。
添加volatile關(guān)鍵字后,它將在操作后強制工作內(nèi)存和主內(nèi)存同步,以確保其他線程可以立即看到它。
讀鎖和寫鎖有什么本質(zhì)的區(qū)別呀?
共享鎖也稱為讀鎖。如果事務t將s鎖添加到數(shù)據(jù)對象a,則事務t可以讀取a,但不能修改a。其他事務只能將s鎖添加到a,而不能添加x鎖,直到t釋放a上的s鎖。這確保了其他事務可以讀取a,但在t釋放a上的s鎖之前,t不能對a進行任何更改。
獨占鎖(x鎖)也稱為寫入鎖上。如果事務t對數(shù)據(jù)對象a應用x鎖,則事務t可以讀取a或修改a。在t釋放a上的鎖之前,其他事務無法對a應用任何鎖。這確保了在t釋放a上的鎖之前,其他事務無法讀取和修改a。
通過讀書,你學到了哪些解決問題的方法?
感謝您的邀請。這是個好問題!舉個例子
!記得小學三年級時,學過一篇課文《釣魚》,時間久了,題目也不確定。那篇課文講述了捕魚的整個過程。過去,林園總是羨慕魚,看到大人釣魚,但他們從小就不理我,不肯教我。自從學習了這篇課文,我就知道如何釣魚了。我買了一條釣魚線,從家里的床上拿了一根竹竿當釣竿,按照課文學習的方法開始釣魚。
從此,一發(fā)不可收拾,每天放學、放假,都會去釣魚。而且捕魚的種類也很奇怪。比如,除了正常的魚類,還有泥鰍、龍蝦、河蝦、貽貝、螃蟹、鯰魚、黑魚、鰻魚等。我總是覺得這些很奇怪,我經(jīng)常談論它們。
互斥鎖和讀寫鎖的區(qū)別?
我缺乏天賦和學識。我給你一個簡短的回答。
:有互斥鎖、讀寫鎖、信號量和條件變量。信號量和互斥量也可以在進程之間使用,SEM是從它的名字ut定義的,我們可以看到它不是專用于線程的(帶有pthread的通用名稱);信號量是互斥量的增強版本(1->N);條件變量與互斥量一起使用來實現(xiàn)線程阻塞,而線程阻塞本身不是鎖。
:mutex(初始化時將屬性修改為shared pthread) mutexattr Setpshared function);文件鎖是進程中應用的一種鎖。由于多線程是通過修改文件描述符所指向的文件結(jié)構(gòu)中的成員變量來實現(xiàn)的,因此不能在線程之間使用文件鎖。