色欲av一区久久精品_久久综合色综合色88_无码在线观看不卡_色黄视频网站_亚洲国产精品久久久久秋霞66

Java synchronized 關(guān)鍵字詳解

時(shí)間:2023-05-16

Javasynchronized關(guān)鍵字詳解
前置技能點(diǎn)
進(jìn)程和線(xiàn)程的概念
線(xiàn)程創(chuàng)立方式
線(xiàn)程的狀態(tài)狀態(tài)轉(zhuǎn)換
線(xiàn)程安全的概念
synchronized關(guān)鍵字的幾種用法
潤(rùn)飾非靜態(tài)成員辦法
synchronizedpublicvoidsync(){
}
潤(rùn)飾靜態(tài)成員辦法
synchronizedpublicstaticvoidsync(){
}
類(lèi)鎖代碼塊
synchronized(類(lèi).class){
}
目標(biāo)鎖代碼塊
synchronized(this|目標(biāo)){
}
synchronized潤(rùn)飾非靜態(tài)辦法時(shí)能夠看做是鎖this目標(biāo),潤(rùn)飾靜態(tài)辦法時(shí)能夠看做是鎖辦法地點(diǎn)的類(lèi)。
synchronized關(guān)鍵字的根本機(jī)制
各個(gè)線(xiàn)程想要拜訪被synchronized潤(rùn)飾的代碼塊,就要取得synchronized聲明的鎖。假如兩個(gè)線(xiàn)程的目標(biāo)是同一個(gè)鎖,就會(huì)呈現(xiàn)阻塞的現(xiàn)象,所以?xún)蓚€(gè)線(xiàn)程不能同時(shí)拜訪同一個(gè)鎖下的代碼,保證了多線(xiàn)程在履行時(shí)終究成果不會(huì)犯錯(cuò)。這與同享變量是否為靜態(tài)無(wú)關(guān)。java手寫(xiě)多級(jí)緩存
幾個(gè)比如
目標(biāo)鎖
publicclassThreadDemoextendsThread{@Overridepublicsynchronizedvoidrun(){for(inti=0;i<10000;i++){
Main.i++;
}
System.out.println(“履行完結(jié)”);
}
}
直接將承繼的run()辦法標(biāo)記為synchronized,作用是對(duì)Main類(lèi)中的i變量做10000次累加操作。
publicclassMain{staticinti=0;publicstaticvoidmain(String[]args)throwsInterruptedException{
ThreadDemothreadDemo=newThreadDemo();
Threadt1=newThread(threadDemo);
Threadt2=newThread(threadDemo);
Threadt3=newThread(threadDemo);
Threadt4=newThread(threadDemo);
t1.start();
t2.start();
t3.start();
t4.start();
t1.join();
t2.join();
t3.join();
t4.join();
System.out.println(i);
}
}//輸出成果://履行完結(jié)//履行完結(jié)//履行完結(jié)//履行完結(jié)//40000
能夠看到當(dāng)4個(gè)線(xiàn)程悉數(shù)履行結(jié)束之后,變量i成功的累加了40000次,沒(méi)有呈現(xiàn)丟失操作的狀況。
假如咱們將main()辦法修正如下:
publicstaticvoidmain(String[]args)throwsInterruptedException{
Threadt1=newThreadDemo();
Threadt2=newThreadDemo();
Threadt3=newThreadDemo();
Threadt4=newThreadDemo();
t1.start();
t2.start();
t3.start();
t4.start();
t1.join();
t2.join();
t3.join();
t4.join();
System.out.println(i);
}//輸出成果://履行完結(jié)//履行完結(jié)//履行完結(jié)//履行完結(jié)//27579
能夠看到丟失了不少的累加操作。調(diào)查前后兩個(gè)main()辦法創(chuàng)立線(xiàn)程的方式能夠發(fā)現(xiàn),前面的main()辦法是使用了同一個(gè)目標(biāo)來(lái)創(chuàng)立了4個(gè)不同的線(xiàn)程,而后一個(gè)main()辦法使用了4個(gè)不同的ThreadDemo目標(biāo)創(chuàng)立了4個(gè)線(xiàn)程。咱們用synchronized潤(rùn)飾的是一個(gè)非靜態(tài)成員函數(shù),相當(dāng)于對(duì)該辦法創(chuàng)立了this的目標(biāo)鎖。在第一個(gè)main()辦法中使用同一個(gè)目標(biāo)來(lái)創(chuàng)立4個(gè)不同線(xiàn)程就會(huì)讓4個(gè)線(xiàn)程搶奪同一個(gè)目標(biāo)鎖,這樣,在同一時(shí)間內(nèi),僅能有一個(gè)線(xiàn)程能拜訪synchronized潤(rùn)飾的辦法。而在第二種main()辦法中,4個(gè)線(xiàn)程各自對(duì)應(yīng)一個(gè)目標(biāo)鎖,4個(gè)線(xiàn)程之間沒(méi)有競(jìng)賽關(guān)系,目標(biāo)鎖自然無(wú)法收效。
類(lèi)鎖
publicclassThreadDemoextendsThread{@Overridepublicvoidrun(){synchronized(ThreadDemo.class){for(inti=0;i<10000;i++){
Main.i++;
}
System.out.println(“履行完結(jié)”);
}
}
}
將潤(rùn)飾辦法的synchronized改為對(duì)ThreadDemo.class上鎖的代碼塊
publicclassThreadDemo2extendsThread{@Overridepublicvoidrun(){synchronized(ThreadDemo2.class){for(inti=0;i<10000;i++){
Main.i++;
}
System.out.println(“履行完結(jié)”);
}
}
}
再創(chuàng)立一個(gè)相同的類(lèi)命名為T(mén)hreadDemo2,與ThreadDemo不同的是,ThreadDemo2中,synchronized對(duì)ThreadDemo2.class上鎖。
publicstaticvoidmain(String[]args)throwsInterruptedException{
Threadt1=newThreadDemo();
Threadt2=newThreadDemo();
Threadt3=newThreadDemo2();
Threadt4=newThreadDemo2();
t1.start();
t2.start();
t3.start();
t4.start();
t1.join();
t2.join();
t3.join();
t4.join();
System.out.println(i);
}//輸出成果://履行完結(jié)//履行完結(jié)//履行完結(jié)//履行完結(jié)//33054
4個(gè)線(xiàn)程別離由ThreadDemo和ThreadDemo2來(lái)創(chuàng)立,明顯得到的成果與預(yù)期的40000不符。假如咱們將ThreadDemo2中的synchronized改為對(duì)ThreadDemo.class上鎖:
publicclassThreadDemo2extendsThread{@Overridepublicvoidrun(){synchronized(ThreadDemo.class){for(inti=0;i<10000;i++){
Main.i++;
}
System.out.println(“履行完結(jié)”);
}
}
}//輸出成果://履行完結(jié)//履行完結(jié)//履行完結(jié)//履行完結(jié)//40000
能夠看到,雖然是聲明在兩個(gè)不同的類(lèi)中的synchronized代碼塊,可是由于都是對(duì)ThreadDemo.class上鎖,所以4個(gè)線(xiàn)程之間還是建立了競(jìng)賽關(guān)系,同時(shí)只能有一個(gè)線(xiàn)程拜訪被synchronized潤(rùn)飾的代碼。
總結(jié)
所以synchronized關(guān)鍵字的本質(zhì)是約束線(xiàn)程拜訪一段代碼,而約束的條件就是,在所有被加上相同鎖的代碼上,同一時(shí)間,只能有一個(gè)線(xiàn)程在運(yùn)行。這與你要修正什么樣的同享變量無(wú)關(guān)。在我剛接觸到的時(shí)候認(rèn)為類(lèi)鎖和目標(biāo)鎖是別離針對(duì)靜態(tài)同享變量和非靜態(tài)同享變量的,但事實(shí)上鎖的是要履行的代碼塊,而不是代碼塊即將拜訪的同享變量。

文章標(biāo)簽:

Copyright ? 2016 廣州思洋文化傳播有限公司,保留所有權(quán)利。 粵ICP備09033321號(hào)

與項(xiàng)目經(jīng)理交流
掃描二維碼
與項(xiàng)目經(jīng)理交流
掃描二維碼
與項(xiàng)目經(jīng)理交流
ciya68