E-COM-NET
首页
在线工具
Layui镜像站
SUI文档
联系我们
推荐频道
Java
PHP
C++
C
C#
Python
Ruby
go语言
Scala
Servlet
Vue
MySQL
NoSQL
Redis
CSS
Oracle
SQL Server
DB2
HBase
Http
HTML5
Spring
Ajax
Jquery
JavaScript
Json
XML
NodeJs
mybatis
Hibernate
算法
设计模式
shell
数据结构
大数据
JS
消息中间件
正则表达式
Tomcat
SQL
Nginx
Shiro
Maven
Linux
Java并发编程学习笔记
java并发
编程 13:JUC之Semaphore、CountdownLatch、 CyclicBarrier
目录Semaphore使用常见应用原理源码流程CountdownLatch使用原理CyclicBarrier使用Semaphore使用Semaphore是一种计数信号量,它用于控制对共享资源的访问。它维护了一个许可计数器,表示可用的许可数量。线程在访问共享资源前必须先获得许可,如果许可数量大于0,则线程可以获得许可并继续执行,同时许可数量减少;如果许可数量为0,则线程必须等待,直到有其他线程释放许
coder Ethan
·
2023-07-27 02:08
java并发编程JUC
java
python
算法
Java并发
学习笔记
最近都在看极客时间的《
Java并发
编程》这一课程,看了好一阵,有些明白,有些混沌。于是想着自己整理一版,根据自己的理解做一点笔记。先罗列了一个笔记大纲,从整体去看,如何去学习。
可乐zzz
·
2023-07-26 18:29
【
Java并发
编程】深入理解并发可见性、有序性、原子性与JMM内存模型
6线程安全要素与JMM内存模型6.1线程安全三要素原子性原子,即一个不可再分割的颗粒;原子性指的是一个操作,要么完全执行成功或完全执行失败;不采取任何的原子性保障措施的自增操作并不是原子性的,比如i++操作;线程上下文切换可能会带来原子性问题,解决方案:Atomic原子类(CAS)、sychronized、Lock;案例分析:publicclassAtomicTest{privatestatici
Firechou
·
2023-07-26 03:38
#
Java基础
java
开发语言
JMM内存模型
可见性
原子性
有序性
java并发
入门
一、进程在多进程设计中各进程之间的数据块是相互独立,彼此通过信号、管道进行通信。而在多线程设计中,各线程不一定独立,同一任务中的各线程共享程序段、数据段等资源。Java通过Package类(Java.lang.package)支持多进程,通过Thread类支持多线程。二、线程多线程既有生产者消费者,哲学家就餐,读写器或者简单的有界缓冲区等应用问题。也有死锁,竞态条件,内存冲突和线程安全等并发问题。
ands999
·
2023-07-26 02:18
2019-12-27-
Java并发
编程:volatile关键字解析
https://www.cnblogs.com/dolphin0520/p/3920373.html
啦啦啦啦啦哈1
·
2023-07-26 01:52
Thread源码剖析
如果没看的同学建议先去阅读一遍哦~在写文章之前通读了一遍《Java核心技术卷一》的并发章节和《
Java并发
编程实战》前面的部分,回顾了一下以前写过的笔记。
Java3y
·
2023-07-25 14:45
【
Java并发
编程】阻塞队列BlockingQueue实战及其原理分析
3阻塞队列3.1概念(1)队列一端插入,另一端删除的线性列表,先进先出(FIFO),插入的一端称为入队(队尾),删除的一端称为出队(队头);队列接口Queue:publicinterfaceQueueextendsCollection{//添加一个元素,添加成功返回true,如果队列满了,就会抛出异常booleanadd(Ee);//添加一个元素,添加成功返回true,如果队列满了,返回false
Firechou
·
2023-07-25 07:36
#
Java基础
java
阻塞队列
BlockingQueue
并发编程
【
Java并发
编程】线程池ThreadPoolExecutor源码分析
1线程池结构及用法线程池用法@Testpublicvoidtest1(){//1-线程池核心线程数,即线程池至少存活的线程数//2-线程池最大线程数,即线程池最大存活的线程数//1000-非核心线程没有可执行的任务时等待时间//TimeUnit.MILLISECONDS-时间单位,此处是毫秒,即1000毫秒=1秒//newLinkedBlockingQueue()-任务队列ExecutorServ
Firechou
·
2023-07-25 07:36
#
Java基础
java
并发编程
线程池
【
Java并发
编程】线程池ForkJoinPool实战及其工作原理分析
5ForkJoinPool5.1概述5.1.1优点充分利用多核CPU性能;5.2归并排序算法对于千万级元素的数组进行排序,可以用高效的归并算法来实现;归并排序的时间复杂度为O(nlogn),空间复杂度为O(n),其中n为数组的长度;5.2.1什么是归并排序归并排序(MergeSort)是一种基于分治思想的排序算法。归并排序的基本思想是将一个大数组分成两个相等大小的子数组,对每个子数组分别进行排序,
Firechou
·
2023-07-25 07:36
#
Java基础
java
排序算法
ForkJoin
并发编程
【
Java并发
编程】线程池ThreadPoolExecutor实战及其原理分析
4Executor线程池4.1概述线程发生异常,会被移除线程池,但是如果是核心线程,会创建一个新核心线程;4.1.1线程池的好处降低资源消耗降低了频繁创建线程和销毁线程开销,线程可重复利用;提高响应速度提高线程可管理性统一对线程分配、调优、监控,线程是系统的稀缺资源;4.1.2线程池的执行流程(1)execute()和submit()的区别publicvoidexecute(Runnablecom
Firechou
·
2023-07-25 07:30
#
Java基础
java
线程池
Executor
并发编程
Java内存模型如何解决并发问题的可见性和有序性
上一篇文章中https://www.jianshu.com/p/a529f47d8103我们提到了java内存模型中的三大特性,以及在并发过程中存在的一些问题,本文主要介绍java内存模型如何解决
java
yfsheng
·
2023-07-25 05:14
Linux 网络
编程学习笔记
——九、I/O 复用
目录I/O复用使得程序能同时监听多个文件描述符,这对提高程序的性能至关重要。通常网络程序在下列情况下需要使用I/O复用技术:客户端程序要同时处理多个socket,比如非阻塞connect技术;客户端程序要同时处理用户输入和网络连接,比如聊天室程序;TCP服务器要同时处理监听socket和连接socket,这是I/O复用使用最多的场合;服务器要同时处理TCP请求和UDP请求,比如回射服务器;服务器要
BeZer0
·
2023-07-25 04:45
计算机网络
网络
linux
学习
Java并发
编程 | 创建线程的几种方式
文章目录一、简介二、使用Thread类创建线程2.1继承Thread类2.1.1创建Thread子类2.1.2重写run方法2.1.3启动线程的方式方式一:创建线程对象后调用start方法方式二:直接使用匿名内部类创建线程对象并调用start方法2.2使用匿名内部类创建线程2.3线程的生命周期和状态转换三、使用Runnable接口创建线程3.1实现Runnable接口3.1.1创建Runnable
夏诗曼CharmaineXia
·
2023-07-24 20:32
JAVA
java
jvm
开发语言
《
Java并发
编程实战》课程学习笔记(十七)
CompletionService:如何批量执行异步任务?当需要批量提交异步任务的时候建议使用CompletionService。CompletionService将线程池Executor和阻塞队列BlockingQueue的功能融合在了一起,能够让批量异步任务的管理更简单。除此之外,CompletionService能够让异步任务的执行结果有序化,先执行完的先进入阻塞队列,利用这个特性可以轻松实
fangzhan666
·
2023-07-24 17:56
Java
基础
java
学习
笔记
探索
Java并发
编程利器:LockSupport,一种高效的线程阻塞与唤醒机制
关于作者:CSDN内容合伙人、技术专家,从零开始做日活千万级APP。专注于分享各领域原创系列文章,擅长java后端、移动开发、人工智能等,希望大家多多支持。目录一、导读二、概览三、用法四、原理五、线程等待和唤醒的方法5.1LockSupport.park()Thread.sleep()和LockSupport.park()的区别5.2Object中的wait()、notify、notifyAllO
Android西红柿
·
2023-07-24 14:39
java学习之路
java
android
面试
线程
并发
【
Java并发
编程】ReentrantLock重入锁解析
概述重入锁ReentrantLock,顾名思义,就是支持重进入的锁,它表示能够支持一个线程对资源的重复加锁。除此之外,该锁还支持获取锁时的公平和非公平选择。Synchronized关键字通过获取自增、释放递减的方式来隐式的支持重入,那么Reentrant是如何支持重入的呢?又是怎么实现公平和非公平选择的呢?接下来我们带着这些问题来看ReentrantLock的源码重进入的实现原理重进入是指任意线程
长大后简单很幸福_f63e
·
2023-07-23 19:54
Java并发
编程艺术(四) Java中的锁
1、Lock接口Lock比synchronized多的特性2、队列同步器同步器是实现锁的关键,在锁的实现中聚合同步器,利用同步器实现锁的语义。同步器是面向锁的实现者,简化了锁的实现方式,屏蔽了同步状态管理、线程的排队、等待与唤醒等底层操作。2.1队列同步器的接口与示例通过getState()setState()compareAndSetState()修改状态。同步器可重写方法同步器模板方法publ
kaiker
·
2023-07-23 18:52
[
Java并发
编程实战] 闭锁 CountDownLatch 实现(含代码)
路漫漫其修远兮,吾将上下而求索。———屈原《离骚》闭锁闭锁(latch)是一种Synchronizer,他可以延迟线程的进度直到线程到达终止状态。一个闭锁工作起来就像一道大门:直到闭锁达到终点状态之前,门一直是关闭的,没有线程通过,在终点状态到来的时候,门开了,允许所有线程都通过。一旦闭锁到达了终点状态,他就不能够在改变状态了,所以它会永远保持敞开的状态。闭锁的应用确保一个计算不会执行,直到它需要
seaicelin
·
2023-07-23 13:58
Java并发
| 单例的其他实现
单例模式静态内置类实现classMyObject{privatestaticclassMyObjectHandler{privatestaticMyObjectobject=newMyObject();}privateMyObject(){}publicstaticMyObjectgetInstance(){returnMyObjectHandler.object;}}使用static代码块实现c
icebreakeros
·
2023-07-23 05:20
JAVA
编程学习笔记
,多线程面试题整理
Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言。Java技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。给你学习路线:html-css-js-jq-javase-数据库-jsp-servlet-Struts2-hibernate-mybatis-spring4-springmv
Java小辰
·
2023-07-23 01:38
JDK中的Future异步编程模式
JDK中的Future在
Java并发
包(JUC包)中Future代表着异步计算的结果,Future中提供了一些方法用来检查计算结果的完成,还提供了同步等待任务执行完成的方法,以及获取结果的方法。当计
逗逼程序员
·
2023-07-23 00:25
Java并发
——别再问 ReentrantLock 的原理了
说到并发,我们会马上想到锁,使用锁来保证各线程之间能够安全访问临界区以及非线程安全的数据。那为啥Java要提供另一种机制呢?难道synchronized关键字不香吗?嗯,它确实在有些场景不是那么香,从而迫切需要提供一种更灵活,更易于控制的锁机制。那在去了解DougLea大佬写的锁机制原理之前,我们自己先想想应该怎么去实现。自实现思考1、需要一个标志是否可以访问共享资源,如果直接使用boolean变
牧呈
·
2023-07-22 18:04
java并发
编程源码_
Java并发
编程实战 PDF+源码
《
Java并发
编程实战》深入浅出地介绍了Java线程和并发,是一本完美的
Java并发
参考手册。
谭俊云
·
2023-07-22 17:29
java并发编程源码
Java并发
编程基础
一、Java为什么要多线程?为了合理利用CPU的高性能,平衡【CPU、内存、I/O设备】的速度差异,计算机体系结构、操作系统、编译程序都做出了贡献,主要体现为:CPU增加了缓存,以均衡与内存的速度差异;操作系统增加了进程、线程,以分时复用CPU,进而均衡CPU与I/O设备的速度差异;编译程序优化指令执行次序,使得缓存能够得到更加合理地利用。二、Java怎么实现多线程?线程的基本概念线程实现:Jav
柚子过来
·
2023-07-21 23:27
快速掌握Java线程池:从ThreadPoolExecutor深入理解
Java并发
编程
1、线程池简介线程池的创建和回收是一个非常消耗系统资源的过程,如果在系统中频繁地创建和回收线程,会极大降低程序的执行性能。并且,短时间内创建大量的线程可能造成CPU占用100%、死机或内存溢出等问题。而使用线程池就能非常轻松地解决这些问题。1.1线程池核心类继承关系线程池是Java从JDK1.5版本开始提供的一种线程使用模式,能够自动创建和回收线程,并管理线程的生命周期。在线程池中能够管理和维护多
coder叶辰
·
2023-07-21 22:07
java
jvm
java
Project Loom:旨在改进 Java 并发编程模型
ProjectLoom是一个旨在改进
Java并发
编程模型的项目。该项目的目标是提供一种新的轻量级线程实现方式,使得Java应用程序可以更容易地实现高并发和高吞吐量的编程模型。
Walter Sun
·
2023-07-21 15:04
java
开发语言
Java并发
编程详解
上一篇文章多线程相关概念的梳理(个人理解)主要从宏观层面上讲了多线程并发的一些概念,这篇文章则围绕Java,聊聊并发编程。sychronized关键字JVM实际上只提供了一种锁,即sychronized关键字,这一点我们从Java的Thread类中定义的State可见一斑。Java中线程状态总共有NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING、TERMINAT
Ninja88!
·
2023-07-21 15:32
jvm
java
算法
Linux 网络
编程学习笔记
——三、TCP 协议详解
目录一、TCP服务的特点传输层协议主要有TCP协议和UDP协议,前者相对于后者的特点是:面向连接、字节流和可靠传输。使用TCP协议通信的双方必须先建立连接,然后才能开始数据的读写。双方都必须为该连接分配必要的内核资源,以管理连接的状态和连接上数据的传输。TCP连接是全双工的,即双方的数据读写可以通过一个连接进行。完成数据交换之后,通信双方都必须断开连接以释放系统资源。TCP协议的这种连接是一对一的
BeZer0
·
2023-07-21 07:40
计算机网络
网络
tcp/ip
linux
读 GitChat 线程三部曲 笔记
GitChat线程三部曲Java编程之美-线程相关的基础知识Java编程之美:并发编程高级篇之一
Java并发
编程(高级篇)笔记Thread.join()阻塞当前线程,直到join的线程执行完毕ThreadLocalThreadLocal
画十
·
2023-07-21 04:29
Java基础面试题(2021最新版)
cosen1024/Java-Interview国内Gitee(可下载pdf):https://gitee.com/cosen1024/Java-Interview这是一个很干的面试题合集,主要涉及Java基础、
Java
程序员库森
·
2023-07-21 02:19
最强
Java并发
编程详解:知识点梳理,BAT面试题等
来源:cnblogs.com/pengdai/p/12026959.html知识体系系统性梳理
Java并发
之基础A.Java进阶-
Java并发
之基础:首先全局的了解并发的知识体系,同时了解并发理论基础和线程基础
Java团长在csdn
·
2023-07-20 18:57
队列
编程语言
java
面试
并发编程
Java并发
与多线程(3)——Java中的锁
三、Java中的锁三、Java中的锁3.1JVM中的对象内存布局3.1.1MarkWord3.1.2指向类的指针:3.1.3数组长度:3.2Java中Monitor对象3.3Java中共享数据3.3.1不可变3.3.2绝对线程安全3.3.3相对线程安全3.3.4线程兼容3.3.4线程对立3.4线程安全的实现3.4.1互斥同步(阻塞同步)3.4.1.1synchronized关键字3.4.1.2Re
冷雨夜中漫步
·
2023-07-20 17:53
Java基础
java
后端
【多线程】(六)
Java并发
编程深度解析:常见锁策略、CAS、synchronized原理、线程安全集合类和死锁详解
文章目录一、常见锁策略1.1乐观锁和悲观锁1.2读写锁1.3重量级锁和轻量级锁1.4自旋锁1.5公平锁和非公平锁1.6可重入锁和不可重入锁二、CAS2.1什么是CAS2.2CAS的实现原理2.3CAS应用2.4ABA问题三、synchronized原理3.1synchronized锁的特点3.2加锁工作过程3.3锁消除和锁粗化四、JUC(java.util.concurrent)的常见类和接口4.
李 ~
·
2023-07-20 17:53
Java进阶
java
多线程
Java并发
-锁
17年10月份接触的
java并发
,距离现在也有一段时间了,对锁这一块一直处于非常迷茫疑惑的状态,一是因为有些概念比较抽象,二是名词性的东西太多,没有一个整体的理解很难去区分不同的名词和概念,因此写篇博客把锁想过知识点整理一下
8714f2c3f1b0
·
2023-07-20 15:50
Java并发
基础(4):Synchronized原理和锁优化升级过程
目录写在前面1、synchronized使用1.1、synchronized使用方式1.2、验证1.2.1、普通方法和代码块中使用this是同一个监视器(锁),即具体调用该代码的对象1.2.2、静态方法和代码块中使用该类的class对象是同一个监视器,任何该类的对象调用该段代码时都是在争夺同一个监视器的锁定1.3、Synchronized使用场景2、synchronized的特点3、synchro
CodingALife
·
2023-07-20 13:58
Java并发编程
java
面试
被字节拷打了~基础还是太重要了...
不同厂的面试风格都不同,如果java同学去面阿里、美团、京东这类的java大厂,面试的问题大概率是集中在java相关的问题,比如
java并发
、java集
骨灰级收藏家
·
2023-07-20 00:19
互联网
面试
求职
面试
数据库
算法
数据链路层
【
Java并发
编程】CAS详解和并发安全问题
CAS和Atomic类(1)概念原子性同事务的原子性概念一样,对多个操作的处理,要么全部成功,要么全部失败;原子性实现方案synchronized锁可以实现原子性,基于阻塞的锁机制,效率低。可能导致优先级高的线程一直被阻塞,使用不当可能导致死锁,锁机制粒度大;为了解决以上synchronized锁的缺点,Java提供了Atomic类系列原子操作类;(2)CAS实现原子性CAS的实现原理底层是调用n
Firechou
·
2023-07-19 05:29
#
Java基础
java
安全
CAS
Atomic
线程安全
并发编程
【
Java并发
编程】导致JVM内存泄露的ThreadLocal详解
ThreadLocal及内存泄漏(1)说明ThreadLocal为每个线程都提供了变量的副本(ThreadLocalMap),使得每个线程在某一时间访问到的并非同一个对象,这样就隔离了多个线程对数据的数据共享;ThreadLocal和Synchonized区别:ThreadLocal和Synchonized都用于解决多线程并发访问。可是ThreadLocal与synchronized有本质的差别。
Firechou
·
2023-07-19 05:58
#
Java基础
java
开发语言
ThreadLocal
并发编程
内存泄漏
【死磕
Java并发
】—–Java内存模型之happens-before
在上篇博客(【死磕
Java并发
】—–深入分析volatile的实现原理)LZ提到过由于存在线程本地内存和主内存的原因,再加上重排序,会导致多线程环境下存在可见性的问题。
Zal哥哥
·
2023-07-19 03:04
Java并发
编程:线程的创建方式,状态周期管理
一、并发编程简介1、基础概念程序与计算机系统操作有关的计算机程序、规程、规则,以及可能有的文件、文档及数据。进程进程是计算机中的程序,关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。线程线程是操作
java进阶程序员xx
·
2023-07-19 03:21
【八股文系列】
Java并发
【线程和进程】进程是对运行时程序的封装,是系统进行资源调度和分配的的基本单位,实现了操作系统的并发;线程是进程的子任务,是CPU调度和分派的基本单位,用于保证程序的实时性,实现进程内部的并发;线程是操作系统可识别的最小执行和调度单位。每个线程都独自占用一个虚拟处理器:独自的寄存器组,指令计数器和处理器状态。每个线程完成不同的任务,但是共享同一地址空间(也就是同样的动态内存,映射文件,目标代码等等)
锦还之路
·
2023-07-18 20:01
Java
基础
java
Java并发
编程艺术pdf下载(有感情的重排版本)
下载(10.17MB)(gitee.com)普普通通一学生,常在网上找学习资料(没少白嫖过),有洁癖,看不惯扫描版的PDF和没的感情的文字识别(格式乱的无法忍受)。实在找不到心仪的版本,就只能自己动手一页页排版,然后收集起来,放到仓库:https://gitee.com/uitc/save-paper为之后学习的同学节约点儿找资料的时间。(别问我叫啥,问就是雷锋)为了不影响强迫症的阅读体验,水印也
swingfer
·
2023-07-18 17:44
常规操作
Java并发编程艺术
Java
并发编程
Java并发
编程的艺术
1、并发编程的挑战1、上下文切换CPU通过给每个线程分配CPU时间片来实现多线程机制。时间片是CPU分配给各个线程的时间,这个时间非常短,一般是几十毫秒。CPU通过时间片分配算法来循环执行任务,当前任务执行一个时间片后会切换到下一个任务,但是,在切换前会保存上一个任务的状态,以便下次切换回这个任务时,可以再加载这个任务的状态。所以任务从保存到再加载的过程就是一次上下文切换。1.1、如何减少上下文切
赛尔号-
·
2023-07-18 17:13
面试题集锦
java
多线程
并发编程
# Java 并发编程的艺术(三)
Java并发
编程的艺术(三)文章目录
Java并发
编程的艺术(三)Java内存模型Java内存模型的基础Java内存模型的抽象结构从源代码到指令序列的重排序重排序happens-beforeJMM的设计happens-before
全栈程序员
·
2023-07-18 17:12
读书笔记
java
并发编程的艺术
《面试小抄》之Java基础篇36问与答 (2021最新版)
本文收录于《面试小抄》系列,Github地址:https://github.com/cosen1024/Java-Interview这是一个很干的面试题合集,主要涉及Java基础、
Java并发
、JVM、
程序员库森
·
2023-07-18 15:04
Java Synchronized 偏向锁/轻量级锁/重量级锁的演变过程
地中断线程-实践篇Java“优雅”地中断线程-原理篇真正理解JavaVolatile的妙用JavaThreadLocal你之前了解的可能有误JavaUnsafe/CAS/LockSupport应用与原理
Java
小鱼人爱编程
·
2023-07-18 12:47
Java
并发
java
测试工具
Java 线程池之线程返回值
地中断线程-实践篇Java“优雅”地中断线程-原理篇真正理解JavaVolatile的妙用JavaThreadLocal你之前了解的可能有误JavaUnsafe/CAS/LockSupport应用与原理
Java
小鱼人爱编程
·
2023-07-18 12:47
Java
并发
java
eclipse
java并发
volatile关键字的理解
在多线程的环境,当一个线程修改了共享变量,另一个线程能读取到这个变量的修改值,变量java提供了volatile保证了变量的可见性,轻量级的synchronized它实现的原理主要有以下两个方面追加的LOCK#指令会使处理器缓存行写回到内存一个处理器的缓存写回到内存会使其他处理器的缓存无效volatile的应用先看一段代码,假如线程1先执行,线程2后执行://线程1booleanstop=fals
xiazki
·
2023-07-18 07:29
干货:
Java并发
编程系列之volatile(一)
Java语言规范第三版中对volatile的定义如下:Java编程语言允许线程访问共享变量,为了确保共享变量能被准确和一致地更新,线程应该确保通过排他锁单独获得这个变量。了解volatile关键字之前需要先了解下Java内存模型,java内存模型抽象示意图如下:Java内存模型线程A和线程B之间若要通信的话,必须经历下面两个步骤(1)线程A和线程A本地内存中更新过的共享变量刷新到主存中去。(2)线
程序员技术圈
·
2023-07-18 05:08
Java进阶必读书单及博客
java基础Java核心技术卷I:开发基础(原书第12版)Java核心技术卷II:高级特性(原书第12版)JVM《深入理解Java虚拟机(第3版)》并发《
Java并发
编程实战》《
Java并发
编程的艺术》
TheFeasterfromAfar
·
2023-07-18 02:18
java
mysql
数据库
上一页
23
24
25
26
27
28
29
30
下一页
按字母分类:
A
B
C
D
E
F
G
H
I
J
K
L
M
N
O
P
Q
R
S
T
U
V
W
X
Y
Z
其他