[問題] 用thread印出log不如預期...

作者: Dong0129 (阿東跟上面講的情況一樣b)   2020-05-11 09:55:52
各位版友好,我寫了一個簡單的程式,利用2個分別印出5行log,
結果發現thread印出的log不如預期...請問是我寫錯了嗎?
Runnable runnable=new Runnable(
{
@Override
public void run(){
for(j=0;j<5;j++)
Log.i(tag,Thread.currentThread.getName());


for(i=0;i<2;i++)
{
Thread thread=new Thread(runnable);
thread.setName(根據i值設定名稱);
try{
thread.start();
thread.join();
}catch(InterruptedException e){}
結果一個thread只印出兩次名字,請問我有寫錯嗎?
作者: LZN (秋)   2020-05-11 11:42:00
有完整code嗎? 我試起來兩個thread各印5次沒錯啊
作者: ssccg (23)   2020-05-11 14:36:00
你這程式根本不能跑,我改到能跑之後一個thread印5次沒問題
作者: dpes10087 (悠哉度日)   2020-05-12 10:51:00
沒寫錯,你直接在getName()後加上+j就會正常印出。你不能顯示的主因是因為logcat的chatty機制,會把重複的中間內容改以chatty : 'identical X lines'顯示。

Links booklink

Contact Us: admin [ a t ] ucptt.com