Synchronized的作用:

能够保证在同一时刻最多只有一个线程执行该段代码,以达到保证并发安全的效果

Synchronized的两个用法:

1)对象锁

包括方法锁(默认锁对象为this当前实例对象)和同步代码块锁(自己指定锁对 象)

2)类锁:

指Synchronized修饰静态的方法或指定锁为Class对象

 1 public class SynchronizedObjectCodeBlock2 implements Runnable {
2
3 static SynchronizedObjectCodeBlock2 intface = new SynchronizedObjectCodeBlock2();
4 Object lock1 = new Object();
5 Object lock2 = new Object();
6
7 @Override
8 public void run() {
9 synchronized (lock1) {
10 System.out.println("lock1部分。我叫:" + Thread.currentThread().getName());
11 try {
12 Thread.sleep(3000);
13 } catch (InterruptedException e) {
14 e.printStackTrace();
15 }
16 System.out.println(Thread.currentThread().getName() + "lock1部分运行结束!");
17 }
18
19 synchronized (lock2) {
20 System.out.println("lock2部分。我叫:" + Thread.currentThread().getName());
21 try {
22 Thread.sleep(3000);
23 } catch (InterruptedException e) {
24 e.printStackTrace();
25 }
26 System.out.println(Thread.currentThread().getName() + "lock2部分运行结束!");
27 }
28 }
29
30 public static void main(String[] args) {
31 Thread t1 = new Thread(intface);
32 Thread t2 = new Thread(intface);
33 t1.start();
34 t2.start();
35 while (t1.isAlive() || t2.isAlive()) {
36
37 }
38 System.out.println("finshed");
39 }
40 }

同步代码块锁

运行结果:

 1 public class SynchronizedObjectMethod3 implements Runnable {
2
3 static SynchronizedObjectMethod3 intface = new SynchronizedObjectMethod3();
4
5 @Override
6 public void run() {
7 method();
8 }
9
10 public static void main(String[] args) {
11 Thread t1 = new Thread(intface);
12 Thread t2 = new Thread(intface);
13 t1.start();
14 t2.start();
15 while (t1.isAlive() || t2.isAlive()) {
16
17 }
18 System.out.println("finshed");
19 }
20
21 public synchronized void method() {
22 System.out.println("我是对象锁的方法修饰符形式。我叫:"+ Thread.currentThread().getName());
23 try {
24 Thread.sleep(3000);
25 } catch (InterruptedException e) {
26 e.printStackTrace();
27 }
28 System.out.println(Thread.currentThread().getName()+"运行结束");
29 }
30 }

方法锁

运行结果:

 1 public class SynchronizedClassStatic4 implements Runnable {
2
3 static SynchronizedClassStatic4 intface1 = new SynchronizedClassStatic4();
4 static SynchronizedClassStatic4 intface2 = new SynchronizedClassStatic4();
5
6 @Override
7 public void run() {
8 method();
9 }
10
11 public static synchronized void method(){
12 System.out.println("我是类锁的第一种形式:static形式。我叫:"+ Thread.currentThread().getName());
13 try {
14 Thread.sleep(3000);
15 } catch (InterruptedException e) {
16 e.printStackTrace();
17 }
18 System.out.println(Thread.currentThread().getName()+"运行结束");
19 }
20
21 public static void main(String[] args) {
22 Thread t1 = new Thread(intface1);
23 Thread t2 = new Thread(intface2);
24 t1.start();
25 t2.start();
26 while (t1.isAlive() || t2.isAlive()) {
27
28 }
29 System.out.println("finshed");
30 }
31 }

类锁的第一种形式:static形式

运行结果:

 1 public class SynchronizedClassClass5 implements Runnable {
2
3 static SynchronizedClassClass5 intface1 = new SynchronizedClassClass5();
4 static SynchronizedClassClass5 intface2 = new SynchronizedClassClass5();
5
6 @Override
7 public void run() {
8 method();
9 }
10
11 public void method(){
12 synchronized (SynchronizedClassClass5.class){
13 System.out.println("我是类锁的第2种形式:synchronized (*.class)形式。我叫:"+ Thread.currentThread().getName());
14 try {
15 Thread.sleep(3000);
16 } catch (InterruptedException e) {
17 e.printStackTrace();
18 }
19 System.out.println(Thread.currentThread().getName()+"运行结束");
20 }
21 }
22
23 public static void main(String[] args) {
24 Thread t1 = new Thread(intface1);
25 Thread t2 = new Thread(intface2);
26 t1.start();
27 t2.start();
28 while (t1.isAlive() || t2.isAlive()) {
29
30 }
31 System.out.println("finshed");
32 }
33 }

类锁的第2种形式:synchronized (*.class)形式

运行结果:

