java线程之同步synchronized


/**
 时间: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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值