码迷,mamicode.com
首页 > 其他好文 > 详细

同步随笔

时间:2019-04-25 20:12:52      阅读:181      评论:0      收藏:0      [点我收藏+]

标签:img   变化   i++   并发   err   tst   情况   自己   预测   

定义:

技术图片

发现百度中关于同步关键字的定义, 同类中同步方法使用同一个锁. 大部分文章中都是对同步方法, 同步代码块, 同步对象, 同步类的测试, 没有对这种情况的说明, 只要自己测试一下.

使用多线程同时访问两个方法, 操作同一个对象. 通过观察该对象的变化, 测试同类中的同步方法使用是否是同一个锁.



public class SynchronizeDemo01 {

public static void main(String[] args) {
//测试目的: 测试同类中同步方法使用的是否是同一把锁
//测试方法: 使用多线程同时访问两个方法, 操作同一个对象. 通过观察该对象的变化, 测试同类中的同步方法使用是否是同一个锁.
//预测结果: 顺序执行时间会长, 而且 size 有序增长. 同时执行则打印出的 size 跳跃性增长.

Random random = new Random(2);
List<String> list = new ArrayList<>();

Runnable runnable = () -> {
if (1 == random.nextInt() % 2) {
test01(list);
} else {
test02(list);
}
};

for (int i = 0; i < 100; i++) {
new Thread(runnable).start();
}

}

private static synchronized void test01(List<String> list01) {
try {
//睡眠一段时间 如果不需要抢锁, 直接并发执行, 将同时执行 add.
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}

list01.add("0");
System.out.println("test01: " + list01.size());
}

private static synchronized void test02(List<String> list01) {
try {
//睡眠一段时间 如果不需要抢锁, 直接并发执行, 将同时执行 add.
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
list01.add("0");
System.out.println("test02: " + list01.size());
}


}

  执行结果:  最后从1到100完全顺序打印, 说明同类中的同步方法使用的是同一个锁.

  技术图片

 

同步随笔

标签:img   变化   i++   并发   err   tst   情况   自己   预测   

原文地址:https://www.cnblogs.com/fuershi/p/10770594.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!