舉的例子不合適,容易誤導別人!繼承thread的子類中定義了票數(shù)變量,每new一下啟動新線程,都會有5張票,把票數(shù)變量定義成全局變量試試
2016-03-13
已采納回答 / 鴻澤
可能是因為并非窗口1首先獲得CPU時間片,而是其他線程。首先是窗口2 ,執(zhí)行到count--之后,sysout時就被阻塞了。注意此時count=4。然后是窗口1 ,執(zhí)行了整個run方法 ,此時count=3。然后是窗口3 ,執(zhí)行了整個run方法 ,此時count=2。此時窗口2恢復,繼count--之后執(zhí)行,輸出count=3。然后是窗口3 ,執(zhí)行了整個run方法 ,此時count=0。當然這種并不一定是這樣,因為現(xiàn)在的多核CPU線程是可以同時執(zhí)行的。
2016-03-12
class MyThread implements Runnable{
Lock lock = new ReentrantLock();
private int number=5;
@Override
public void run() {
lock.lock();
try{
while(number >0){
number--;
System.out.println(Thread.currentThread().getName()+"賣一張剩余票數(shù):"+number);
}
}finally{
lock.unlock();
}
}}要加鎖機制
Lock lock = new ReentrantLock();
private int number=5;
@Override
public void run() {
lock.lock();
try{
while(number >0){
number--;
System.out.println(Thread.currentThread().getName()+"賣一張剩余票數(shù):"+number);
}
}finally{
lock.unlock();
}
}}要加鎖機制
2016-02-27
最新回答 / 飄游人
extends Thread的例子沒有問題。想實現(xiàn)的確實是3個窗口總共有5張票,老師故意用extends Thread的例子,就是為了說明這種方式達不到希望的效果(即實際出現(xiàn)的效果是你所說的“每個窗口擁有5張票”)。老師也在PPT中寫明,只有Runnable的方式才適合多個線程處理同一資源的情況。如果硬要用extends Thread來實現(xiàn)效果,確實像你說的可以加static關鍵字,但老師想告訴我們的是,對于這樣的情況,還是用Runnable好。
2016-02-16
thread代碼里主函數(shù)那對象實例化和Runnable代碼里的主函數(shù)對象實例化的代碼都不一樣,前提條件都不一樣,咋比出thread和Runnable的不同啊。
而且我把ticketsRunnable里面的代碼implements Runnable換成extends Thread,執(zhí)行效果一樣啊,那Thread和Runnable還有啥區(qū)別啊。
而且我把ticketsRunnable里面的代碼implements Runnable換成extends Thread,執(zhí)行效果一樣啊,那Thread和Runnable還有啥區(qū)別啊。
2016-01-26
線程一剛執(zhí)行完tick--,還沒有執(zhí)行打印語句,那就算線程還未結(jié)束,別的線程怎么能搶走執(zhí)行權(quán)呢?
2016-01-23