1.synchronized的几种用法 synchronized关键字最主要有以下5种应用方式,下面分别介绍。 1. 修饰对象普通方法,作用于当前对象,进入同步方法前要获得当前对象的锁 2. 修饰对象静态方法,作用于当前类对象加锁,进入同步该方法前要获得当前类对象的锁 3. 修饰代码块,指定加锁对象,对给定对象加锁,进入同步代码库前要获得指定对象的锁。 4. 修饰 this,指定当前对象,对给当前对象加锁,进入同步代码前要获得当前对象的锁(该方式和方式1作用相同)。 5. 修饰 xxx.class,(该方式和方式2作用相同)。
2.锁竞争说明 同时调用两个都加有synchronized的方法时存在锁竞争关系(同时调用时会一个先输出,另一个晚两秒输出)以下代码同时调用会产生竞争关系(this的作用相同)
public synchronized void getSex() throws InterruptedException { Thread.sleep(2000); System.out.println("getSex synchronized : " + System.currentTimeMillis()); } public synchronized void getHeight() throws InterruptedException { Thread.sleep(2000); System.out.println("getHeight synchronized : " + System.currentTimeMillis()); } public void getWeight() throws InterruptedException { synchronized (this){ Thread.sleep(2000); System.out.println("getWeight synchronized : " + System.currentTimeMillis()); } }
- 同时调用两个都加有synchronized的静态(static)方法时存在锁竞争关系(同时调用时会一个先输出,另一个晚两秒输出)
-
public static synchronized void getName() throws InterruptedException { Thread.sleep(2000); System.out.println("getName static synchronized : " + System.currentTimeMillis()); } public static synchronized void getAge() throws InterruptedException { Thread.sleep(2000); System.out.println("getAge static synchronized : " + System.currentTimeMillis()); }
- 同时调用锁代码块的要看锁的目标是不是同一个,如果是同一个时就存在锁竞争关系,如果不是则没有关系 当传入的参数一样则有竞争关系
- 这里要注意点的就是 当传入的是getWX(“55”)和getQQ(“55”),getWX(new String(“55”))和getQQ(new String(“55”))这两中的结果是不同的 注意前面的存在竞争关系,后面不存在,因为new 是从新创建了对象,内存地址不是同一个
-
public void getQQ(String qq) throws InterruptedException { synchronized (qq){ Thread.sleep(2000); System.out.println("getQQ QQ synchronized : " + System.currentTimeMillis()); } } public void getWX(String wx) throws InterruptedException { synchronized (wx){ Thread.sleep(2000); System.out.println("getWX WX synchronized : " + System.currentTimeMillis()); } }
- 同时一个synchronized的静态(static)方法和一个普通synchronized方法时 和一个synchronized代码块时(代码块不是 this和xxx.class),不存在竞争关系
- 这里要注意点的就是 synchronized代码块必须不是this和xxx.class,要不然会有竞争关系 因为this和synchronized普通方法效果相同,xxx.class与synchronized静态方法效果相同
-
public synchronized void getSex() throws InterruptedException { Thread.sleep(2000); System.out.println("getSex synchronized : " + System.currentTimeMillis()); } public static synchronized void getAge() throws InterruptedException { Thread.sleep(2000); System.out.println("getAge static synchronized : " + System.currentTimeMillis()); } public void getWX(String wx) throws InterruptedException { synchronized (wx){ Thread.sleep(2000); System.out.println("getWX WX synchronized : " + System.currentTimeMillis()); } }
以下是全部代码 -
/** * 文件介绍 * * @author YangLD * @date 2018/8/3 21:17 */ public class RunMain { static{ System.out.println("static"); } public static void main(String[] args) throws IllegalAccessException, InstantiationException { RunMain runMain = RunMain.class.newInstance(); System.out.println(System.currentTimeMillis()); CyclicBarrier cyclicBarrier = new CyclicBarrier(9); ThreadUtil.execute(new Runnable() { @Override public void run() { try { cyclicBarrier.await(); RunMain.getName(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } }); ThreadUtil.execute(new Runnable() { @Override public void run() { try { cyclicBarrier.await(); RunMain.getAge(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } }); ThreadUtil.execute(new Runnable() { @Override public void run() { try { cyclicBarrier.await(); runMain.getEmail(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } }); ThreadUtil.execute(new Runnable() { @Override public void run() { try { cyclicBarrier.await(); runMain.getSex(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } }); ThreadUtil.execute(new Runnable() { @Override public void run() { try { cyclicBarrier.await(); runMain.getHeight(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } }); ThreadUtil.execute(new Runnable() { @Override public void run() { try { cyclicBarrier.await(); runMain.getWeight(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } }); ThreadUtil.execute(new Runnable() { @Override public void run() { try { cyclicBarrier.await(); runMain.getQQ("qq"); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } }); ThreadUtil.execute(new Runnable() { @Override public void run() { try { cyclicBarrier.await(); runMain.getWX("qq"); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } }); ThreadUtil.execute(new Runnable() { @Override public void run() { try { cyclicBarrier.await(); runMain.getAli(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } }); } public static synchronized void getName() throws InterruptedException { Thread.sleep(2000); System.out.println("getName static synchronized : " + System.currentTimeMillis()); } public static synchronized void getAge() throws InterruptedException { Thread.sleep(2000); System.out.println("getAge static synchronized : " + System.currentTimeMillis()); } public synchronized void getSex() throws InterruptedException { Thread.sleep(2000); System.out.println("getSex synchronized : " + System.currentTimeMillis()); } public synchronized void getHeight() throws InterruptedException { Thread.sleep(2000); System.out.println("getHeight synchronized : " + System.currentTimeMillis()); } public void getEmail() throws InterruptedException { Thread.sleep(2000); System.out.println("getEmail : " + System.currentTimeMillis()); } public void getWeight() throws InterruptedException { synchronized (this){ Thread.sleep(2000); System.out.println("getWeight synchronized : " + System.currentTimeMillis()); } } public void getQQ(String qq) throws InterruptedException { synchronized (qq){ Thread.sleep(2000); System.out.println("getQQ QQ synchronized : " + System.currentTimeMillis()); } } public void getWX(String wx) throws InterruptedException { synchronized (wx){ Thread.sleep(2000); System.out.println("getWX WX synchronized : " + System.currentTimeMillis()); } } public void getAli() throws InterruptedException { synchronized (RunMain.class){ Thread.sleep(2000); System.out.println("getAli synchronized : " + System.currentTimeMillis()); } } }
1)CountDownLatch和CyclicBarrier都能够实现线程之间的等待,只不过它们侧重点不同:CountDownLatch一般用于某个线程A等待若干个其他线程执行完任务之后,它才执行;
而CyclicBarrier一般用于一组线程互相等待至某个状态,然后这一组线程再同时执行;
另外,CountDownLatch是不能够重用的,而CyclicBarrier是可以重用的。
2)Semaphore其实和锁有点类似,它一般用于控制对某组资源的访问权限。
相关推荐
java中synchronized用法
java里面synchronized用法
java多线程编程核心技术synchronized实例大全,同步方法,同步语句块,类锁,对象锁全都用代码来展现出来
java同步synchronized关键字用法示例
synchronized关键字在java中的重要性 以及常用的方法 还有它的详解
本文实例讲述了PHP pthreads v3下同步处理synchronized用法。分享给大家供大家参考,具体如下: 之所以会用到同步,是因为如果多个线程中对同一个资源进行操作时,会发生混乱。 比如2个线程对变量进行加1操作,第1个...
本篇文章主要介绍了java synchronized用法详解,synchronized是Java中的关键字,是一种同步锁。有兴趣的同学可以了解一下。
Synchronized关键字的用法
下面小编就为大家带来一篇解决Maven 项目报错 java.httpservlet和synchronized使用方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
主要介绍了java多线程中的volatile和synchronized用法分析,以实例的形式分析了在多线程中volatile和synchronized的用法区别与使用原理,具有一定的参考借鉴价值,需要的朋友可以参考下
Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码。本文给大家介绍java中 synchronized的用法,对本文感兴趣的朋友一起看看吧
java多线程中synchronized关键字的用法 解压密码 www.jiangyea.com
synchronized是很重要的,但是不少人不是很明白synchronized的用法,这里有详细的doc文档给大家参考
NULL 博文链接:https://seandsky-boyy-163-com.iteye.com/blog/1340783
* [synchronized 使用方法](#synchronized-使用方法) * [Synchronized和ReentrantLock的区别](#synchronized和reentrantlock的区别) * [乐观锁](#乐观锁) * [悲观锁](#悲观锁) * [独占锁](#独占锁) * [共享锁]...
synchronized下的方法控制多线程程序中的线程同步非常方便,这里就来看一下Java使用synchronized修饰方法来同步线程的实例演示,需要的朋友可以参考下
主要介绍了Java中syncronized正确使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
该内容是在暮课网学习的课程比较,讲解synchronized的原理和用法,以及常见的面试题。上传网上以供自己以后复习。
synchronized同步锁(悲观锁)2.1 synchronized 作用范围2.2 synchronized 核心组件2.3 synchronized 实现 1. Java锁的种类 1.1 乐观锁 乐观锁是一种乐观思想,即认为读多写少,遇到并发写的可能性低。 每次去拿...