java线程之同步synchronized

来源:互联网 发布:sql参数错误 编辑:程序博客网 时间:2024/04/27 22:57

/**
 时间: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

D:\java\thread>java TestSyncronize
t1, 你是第2个使用timer的线程
t2, 你是第2个使用timer的线程

加入synchronized关键字以后
D:\java\thread>javac TestSynchronized.java

D:\java\thread>java TestSynchronized
t1, 你是第1个使用timer的线程
t2, 你是第2个使用timer的线程

t1运行了!
t2运行了!
t1, 你是第2个使用timer的线程
t2, 你是第2个使用timer的线程



==================================
*/
0 0
原创粉丝点击