你的答案有兩個問題:1,obj不是static,就是說每個線程都有自己的obj,synchronize鎖的是自己線程的obj,不能起到阻塞其它線程的作用。運(yùn)行的話會看到有的票被出售多次。
創(chuàng)新互聯(lián)建站服務(wù)項(xiàng)目包括冷水灘網(wǎng)站建設(shè)、冷水灘網(wǎng)站制作、冷水灘網(wǎng)頁制作以及冷水灘網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,冷水灘網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到冷水灘省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
但是要注意,s的定義一定要在run方法之外,不然還會出現(xiàn)負(fù)數(shù)。因?yàn)槟銌恿?個線程,每個線程都調(diào)用了run方法,在每個線程就會在run方法里邊產(chǎn)生自己的s對象,一共會產(chǎn)生3個,達(dá)不到同步的目的。
0; i 10; i++) { new Thread(new Save()).start();} } } 線程同步安全模式,當(dāng)然不是你要求的這個順序方式..因?yàn)槭燮睍r,無法保證售票與存票是同步的。我這個寫的只是一個簡單模式。
三個線程共享count, 但count++不是原子操作,包括count與比較sum時候 也是, 會導(dǎo)致出現(xiàn)多線程問題。
你的答案有兩個問題:1,obj不是static,就是說每個線程都有自己的obj,synchronize鎖的是自己線程的obj,不能起到阻塞其它線程的作用。運(yùn)行的話會看到有的票被出售多次。
讓每個線程只能買一張,買了就解鎖,然后回到線程池里面等下一次搶到機(jī)會。
1、為了回答這個問題,我們可以通過編寫一段代碼來進(jìn)行分析。我們用代碼來模擬鐵路售票系統(tǒng),實(shí)現(xiàn)通過四個售票點(diǎn)發(fā)售某日某次列車的100張車票,一個售票點(diǎn)用一個線程表示。
2、這個不難,我正好有個類似的模板,稍微修改下文字,調(diào)整下就可以用了。
3、Java中,能通過兩種方法使用線程。一是繼承Thread類,二是實(shí)現(xiàn)Runnable接口。具體怎么使用,請參考相應(yīng)的資料。該文檔主要介紹的是多線程的同步問題。 我們能夠創(chuàng)建許許多多的線程,來處理許許多多的事情。
4、多實(shí)例每個實(shí)例都可以有自己獨(dú)立的已售出票區(qū)間,這樣才能最充分的利用火車的運(yùn)力??推毕到y(tǒng)本身就比較復(fù)雜,也不會把所有的票都集中在一個服務(wù)器里。應(yīng)該有很多服務(wù)器分別處理不同的票。