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并发
- 原子类
CAS原子操作CAS(CompareandSwap)是一种并发算法,通常用于实现多线程环境下的同步操作,特别是在并发编程中实现无锁算法。CAS操作涉及三个参数:内存位置(V)、期望值(A)和新值(B)。操作的意义是:仅当V的值等于A时,才将V的值更新为B。整个操作是原子的,不会被其他线程中断。下面是CAS的基本原理:读取内存值(V):线程首先读取共享变量的当前值(V)。比较并交换(Comparea
--土拨鼠--
·
2024-01-14 13:08
Java
java
jvm
开发语言
Java并发
- synchronized关键字
synchronized关键字在Java中的主要作用是确保多线程环境下对共享资源的安全访问,避免出现竞态条件和数据不一致的问题。它的主要意义包括以下几个方面:保证原子性:synchronized关键字能够确保被它修饰的方法或代码块在同一时刻只能被一个线程执行。解决竞态条件:使用synchronized关键字可以防止竞态条件的发生,确保对共享资源的操作按照预期的顺序执行。实现线程间通信:synchr
--土拨鼠--
·
2024-01-14 13:07
Java
java
开发语言
Java并发
- volatile关键字
volatile是Java中的关键字,主要用于确保多线程环境下共享变量的可见性、禁止指令重排序以及一些轻量级的同步操作。1.volatile的作用详解可见性:当一个线程对volatile变量进行写操作时,这个变量的新值会立即被刷新到主内存,而不是在线程本地缓存中等待一段时间。当其他线程需要读取这个变量时,它会从主内存中重新加载,而不是使用线程本地缓存中的值。禁止指令重排序:volatile关键字禁
--土拨鼠--
·
2024-01-14 13:07
Java
java
jvm
开发语言
Java并发
- 线程基础
1.程序&线程定义:程序(Process):一个程序是一个独立的执行单元,它包含了代码、数据、和系统资源的集合。每个程序都运行在自己独立的内存空间中,互相之间不直接共享内存。线程(Thread):线程是程序的执行流程,是操作系统调度的最小单元。一个程序可以包含多个线程,它们共享程序的内存空间和资源。资源分配:程序(Process):每个程序有独立的内存空间和系统资源,包括文件句柄、网络连接等。程序
--土拨鼠--
·
2024-01-14 13:37
Java
java
开发语言
Java并发
- LockSupport详解
LockSupport是
Java并发
包(java.util.concurrent)中的一个工具类,用于实现线程的阻塞和唤醒操作。
--土拨鼠--
·
2024-01-14 13:57
Java
java
开发语言
java-ArrayBlockingQueue详解
在
Java并发
编程中,ArrayBlockingQueue是一个非常常用的工具类。它是一个由数组支持的有界阻塞队列,提供了线程安全的队列操作。
一杯可乐、
·
2024-01-14 10:17
多线程
java
常用Java代码-Java中的并发集合(ConcurrentHashMap、CopyOnWriteArrayList等)
1.ConcurrentHashMapConcurrentHashMap是
Java并发
包java.util.concurrent中的一个类,它提供了线程安全的Map实现。与Hashtabl
crmeb服务商-肥仔全栈开发
·
2024-01-14 08:08
java
windows
多线程设计模式-Guarded Suspension模式
GuardedSuspension设计模式是很多设计模式的基础,比如生产者消费者模式,同样在
Java并发
包中的BlockingQueue中也大量使用到了GuardedSuspension设计模式。
zjyfree
·
2024-01-13 16:13
设计模式
java
前端
Java多线程并发之同步容器和并发容器-第一篇
本文是《凯哥分享
Java并发
编程之J.U.C包讲解》系列教程中的第五篇。如果想系统学习,凯哥(kaigejava)建议从第一篇开始看。从本篇开始,我们就来讲解讲解Java的并发容器。大致思路:先介
tomfyyds
·
2024-01-13 14:46
程序员
java
java程序
java
经验分享
apache
开发语言
c语言
JAVA并发
-Semaphore
案例/***@authorqhong*@date2019/12/1310:59*https://www.cnblogs.com/dolphin0520/p/3920397.html*信号量*一个工厂有5台机器,但是有8个工人,一台机器同时只能被一个工人使用,只有使用完了,其他工人才能继续使用**/publicclassSemaphoreDemo{publicstaticvoidmain(Strin
hongdada
·
2024-01-13 06:08
Java并发
Condition 详解
1.引言在
Java并发
编程中,线程间的协作是一个核心话题。为了实现线程间的协作,Java提供了多种机制,其中等待/通知机制是最常见的一种。
一杯可乐、
·
2024-01-13 04:05
多线程
java
闲来无事,动手写一个本地缓存
学习
java并发
的时候,书上的例子是基于缓存展开的,于是就想可以写一个通用的本地缓存写在前面写一个缓存,需要考虑缓存底层存储结构、缓存过期、缓存失效、并发读写等问题,因此自己动手写的本地缓存将围绕这几点进行设计缓存失效缓存失效指的是缓存过期了
何甜甜在吗
·
2024-01-13 00:13
CyclicBarrier和CountDownLatch的区别?
`CyclicBarrier`和`CountDownLatch`都是
Java并发
工具类,用于协调多个线程的同步操作,但它们之间有一些关键的区别。
郭梓航
·
2024-01-12 20:55
CyclicBarrier
CountDownLatch
什么是AQS?
AQS(AbstractQueuedSynchronizer)是
Java并发
包中用于构建同步器的框架。
郭梓航
·
2024-01-12 20:55
AQS
Semaphore
Semaphore是
Java并发
包中的一个同步工具,用于控制同时访问特定资源的线程数量。它维护了一个许可证(permit)计数,线程在获取资源时需要消耗一个许可证,在释放资源时会释放一个许可证。
郭梓航
·
2024-01-12 20:55
算法
Semaphore
第四周
1.Algorithm:leetcode01https://www.jianshu.com/p/e80d1e9e860c2.Review:看了
Java并发
的一些内容,明天整理上传3.Tip:gitadd
衣锦昼行
·
2024-01-12 17:21
Java并发
之同步二:
Java并发
工具类
一、CountDownLatch(1等多汇总、多等1开关)countdownlatch底层原理,定义锁资源:0,当资源为0才叫拿到锁,所以countdownlatch也叫做倒数器,拿锁的时候判断是不是0,不是就park,然后countdown的时候,会-state的时,当state的值为1的时候,park的现场就会醒过来在我的理解下,CountDownLatch可以理解为就是一个同步器,让谁先做,
上海第一shen 深情
·
2024-01-12 17:45
#
java并发
java
开发语言
Java并发
Java多线程
Java并发
之互斥二:ReentrantLock(基于公平锁)
1.构造方法不传参数默认是非公平锁根据传的fair是否公平来创建锁基于公平锁来分析一下``所以最终我们又需要看到AQS这个类中,AQS是一个抽象的队列同步器AQS:AQS内部类(对应同步队列的每一个节点):staticfinalclassNode{//枚举:共享模式staticfinalNodeSHARED=newNode();//枚举:独占模式staticfinalNodeEXCLUSIVE=n
上海第一shen 深情
·
2024-01-12 17:15
#
java并发
java
linux
java多线程
ReentrantLock
Java并发
之同步三:Condition条件队列
一、总览二、源码分析2.1人口publicConditionnewCondition(){returnsync.newCondition();}finalConditionObjectnewCondition(){returnnewConditionObject();}publicclassConditionObjectimplementsCondition,java.io.Serializabl
上海第一shen 深情
·
2024-01-12 17:13
#
java并发
java
开发语言
java多线程
java并发
Contiditon
Java并发
编程——伪共享和缓存行问题
在
Java并发
编程中,伪共享(FalseSharing)和缓存行(CacheLine)是与多线程访问共享数据相关的两个重要概念。
ByeDark
·
2024-01-12 10:10
Java
java
缓存
Java并发
- Final关键字
1.final方法的基础使用1.1final修饰变量在声明基本类型的变量时,我们可以使用final关键字使其成为常量。一旦赋值,这个值将无法再被修改。finalintMAX_VALUE=100;//MAX_VALUE=200;//重新给MAX_VALUE赋值时,编译错误,无法修改final变量1.2引用类型的final变量对于引用类型的变量,final关键字确保引用不会再指向其他对象,但并不表示引
--土拨鼠--
·
2024-01-12 06:21
Java
java
开发语言
jvm
springboot 多数据源怎么配置在控制台的sql打印日志
最近整理了一波电子书籍资料,包含《EffectiveJava中文版第2版》《深入JAVA虚拟机》,《重构改善既有代码设计》,《MySQL高性能-第3版》,《
Java并发
编程实战》等等获取方式:关注公众号并回复电子书领取
飞乐鸟
·
2024-01-11 21:16
mybatis
spring
boot
java
Java并发
编程的艺术:深度剖析线程池的设计与应用
Java并发
编程作为应对这一挑
喔的 喔的嘛呀
·
2024-01-11 08:24
java
开发语言
【Java 面试题合集】ThreadPoolExecutor 线程池面试题
文章目录自定义的线程池的7个参数如何合理设置核心线程数corePoolSize的大小《
JAVA并发
编程实战》中的方案java开发手册中为什么不允许使用Executors默认的实现?
秀强
·
2024-01-10 16:50
并发编程
JUC
源码解析
java
一篇文章讲清楚
Java并发
理论基础
文章目录前言一、计算机操作系统的木桶效应二、CPU、内存和I/O设备之间的速度不匹配的问题解决三、并发出现线程不安全的根源:可见性、原子性和有序性问题四、JAVA是怎么解决并发问题的:JMM(Java内存模型)前言大家好,我是佩洛君,致力于新手友好地讲清楚Java开发问题的来龙去脉。一、计算机操作系统的木桶效应有过电脑硬件设备DIY的小伙伴们都知道,CPU显卡内存主板,如果哪一个很拉,整个电脑就会
佩洛君
·
2024-01-10 15:10
面试
学习Java必看
java
开发语言
「 并发编程技术 」剖析Synchronized修饰方法与代码块的区别(附详细代码案例解析)
「并发编程技术」剖析Synchronized修饰方法与代码块的区别(附详细代码案例解析)参考&鸣谢oldmonk真正的小明被占用了Java学到头秃《
Java并发
编程实战》《深入理解Java虚拟机》文章目录
FrozenPenguin
·
2024-01-10 06:40
JUC并发编程
并发编程技术
java
jvm
开发语言
Java并发
编程 Lock Condition & ReentrantLock(一)
Lock框架为
java并发
编程提供了除synchronized之外的另外一种选择。
weixin_44612246
·
2024-01-10 05:47
java
开发语言
Java并发
编程 Lock Condition & ReentrantLock(二)
完成上一篇文章的未尽事宜:ReentrantLock的lock、unlock源码分析Condition的await、signal源码分析ReentrantLock#locklock方法最终是由sync实现的,公平锁的sync是FairSync,非公平锁是UnfairSync。两者lock方法的区别是,公平锁FairSync直接调用acquire(1)方法,非公平锁UnfairSync则首先尝试获得
weixin_44612246
·
2024-01-10 05:47
java
开发语言
算法
JAVA学习专栏
JAVA专栏Java核心技术Java核心技术Java练手算法Java练手算法Java数据结构和算法Java数据结构和算法Java设计模式Java设计模式
Java并发
编程
Java并发
编程MySQL数据库MySQL
weixin_51551879
·
2024-01-09 22:37
java
java 全栈高级工程师,架构师学习资源 交流
redis集群zookeeper集群搭建与调优dubbo/dubbox分布式服务jvm调优,内存分析
java并发
dockerlinuxjmeter性能测试netty/minamycathadoop管理级别技能
昵称不能为null
·
2024-01-09 15:03
Java并发
编程之Java线程
文章目录前言01、线程简介02、线程池03、线程间通信总结前言记录一下
Java并发
编程的知识点。有部分内容是借鉴《
Java并发
编程的艺术》这本书的。本次先介绍一下线程。
Be reborn
·
2024-01-09 12:20
Java并发编程
java
Java并发
编程(Java Concurrency)(5) - 同一线程(Same-threading)
原文链接:http://tutorials.jenkov.com/java-concurrency/same-threading.html 摘要:这是翻译自一个大概30个小节的关于
Java并发
编程的入门级教程
编程武士
·
2024-01-08 21:19
Java并发
java
并发
编程
线程
java并发
多线程面试_Java多线程并发面试问答
java并发
多线程面试TodaywewillgothroughJavaMultithreadingInterviewQuestionsandAnswers.WewillalsolookintoConcurrencyinterviewquestionsandanswersbecausebothmultithreadingandconcurrencygohandinhand
cunchi4221
·
2024-01-08 21:19
python
多线程
面试
java
编程语言
Java多线程&并发篇----第一篇
系列文章目录文章目录系列文章目录前言一、
JAVA并发
知识库二、Java中实现多线程有几种方法三、继承Thread类四、实现Runnable接口。
数据大魔王
·
2024-01-08 15:48
java面试题套2
java
开发语言
Java并发
本博客仅对
Java并发
相关内容进行补充和调整。文章目录并发编程三要素?实现可见性的方法有哪些?线程B怎么知道线程A修改了变量synchronized的作用?
不胜舟
·
2024-01-08 08:32
Java八股文
java
jvm
开发语言
Java多线程及线程池
1.volatile内存模型的相关概念
Java并发
编程:volatile关键字解析-Matrix海子-博客园(cnblogs.com)在JVM底层volatile是采用“内存屏障”来实现的。
谭某人66
·
2024-01-08 08:30
多线程
java
Java并发
集合详解
第1章:引言大家好,我是小黑,在这篇博客中,咱们将一起深入探索Java中的并发集合。多线程编程是一个不可或缺的部分,它能让程序运行得更快,处理更多的任务。但同时,多线程也带来了一些挑战,尤其是在数据共享和同步方面。为了解决这些挑战,Java提供了一系列的并发集合,这些集合为处理并发数据访问提供了优雅而强大的解决方案。在单线程程序中,数据结构的设计往往较为简单,因为只有一个线程在任何时刻访问数据。但
宋小黑
·
2024-01-08 06:31
java
并发
多线程
Java基础常见面试题总结
注意,关于JVM和
Java并发
编程的面试题因为内容较多,单独整理。
夜雨风云
·
2024-01-08 01:13
面试
#
Java基础
Java
java
面试
Java基础
Java并发
多线程的6种状态
线程状态线程可以有以下6种状态1.New(新建)2.Runnable(可运行)3.Blocked(被阻塞)4.Waiting(等待)5.Timedwaiting(计时等待)6.Terminated(被终止新创建线程(New)当用new创建了一个线程,但是该线程还没有开始运行时,那么他的状态就是new。可运行线程(Runnable)一旦调用start方法,则该线程处于runnable状态,处于该状态
Jack_Tpy
·
2024-01-07 21:46
Java
多线程
java 的synchronized和volatile
java代码安全性的三大要素在
Java并发
编程中,原子性、可见性和有序性是保证代码安全性的三大要素。为了解决这些问题,Java提供了多个关键字和机制。
doka+
·
2024-01-07 17:52
java
开发语言
jvm
Java并发
编程的艺术:深度剖析锁的优化机制
目录第一章:引言第二章:锁的基础知识2.1synchronized关键字2.2ReentrantLock第三章:锁的优化手段3.1自旋锁3.2可重入锁3.3读写锁3.4锁的粒度控制3.5CAS与乐观锁第四章:锁的升级与降级4.1锁的升级4.2锁的降级4.3适用场景与注意事项第五章:实际案例分析5.1初始版本:基本锁机制5.2自旋锁优化5.3读写锁优化5.4锁粒度控制优化第六章:性能测试与对比分析6
喔的 喔的嘛呀
·
2024-01-07 05:16
java
开发语言
RocketMQ生产部署架构设计,建议收藏
梳理知识后,夯实基础乃是刚需:深入进阶学习(28个主流Java知识点“一网打尽”)1、并发编程
Java并发
编程是整个Java开发体系中最难以理解,但也是最重要的知识点之一,一旦掌握你一定在市场上供不应求
imtokenmax合约众筹
·
2024-01-06 19:36
程序员
java
经验分享
面试
Java并发
编程(八) ScheduledThreadPoolExecutor
下面我们来说一下ScheduledThreadPoolExecutor。我们之前说过,定时任务的线程池不是直接用ThreadPoolExecutor实现的,其实是用ScheduledThreadPoolExecutor实现的,下面我们就来分析一下定时任务的线程池的原理。我们来看一下ScheduledThreadPoolExecutor的构造方法publicScheduledThreadPoolEx
skyguard
·
2024-01-06 18:05
Java并发
编程常识
写中间件经常要做两件事:1.延迟加载,在内存缓存已加载项。2.统计调用次数,拦截并发量。就这么个小功能,团队里的人十有八九写错。上面这句话不是我说的,是梁飞在他的博客里面说的。梁飞是谁?据网上的公开资料,梁飞,花名虚极。2009年加入阿里巴巴,负责中间件的开发,Dubbo开源分布式服务框架作者,HTTL开源模板引擎作者。2012年加入天猫,负责手机天猫APP的技术团队,见证了天猫双11无线化全过程
雪中悍刀跑
·
2024-01-06 14:09
免费的GPT4来了,你还不知道吗?
最近整理了一波电子书籍资料,包含《EffectiveJava中文版第2版》《深入JAVA虚拟机》,《重构改善既有代码设计》,《MySQL高性能-第3版》,《
Java并发
编程实战》等等获取方式:关注公众号并回复电子书领取
飞乐鸟
·
2024-01-06 11:06
GPT
备战春招!2024最新Java春招高频面试题总结!精选312道(附答案PDF)
一、
Java并发
编程基础1.谈谈你对AQS的理解2.lock和synchronized区别3.线程池如何知道一个线程的任务已经执行完成4
浮生带你学Java
·
2024-01-05 21:14
Java面试题
java
面试
学习方法
跳槽
职场和发展
java并发
之阻塞队列DelayQueue
前言在深入之前先了解下下ReentrantLock和Condition:重入锁ReentrantLock:ReentrantLock锁在同一个时间点只能被一个线程锁持有;而可重入的意思是,ReentrantLock锁,可以被单个线程多次获取。ReentrantLock分为“公平锁”和“非公平锁”。它们的区别体现在获取锁的机制上是否公平。“锁”是为了保护竞争资源,防止多个线程同时操作线程而出错,Re
fastjson_
·
2024-01-05 20:28
java
并发编程
java
rabbitmq
Java并发
系列(14)——synchronized之HotSpot源码解读(上)
上一篇:《
Java并发
系列(13)——线程池的选择与参数设置》文章目录10synchronized实现原理10.1研究思路10.1.1输出JVM指令10.1.2跟踪JVM源码10.2预备知识10.2.1
JinchaoLv
·
2024-01-05 19:11
并发
java
synchronized
多线程
并发
偏向锁
虚拟线程:Java21 并发编程的新篇章
虚拟线程:
Java并发
编程的新篇章在现代软件开发中,对并发处理的需求日益增长。随着Java21引入虚拟线程,这一领域即将迎来革新。
半个程序员一个哲学家
·
2024-01-05 18:17
java
java
servlet
jvm
Java 学习路线图
Java并发
编程:包括线程、锁、同步和异步等。Java数据库编程:包括JDBC和ORM框架的使用。JavaWeb开发:包括Servlet、JSP、M
꧁缘法天地间꧂
·
2024-01-04 19:12
java
上一页
1
2
3
4
5
6
7
8
下一页
按字母分类:
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
其他