synchronized:内部锁

起源: 并行程序开发涉及多线程、多任务间的协作和数据共享

一)、内部锁:synchronized

1).定义在方法上

public synchronized void method()

当method方法被调用时,调用线程必须获得当前对象的锁。

锁对象:当前对象。

2).同步代码块

synchronized(Object obj){ }

锁对象:自定义一个共同使用的锁对象。

好处:

1.同步块可以更为精确的控制同步代码范围

2.小的代码块非常有利于锁的快进快出,假设同步块前后代码段较为耗时,而它

​ 们又无需进行同步操作,那么,将这些代码纳入整个同步代码块就会增加锁的等

​ 待时间。

3).静态方法的同步

public synchronized static method()

锁对象:Class对象

4).使用wait()、notify()来创建一个阻塞队列

构建:

方法一:当队列有数据时,取出第一个元素,没有数据时,线程进入等待状态,线

​ 程被阻塞。

方法二:将一个对象添加进入队列,并通知等待的方法。

使用wait()、notify()实现了多线程之间的协作以及数据的共享。

模拟队列:

/**
* 使用synchronize和wait(), notify()实现一个阻塞队列
* 实现:
* 获取队列中的元素: 使用pop操作队列,当队列中有元素,则取出第一个元素,若队列为空,线程进入等待状态
* 使用put()方法添加元素,并唤醒等待的线程
*/
public class BlockQueue {
List list = new ArrayList<>();
public synchronized Object pop() throws InterruptedException {
//当涉及条件判断时,wait方法要在一个循环中使用,并指出跳出循环的条件
//原因:若使用if语句,线程被唤醒,直接执行接下的业务逻辑,不再进行list.size() == 0的判断,若之前队列的
//元素被消费,此时又再次唤醒该线程,队列中无数据,执行业务逻辑出错。
//将wait()放入while中,唤醒线程后会再次进行条件判断,条件满足则执行业务逻辑。
if(list.size() == 0) {
this.wait();
}
if(list.size() > 0){
System.out.println("取值");
return list.remove(0);
}else{
return null;
}
} public synchronized void put(Object obj){
list.add(obj);
this.notify();
}
}

测试:

public class ThreadPoolTest {
public static void main(String[] args) {
BlockQueue queue = new BlockQueue();
//两个线程,一个线程获取队列的数据,如果队列有数据则获取数据,如果没有则等待
/**
* 使用线程池来创建线程对象
*/
ExecutorService executor = Executors.newFixedThreadPool(10);
//线程一,取数据
executor.execute(new Runnable(){
@Override
public void run(){
while(true) {
//获取队列的数据
try {
queue.pop();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
});
executor.execute(new PopThread(queue));
//线程二,放数据
executor.execute( new Runnable(){
@Override
public void run(){
while(true) {
String a = "1";
queue.put(a);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
});
} }

synchronized:内部锁的更多相关文章

  1. 悲观的并发策略——Synchronized互斥锁

    volatile既然不足以保证数据同步,那么就必须要引入锁来确保.互斥锁是最常见的同步手段,在并发过程中,当多条线程对同一个共享数据竞争时,它保证共享数据同一时刻只能被一条线程使用,其他线程只有等到锁 ...

  2. [多线程] 线程中的synchronized关键字锁

    为什么要用锁? 在多线程中,难免会出现在多个线程中对同一个对象的实例变量或者全局静态变量进行并发访问的情况,如果不做正确的同步处理,那么产生的后果就是"脏读",也就是取到的数据其实 ...

  3. Java内部锁的可重用性(Reentrancy)

    Java提供了强制原子性的内部锁机制:synchronized块.但是内部锁是可重入的,当线程试图获得它自己占有的锁时,请求会成功. 简单的说,就是在一个synchronized方法内部调用本类的其他 ...

  4. 内部锁之一:锁介绍(偏向锁 & 轻量级锁 & 重量级锁 & 各自优缺点及场景)

    一.内部锁介绍 上篇文章<Synchronized之二:synchronized的实现原理>中向大家介绍了Synchronized原理及优化锁.现在我们应该知道,Synchronized是 ...

  5. synchronized到底锁住的是谁?

    本文代码仓库:https://github.com/yu-linfeng/BlogRepositories/tree/master/repositories/sync 先来一道校招级并发编程笔试题 题 ...

  6. 由Java 15废弃偏向锁,谈谈Java Synchronized 的锁机制

    Java 15 废弃偏向锁 JDK 15已经在2020年9月15日发布,详情见 JDK 15 官方计划.其中有一项更新是废弃偏向锁,官方的详细说明在:JEP 374: Disable and Depr ...

  7. synchronized类锁,对象锁,方法锁

    synchronized从语法的维度一共有3个用法: 静态方法加上关键字 实例方法(也就是普通方法)加上关键字 方法中使用同步代码块 前两种方式最为偷懒,第三种方式比前两种性能要好. synchron ...

  8. Java多线程之synchronized线程锁

    package org.study2.javabase.ThreadsDemo.sync; /** * @Auther:GongXingRui * @Date:2018/9/18 * @Descrip ...

  9. synchronized、锁、多线程同步的原理是咋样

    先综述个结论: 一般说的synchronized用来做多线程同步功能,其实synchronized只是提供多线程互斥,而对象的wait()和notify()方法才提供线程的同步功能. 一般说synch ...

随机推荐

  1. 18.Tomcat基本应用

    1.JVM基本介绍 JAVA编译型 ---> 编译 C 编译型---> linux --->编译一次 windows --->编译一次 macos ubuntu 跨平台 移值型 ...

  2. 关于MySQL的经典例题50道 答案参考

    答案不全面,欢迎交流沟通 -- 1.查询"01"课程比"02"课程成绩高的学生的信息及课程分数select * from  sc s INNER JOIN sc ...

  3. 在Mac平台用Sublime编辑器使用Git并连接github

    近期闲来无事,学习一下Git版本控制的东西,首先是要在我的pc上学会如何向git上提交我的代码,记录一下过程以及遇到的问题. 一.Mac下Sublime Text 3整合Git 来源于一个技术教程:h ...

  4. Redis(十五)Redis 的一些常用技术(Spring 环境下)

    一.Redis 事务与锁机制 1.Redis的基础事务 在Redis中开启事务的命令是 multi 命令, 而执行事务的命令是 exec 命令.multi 到 exec 命令之间的 Redis 命令将 ...

  5. 小程序多端差异调研报告(微信,支付宝,头条,QQ)

    已经使用uni-app开发并发布了一个跨端小程序啦,嘻嘻嘻!

  6. SpirngCloud之Ribbon负载均衡(二)

    一 概念 Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端 负载均衡的工具. 简单的说,Ribbon是Netflix发布的开源项目,主要功能是提供客户端的软件负 ...

  7. List<model>需要根据特定字段求差集的实现

    list对象不能直接使用Except等封装好的函数,因为内存地址不一样(还有一些数虽然主数据一致但是update/create信息也不一致,对,我碰到的需求就是这么难受 TOT) 这时候我们的需求很多 ...

  8. [apue] 如何处理 tcp 紧急数据(OOB)?

    在上大学的时候,我们可能就听说了OOB(Out Of Band 带外数据,又称紧急数据)这个概念. 当时老师给的解释就是在当前处理的数据流之外的数据,用于紧急的情况.然后就没有然后了…… 毕业这么多年 ...

  9. 转:redis-cli 命令总结

    redis-cli常用命令,原文地址:https://maoxian.de/2015/08/1342.html Redis提供了丰富的命令(command)对数据库和各种数据类型进行操作,这些comm ...

  10. Linux下基本操作

    强行转Linux,开始以为会很不适应,其实还好,换汤不换药 本文只讲基本操作,足够让你愉快的打代码,想飞上天的自行百度,或找其他大神(友链) Update 6/20:由于写得太烂被学长爆踩了一顿 直接 ...