多线程Synchronized的两种锁的更多相关文章

  1. WPF多线程UI更新——两种方法

    WPF多线程UI更新——两种方法 前言 在WPF中,在使用多线程在后台进行计算限制的异步操作的时候,如果在后台线程中对UI进行了修改,则会出现一个错误:(调用线程无法访问此对象,因为另一个线程拥有该对 ...

  2. 多线程通信的两种方式? (可重入锁ReentrantLock和Object)

    (一)Java中线程协作的最常见的两种方式: (1)利用Object的wait().notify()和notifyAll()方法及synchronized (2)使用Condition.Reentra ...

  3. JAVA多线程实现的两种方式

    java多线程实现方式主要有两种:继承Thread类.实现Runnable接口 1.继承Thread类实现多线程 继承Thread类的方法尽管被我列为一种多线程实现方式,但Thread本质上也是实现了 ...

  4. JavaSE——多线程实现的两种方式

    Thread类: 创建新执行线程有两种方法. 一种方法是将类声明为 Thread 的子类.该子类应重写 Thread 类的 run 方法.接下来可以分配并启动该子类的实例.例如,计算大于某一规定值的质 ...

  5. Java中的ReentrantLock和synchronized两种锁机制的对比

    原文:http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html 多线程和并发性并不是什么新内容,但是 Java 语言设计中的创新之 ...

  6. Java-将多线程停止的两种方法

    线程如何停止呢 stop方法过时了,看起描述发现,有其他解决方案. 线程结束:就是让线程任务代码执行完,run方法结束. run方法怎么结束呢? run方法中通常都定义循环,只要控制住循环就哦了. / ...

  7. SAP Fiori里两种锁机制(lock)的实现

    方法1: ETAG机制 SAP CRM Fiori采用了这种机制. 看一个具体的例子来理解.假设我用用户名Jerry选中了这个ID为3456的Opportunity,点击Edit按钮之后: 会触发一个 ...

  8. day36 joinablequeue、多线程理论、多线程的两种使用方式、守护线程、互斥锁、死锁、递归锁、信号量

    1.joinablequeue队列 joinablequeue与queue一样,也是一种队列,其继承自queue,也有queue中的put 与get 方法,但是在joinablequeue中有自己的 ...

  9. 【Java多线程】两种基本实现框架

    Java多线程学习1——两种基本实现框架 一.前言 当一个Java程序启动的时候,一个线程就立刻启动,改程序通常也被我们称作程序的主线程.其他所有的子线程都是由主线程产生的.主线程是程序开始就执行的, ...

随机推荐

  1. etcd学习(3)-grpc使用etcd做服务发现

    grpc通过etcd实现服务发现 前言 服务注册 服务发现 负载均衡 集中式LB(Proxy Model) 进程内LB(Balancing-aware Client) 独立 LB 进程(Externa ...

  2. 【Azure 应用服务】App Service服务无法启动,打开Kudu站点,App Service Editor 页面均抛出:The service is unavailable

    问题描述 App Service 服务URL无法访问,进入门户中的Advanced Tools(Kudu).App Service Editor (Preview)等页面无法打开, 打开就出现 The ...

  3. Guava - 字符串处理

    Joiner 连接 比如,有这样一个集合[1,2,3,4,5,7,null],想把这个集合转换成以#分割的字符串,并过滤掉集合中的空元素 List<Integer> eleList = A ...

  4. 【Uva1025 A Spy in the Metro】动态规划

    题目描述 某城市地铁是线性的,有n(2≤n≤50)个车站,从左到右编号1~n.有M1辆列车从第1站开始往右开,还有M2辆列车从第n站开始往左开.列车在相邻站台间所需的运行时间是固定的,因为所有列车的运 ...

  5. 【洛谷P1816 忠诚】线段树

    题目描述 老管家是一个聪明能干的人.他为财主工作了整整10年,财主为了让自已账目更加清楚.要求管家每天记k次账,由于管家聪明能干,因而管家总是让财主十分满意.但是由于一些人的挑拨,财主还是对管家产生了 ...

  6. <textarea></textarea>标签的placeholder属性不生效问题

    <textarea></textarea>标签的placeholder属性不生效问题   1.在用到<textarea></textarea>标签时,设 ...

  7. 桌面小部件AppWidgetProvider简单分析

    1.一般桌面小部件涉及到的类 AppWidgetProvider :BroadcastRecevier子类,用于接收更新,删除通知 AppWidgetProvderInfo:AppWidget相关信息 ...

  8. IPSec组播概要

    IPSec作为主流IP安全协议之一,在单播环境下,特别是在VPN场景中应用广泛.但是在组播环境貌似看到的不多,通过RFC4301了解到IPSec首先是支持组播的,即通过手动配置的方式可以实现组播包加密 ...

  9. Java流程控制05——循环结构

    循环结构 while 循环  while(布尔表达式){   //循环语句 } 只要布尔表达式为true,循环就会一直执行下去. 我们为你大多数情况是会让循环停止下来的,我们需要让一个表达式时效的方式 ...

  10. 说实话,Android开发月薪3W,谁不酸呢?

    近期有个网友在某匿名区晒字节跳动Offfer,毕业一年月薪3W,引发众多读者羡慕,纷纷留言酸了.酸了.但进大厂的要求还是蛮高的,需要在技术实力上有一定的积累,今天给大家分享一份高质量笔记, 助力大家技 ...