/**
时间:2015年3月12日18:13:29
测试同步Syncronized
文件路径:D:\java\thread\TestSynchronized.java
在使用关键字前和使用关键字后的运行结果的对比中,我们明显可以看出,第二次运行的结果才真正是人的意图。
这是因为线程可以看成是轻量级的进程,同一类线程共享代码和数据空间。在本程序中,
t1和t2共享同一个数据num。程序是这样执行的,首先创建两个不同的执行路径,也就是线程。t1, t2
然后启动这两个线程。调用这两个线程的线程体,run(),run方法同时调用的是成员变量timer的add方法
t1进入add方法,先把静态变量num自加,使得num变成1,执行try块,休眠了100毫秒。
而就在此刻,t2线程也进入了add方法,再一次把num自加。num变成了2,t2休眠了100毫秒。
t1苏醒.
这个解释有点牵强。………………
*/
public class TestSynchronizd implements Runnable{
Timer timer = new Timer();
public static void main(String[] args) {
TestSynchronizd test = new TestSynchronizd();
Thread t1 = new Thread(test);
Thread t2 = new Thread(test);
t1.setName("t1");
t2.setName("t2");
t1.start();
t2.start();
}
public void run() {
System.out.println(Thread.currentThread().getName() + "运行了!");
timer.add(Thread.currentThread().getName());
}
}
时间:2015年3月12日18:13:29
测试同步Syncronized
文件路径:D:\java\thread\TestSynchronized.java
在使用关键字前和使用关键字后的运行结果的对比中,我们明显可以看出,第二次运行的结果才真正是人的意图。
这是因为线程可以看成是轻量级的进程,同一类线程共享代码和数据空间。在本程序中,
t1和t2共享同一个数据num。程序是这样执行的,首先创建两个不同的执行路径,也就是线程。t1, t2
然后启动这两个线程。调用这两个线程的线程体,run(),run方法同时调用的是成员变量timer的add方法
t1进入add方法,先把静态变量num自加,使得num变成1,执行try块,休眠了100毫秒。
而就在此刻,t2线程也进入了add方法,再一次把num自加。num变成了2,t2休眠了100毫秒。
t1苏醒.
这个解释有点牵强。………………
*/
public class TestSynchronizd implements Runnable{
Timer timer = new Timer();
public static void main(String[] args) {
TestSynchronizd test = new TestSynchronizd();
Thread t1 = new Thread(test);
Thread t2 = new Thread(test);
t1.setName("t1");
t2.setName("t2");
t1.start();
t2.start();
}
public void run() {
System.out.println(Thread.currentThread().getName() + "运行了!");
timer.add(Thread.currentThread().getName());
}
}
class Timer {
public static int num = 0;
boolean flag = true;
public synchronized void add(String name) {
num ++;
try {
Thread.sleep(300);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(name+", 你是第"+num+"个使用timer的线程");
}
}
/*
==================================
D:\java\thread>javac TestSyncronize.java
public static int num = 0;
boolean flag = true;
public synchronized void add(String name) {
num ++;
try {
Thread.sleep(300);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(name+", 你是第"+num+"个使用timer的线程");
}
}
/*
==================================
D:\java\thread>javac TestSyncronize.java
D:\java\thread>java TestSyncronize
t1, 你是第2个使用timer的线程
t2, 你是第2个使用timer的线程
t1, 你是第2个使用timer的线程
t2, 你是第2个使用timer的线程
加入synchronized关键字以后
D:\java\thread>javac TestSynchronized.java
D:\java\thread>javac TestSynchronized.java
D:\java\thread>java TestSynchronized
t1, 你是第1个使用timer的线程
t2, 你是第2个使用timer的线程
t1, 你是第1个使用timer的线程
t2, 你是第2个使用timer的线程
t1运行了!
t2运行了!
t1, 你是第2个使用timer的线程
t2, 你是第2个使用timer的线程
t2运行了!
t1, 你是第2个使用timer的线程
t2, 你是第2个使用timer的线程
==================================
*/
*/