package com.thread;public class ThreadTest4 {
public static void main(String[] args) {
Runnable ru = new HelloThread1();
Thread t1 = new Thread(ru);
Thread t2 = new Thread(ru);
t1.start();
t2.start();

}

}
class HelloThread1 implements Runnable
{
     int i;
@Override
public void run() {
int i = 0;
while(true)
{
System.out.println("number :"+this.i++);
try {
Thread.sleep((long)(Math.random()*1000));
} catch (InterruptedException e) {
e.printStackTrace();
}
if(this.i == 50)
break;

}
System.out.println("我来测试!!!");

}
}
输出结果number :0
number :1
number :2
number :3
number :4
number :5
number :6
number :7
number :8
number :9
number :10
number :11
number :12
number :13
number :14
number :15
number :16
number :17
number :18
number :19
number :20
number :21
number :22
number :23
number :24
number :25
number :26
number :27
number :28
number :29
number :30
number :31
number :32
number :33
number :34
number :35
number :36
number :37
number :38
number :39
number :40
number :41
number :42
number :43
number :44
number :45
number :46
number :47
number :48
number :49
我来测试!!!
我来测试!!!
线程t1 和 线程t2 同时对 i 进程操作,肯定有某一个线程让i = 50 run方法终止,但是另外一个线程在执行循环,i的值变为51 ,不是死循环码,求解??求解释?????

解决方案 »

  1.   

    这样是不对的,出现的情况会有:
    1、t1, t2两个线程都退出;
    2、t1, t2两个线程都一直运行下去;
    3、t1线程退出, t2线程一直运行下去;
    4、t1线程一直运行下去, t2线程退出;如:当i=49时,若t1在执行完this.i++后,就被阻塞; t2同样被阻塞,
    或 在if(this.i == 50)前,同样发生上述情况,
    那么就是情况2了;(其它情况自己体会了)不要认为一定要sleep线程才会被阻塞。
      

  2.   

    之所以我们测试没有出现死循环,我认为其原因是:楼主的程序不易出现此种情况。(理论上有,但实际测试时几乎不出现。)。
    假设t1在i=49时线程,执行了  System.out.println("number :"+this.i++); 语句,那么执行完后,i为50了。假设t1继续执行,会检测到i==50,使t1结束。  关键是此时t2线程会从什么地方执行呢? 我测试是在休眠状态,它一结束休眠,会检测到i==50,线程结束。什么情况容易出现楼主希望的结果呢?
    1 在 System.out.println("number :"+this.i++);之前加条语句。
    2 减少休眠时间。第一条,我反复进行了测试,发现如果不加条语句,都不会出现死循环,(就是线程被别的线程抢占时,都在
    System.out.println("number :"+this.i++);之后。一旦获得运行机会,没有机会执行这条语句)。