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基础和多线程基础个别问题整理
Java并发编程
:Lock转载http://www.cnblogs.com
shine_du
·
2024-03-13 22:17
架构师之路
多线程
java
队列
面试 Java 并发编程八股文十问十答第四期
面试
Java并发编程
八股文十问十答第四期作者:程序员小白条,个人博客相信看了本文后,对你的面试是有一定帮助的!关注专栏后就能收到持续更新!⭐点赞⭐收藏⭐不迷路!
程序员小白条
·
2024-03-13 21:17
面试八股文系列
面试
java
职场和发展
八股文
面试基础
项目实战
Java面试八股文
1.网络一文搞懂所有计算机网络面试题-知乎01我应该站在谁的肩膀上-OSIvsTCPIP模型2.Java面渣逆袭必看,面试题八股文Java基础、Java集合框架、
Java并发编程
、JVM、Spring、
翁正存
·
2024-02-26 05:16
java
JAVA高并发——JDK的
并发容器
文章目录1、超好用的工具类:并发集合简介2、线程安全的HashMap3、深入浅出ConcurrentHashMap3.1、ConcurrentHashMap的内部数据结构3.2、put()方法的实现3.3、get()方法的实现4、有关List的线程安全5、高效读写的队列:深度剖析ConcurrentLinkedQueue类6、高效读取:不变模式下的CopyOnWriteArrayList类7、数据
布道师小羊
·
2024-02-20 16:39
#
网络+并发+函数式+JVM
JAVA高阶
java
开发语言
Scala基础教程--19--Actor
1.1
Java并发编程
的问题在
Java并发编程
中,每个对象都有一个逻辑监视器(monitor),可以用来控制对象
落空空。
·
2024-02-20 10:28
java
spark
scala
java
开发语言
redo log —— MySQL宕机时数据不丢失的原理
扫描下方二维码或者微信搜索公众号菜鸟飞呀飞,即可关注微信公众号,阅读更多Spring源码分析、
Java并发编程
和Netty源码系列文章。问题在开始阅读本文之前,可以先思考一下下面两个问题。
天堂2013
·
2024-02-20 02:00
MySQL
MySQL
redo
log
java
Java多线程系列——内存模型JMM
目录核心思想关键概念1.可见性2.原子性3.有序性工作原理并发工具类对并发编程的影响同步策略JMM的实践意义结语Java内存模型(JavaMemoryModel,JMM)是
Java并发编程
中的核心概念,
飞影铠甲
·
2024-02-19 23:00
Java
java
开发语言
c++
算法
JAVA并发编程
之synchronized与Lock锁详解
synchronized与Lock锁synchronized和ReentrantLock都是Java中提供的互斥锁。从功能上来说,你使用无论哪个,功能向都是一样的。today主要分析这两种锁他的实现逻辑。没把锁都聊两个维度的内容:加锁(排队等待)和释放锁wait¬ify、await&signal一、ReentrantLock锁特性要聊ReentrantLock,首先大家必须要知道AQS是什么
一只经常emo的程序员
·
2024-02-19 10:10
java
java
dreamweaver
开发语言
JAVA并发编程
之ConcurrentHashMap详解
ConcurrentHashMap一、ConcurrentHashMap写入数据流程一般在项目中使用ConcurrentHashMap时,都是作为JVM缓存使用的。ConcurrentHashMap是线程安全的。如果你项目涉及到了多个线程都会操作key-value结构时,别用HashMap,一定要上ConcurrentHashMap。在方法局部内,只有当前线程使用时,才可以用HashMap。Con
一只经常emo的程序员
·
2024-02-19 10:40
java
java
开发语言
Java 并发编程之一——天生的多线程语言
《
Java并发编程
》专栏旨在从头讲解
Java并发编程
的相关知识。为初学者和相关开发的同学提供一个由浅入深、由内到外的学习方向。如果文章中存在错误或者讲解不清楚的地方,欢迎大家互相讨论和指正!
君若雅
·
2024-02-15 07:58
深入理解
Java
并发编程
java
后端
Java进阶之光!java向数据库添加中文乱码
Java并发编程
3、什么是多线程中的上下文切换?4、死锁与活锁的区别,死锁与饥饿的区别?5、Java中用到的线程调度算法是什么?6、什么是线程组,为什么在Java中不推荐使用?》
编码老司机
·
2024-02-15 05:32
程序员
面试
后端
java
java并发编程
(一)线程与进程
一、进程进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体。在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。1.1进程切换进程从硬盘读取我们的程序代码,这个时候是比较费时的,CPU不会阻塞在这里等着,而是切
我犟不过你
·
2024-02-15 04:34
java并发编程
的艺术
java并发编程
的艺术第一章–并发的挑战1。
可爱的小小小狼
·
2024-02-14 22:06
并发编程
java
spring
开发语言
Java并发编程
基础
编写优质的并发代码是一件难度极高的事情。Java语言从第一版本开始内置了对多线程的支持,这一点在当年是非常了不起的,但是当我们对并发编程有了更深刻的认识和更多的实践后,实现并发编程就有了更多的方案和更好的选择。本文是对并发编程的一点总结和思考,同时也分享了Java5以后的版本中如何编写并发代码的一点点经验。为什么需要并发并发其实是一种解耦合的策略,它帮助我们把做什么(目标)和什么时候做(时机)分开
笨笨11
·
2024-02-14 19:09
Java 并发编程之美:并发编程高级篇之一-chat
借用
Java并发编程
实践中的话:编写正确的程序并不容易,而编写正常的并发程序就更难了。
阿里加多
·
2024-02-13 03:10
Ainx-V0.2-简单的连接封装与业务绑定
本文收录于Ainx系列,大家有兴趣的可以看一看相关专栏Rust初阶教程、go语言基础系列、spring教程等,大家有兴趣的可以看一看
Java并发编程
系列,设计模式系列、goweb开发框架系列正在发展中,
过去日记
·
2024-02-12 03:27
AINX
开发语言
go
tcp
golang
Java并发编程
之Volatile原理
Volatile定义Java语言规范第3版中对volatile的定义如下:Java编程语言允许线程访问共享变量,为了确保共享变量能被准确和一致地更新,线程应该确保通过排他锁单独获得这个变量。Java语言提供了volatile,在某些情况下比锁要更加方便。如果一个字段被声明成volatile,Java线程内存模型确保所有线程看到这个变量的值是一致的。CPU的相关术语术语术语描述内存屏障用一组处理器指
逍遥白亦
·
2024-02-12 01:51
java并发编程
艺术读书笔记
1.减少上下文切换的方法有无锁并发编程、CAS算法、使用最少线程和使用协程。无所并发编程:多线程竞争锁时,会引起上下文切换,所以多线程处理数据时,可以用一些办法来避免使用锁,如将数据的ID按照Hash算法取模分段,不同的线程处理不同段的数据;CAS算法:Java的Atomic包使用CAS算法来更新数据,而不需要加锁;使用最少线程:避免创建不需要的线程,比如任务很少,但是创建了很多线程来处理,这样会
奔跑的Robi
·
2024-02-11 20:14
Java并发编程
:Java线程池核心ThreadPoolExecutor的使用和原理分析
引出线程池线程是并发编程的基础,前面的文章里,我们的实例基本都是基于线程开发作为实例,并且都是使用的时候就创建一个线程。这种方式比较简单,但是存在一个问题,那就是线程的数量问题。假设有一个系统比较复杂,需要的线程数很多,如果都是采用这种方式来创建线程的话,那么就会极大的消耗系统资源。首先是因为线程本身的创建和销毁需要时间,如果每个小任务都创建一个线程,那么就会大大降低系统的效率。其次是线程本身也是
Zhang.Voi
·
2024-02-11 14:08
JAVA
java
开发语言
后端
并发编程(一)-多线程&并发设计原理
Java并发编程
主要涉及以下几个部分:并发编程三要素原子性:即一个不可再被分割的颗粒。在Java中原子性指的是一个或多个操作要么全部执行成功要么全部执行失败。有序性:程序执行的顺序按照代码的
Alan1914
·
2024-02-11 07:49
Java 多线程(二)基础构建模块
基础构建模块
并发容器
同步容器将所有对容器状态的访问都串行化,以实现它们的线程安全性。ConcurrentHashMap同步类容器在执行每个操作期间都持有一个锁。
闲相思
·
2024-02-10 09:12
【
java并发编程
实战读书总结6】显式锁
Java5.0以后除了内置锁synchronized外在concurrent包还提供了显式锁接口Lock。何为显式?就是显式地加锁和解锁,需要自己写代码去加锁和解锁。Synchronized是隐式加锁解锁,也就是无需自己写加锁解锁代码,进了synchronized代码块就隐式加锁,出了代码块就隐式解锁。下图为使用显式锁保证计数结果正确的demo:aaa.png在lock和unlock之间的代码是被
powerjiajun
·
2024-02-10 04:54
JUC-
java并发编程
的艺术
一、并发问题上下文切换:CPU通过时间片分配算法来循环执行任务,当前任务执行一个时间片后会切换到下一个任务。在切换前会保存上一个任务的状态,以便下次切换回这个任务时,可以再加载这个任务的状态。所以任务从保存到再加载的过程就是一次上下文切换。多线程不一定快:多线程有线程创建和上下文切换的开销。减少上下文切换:无锁并发:多线程竞争锁时,会引起上下文切换,所以多线程处理数据时,可以用一些办法来避免使用锁
HBryce24
·
2024-02-09 16:53
并发
java
Java并发编程
:synchronized
在多线程编程过程中,那一定避免不了线程安全的问题。由于每个线程执行过程是不可控的,所以很可能导致最终的结果与实际上的愿望相违背或者直接导致程序出错。那么怎么解决线程安全的问题呢?基本上所有的并发模式在解决线程安全的问题时,都是采用互斥访问的方式来解决,就是在同一时刻,只能由一个线程访问共享的资源。也就是在访问共享资源的代码之前加一个锁,当线程访问该资源时持有这个锁,等访问结束释放这把锁,这样别的线
匿名用户_bcc3
·
2024-02-09 03:07
锁(一)java中的锁相关
《
Java并发编程
的艺术》-Java并发包中的读写锁及其实现分析|并发编程网–ifeve.com一、java.util.concurrent.Lock接口1、锁的简单介绍锁可以控制多个线程访问共享资源的方式
w_t_y_y
·
2024-02-07 13:07
多线程编程
安全
java
jvm
java多线程实现(二)Java
并发容器
和框架
一、CouncurrentHashMap二、ConcurrentLinkedQueue三、java中的阻塞队列jdk7提供了7个阻塞队列四、Fork/Join框架
w_t_y_y
·
2024-02-07 13:37
多线程编程
java
开发语言
阻塞队列BlockingQueue实战及其原理分析
传送门:
并发容器
(Map、List、Set)实战及其原理目录阻塞队列介绍队列阻塞队列应用场景JUC包下的阻塞队列ArrayBlockingQueueArrayBlockingQueue使用ArrayBlockingQueue
Myname_China
·
2024-02-07 12:53
数据结构
并发编程
Java
java
开发语言
并发编程
并发容器
(Map、List、Set)实战及其原理
目录JUC包下的
并发容器
CopyOnWriteArrayList应用场景CopyOnWriteArrayList使用CopyOnWriteArrayList原理CopyOnWriteArrayList的缺陷扩展知识
Myname_China
·
2024-02-07 12:50
并发编程
数据结构
Java
数据结构
并发编程
java
AQS与ReentrantLock
AbstractQueuedSynchronizer简称AQS
Java并发编程
核心在于java.concurrent.util包而juc当中的大多数同步器实现都是围绕着共同的基础行为,比如等待队列、条件队列
蒋斌文
·
2024-02-07 06:41
Java并发编程
:线程间协作的两种方式:wait、notify、notifyAll和Condition
https://www.cnblogs.com/dolphin0520/p/3920385.html
博弈史密斯
·
2024-02-06 04:27
java并发编程
一、java线程1.三种创建线程的方式Integersum=futureTask.get();会等待其对应的线程执行完,即阻塞再获得结果。所以我在测试时,出现一个小插曲@Slf4jpublicclassThreeWays{//1.自定义MyThread进行继承Threadstaticvoidtest001(){Threadthread=newMyThread();thread.setName("t
grin : (0~.~0)
·
2024-02-05 18:50
java
开发语言
CountDownLatch并发测试
CountDownLatch是
并发容器
JUC下的类,允许一个或多个线程等待直到在其他线程中执行的一组操作完成的同步辅助。使用给定的计数初始化CountDownWatch。
l_learning
·
2024-02-05 10:51
Java并发基础:CyclicBarrier和CountDownLatch区别!
核心概念CyclicBarrier和CountDownLatch都是
Java并发编程
中的工具,用于协调多线程之间的同步。虽然它们都用于等待一组线程完成某项任务,但它们的使用场景和行为有一些关键的区别。
程序员古德
·
2024-02-05 07:01
Java并发基础
java
性能优化
开发语言
Ainx框架实现 一
本文收录于Ainx系列,大家有兴趣的可以看一看相关专栏Rust初阶教程、go语言基础系列、spring教程等,大家有兴趣的可以看一看
Java并发编程
系列,设计模式系列、goweb开发框架系列正在发展中,
过去日记
·
2024-02-05 00:19
AINX
go
网络
golang
线程池的7大参数及4大拒绝策略详解
这里借用《
Java并发编程
的艺术》提到的来说一下使用线程池的好处:降低资源消耗
YangYangYang24
·
2024-02-04 11:06
java
java并发编程
-线程池(三)Executors工厂类
如果觉得写的还可以请关注微信公众号:程序猿的日常分享,定期更新分享。Executors工厂线程池主要有三类,一个是用于创建立即执行的线程池ThreadPoolExecutor,一个是用于创建执行定时任务类线程池ScheduledThreadPoolExecutor,还有就是在jdk1.7引入的基于fork/join框架的分治线程池ForkJoinPool。基于这3种线程池实现类,Executors
wangpeng123
·
2024-02-04 04:09
业务程序中如何设置线程数?
我们通常在资料中找到一些经典的回答,例如判断任务是CPU密集型还是IO密集型,或者参考《
Java并发编程
实战》一书的建议:1.判断任务是CPU密集型还是IO密集型(其中N表示CPU的核心数量):CPU密集型
半亩方塘立身
·
2024-02-03 19:13
Java
面试
java
后端
java并发编程
0.思维导图并行:单位时间多个处理器同时处理多个任务并发:一个处理器处理多个任务,按时间片轮流处理1.java实现多线程有几种方式♥♥♥实现接口会更好一些,因为java不支持多重继承,因此继承了Thread类就无法继承其他类,但是可以实现多个接口继承Thread类,只需要创建一个类继承Thread类然后重写run方法,在main方法中调用该类实例对象的start方法。实现Runnable接口,只需
韩顺平的小迷弟
·
2024-02-03 16:04
#
java基础
java
数据库
开发语言
【零散知识点总结2】
1》该文章涉及:Dubbo、HTTP和HTTPS、Mybatis、Hibernate、Zookeeper、Kafka、Elasticsearch、Redis《零散知识点总结2》该文章涉及:MySQL、
Java
木林森屿城
·
2024-02-03 16:44
java
java
线程基础—
并发容器
:PriorityBlockingQueue
本文作者:王一飞,叩丁狼高级讲师。原创文章,转载请注明出处。#####概述按api上的解释,PriorityBlockingQueue是有一个带有优先级级别的无界阻塞队列,不支持null元素入列,并且要求队列对象必须为可以比较对象。这点跟PriorityQueue类类似,区别是PriorityBlockingQueue带有阻塞功能。PriorityBlockingQueue出列具有优先级之分,每次
叩丁狼
·
2024-02-03 03:36
杂集
JUC,
Java并发编程
JUC概述线程状态线程状态枚举类NEW新建RUNNABLE准备就绪BLOCK阻塞WAITING不见不散TIMED_WAITING过时不候TERMINATED中结并行与并发wait和sleep的区别sleep是Thread的静态方法,wait是Object的方法,任何对象实例都可以调用。sleep不会释放锁,它也不需要占用锁。若当前线程占有锁,那么wait会释放锁。他们都可以被interrupted
Benaso
·
2024-02-02 14:10
JUC
java
开发语言
JUC并发编程
Java并发编程
(JavaConcurrency)是指在Java程序中同时进行多个任务的一种编程方式。
星光不问赶路人-
·
2024-02-02 12:14
并发
JUC
java并发编程
基础(四)
Java中的锁1.Lock接口锁是用来控制多个线程访问共享资源的方式,一般来说,一个锁能够防止多个线程访问共享资源。在lock接口出现之前,java程序依靠synchroized关键字实现锁的功能,Loc接口拥有了获取锁与释放锁的可操作性,可中断的获取锁。packagecn.smallmartial.concurrency;importjava.util.concurrent.locks.Reen
smallmartial
·
2024-02-02 08:21
关于Redis分布式锁这一篇应该是讲的最好的了,先收藏起来再看!
前言在
Java并发编程
中,我们通常使用到synchronized、Lock这两个线程锁,Java中的锁,只能保证对同一个JVM中的线程有效。而在分布式集群环境,这个时候我们就需要使用到分布式锁。
前程有光
·
2024-02-01 16:57
并发编程技术之J.U.C中的
并发容器
——七个面试知识点
点关注,不迷路;持续更新Java架构相关技术及资讯热文!!!眼尖的朋友可能还看见了此博客页面左上角还有惊喜哟面试题1.Java集合框架以及J.U.C框架中列举List、Set、Map的实现?集合框架ListArrayListLinkedListMapHashMapSetHashSetTreeSetJ.U.C框架ListCopyOnWriteArrayListSetCopyOnWriteArrayS
Java_No01
·
2024-02-01 05:53
面试题
并发编程
并发容器
面试题
Java
程序人生
Java并发编程
之阻塞队列
1.什么是阻塞队列阻塞队列(BlockingQueue)是一个支持两个附加操作的队列。这两个附加的操作支持阻塞的插入和移除方法。支持阻塞的插入方法:意思是当队列满时,队列会阻塞插入元素的线程,直到队列不满。支持阻塞的移除方法:意思是在队列为空时,获取元素的线程会等待队列变为非空。阻塞队列常用于生产者和消费者的场景,生产者是向队列里添加元素的线程,消费者是从队列里取元素的线程。阻塞队列就是生产者用来
逍遥白亦
·
2024-01-31 22:24
ConcurrentSkipListMap 图解
高并发核心编程》大厂必备+大厂必备+大厂必备【博客园总入口】入大厂+涨工资必备:高并发【亿级流量IM实战】实战系列【SpringCloudNginx秒杀】实战系列【博客园总入口】JUC高并发工具类(3文章)与高
并发容器
类
40岁资深老架构师尼恩
·
2024-01-31 09:24
java
学习笔记:Java 并发编程(补)CompletableFuture
学习视频:https://www.bilibili.com/video/BV1ar4y1x727参考书籍:《实战JAVA高并发程序设计》葛一鸣著系列目录学习笔记:
Java并发编程
①_基础知识入门学习笔记
YanZhaoHanWei_555
·
2024-01-30 22:32
#
JUC
Java
基础学习
java
学习
并发编程之AQS初探
Java并发编程
核心在于java.concurrent.util包,而juc当中的大多数同步器实现都是围绕着共同的基础行为,比如等待队列、条件队列、独占获取、共享获取等,而这个行为的抽象就是基于AbstractQueuedSynchronizer
lianzhongzhang
·
2024-01-30 19:38
并发编程
并发编程
java
Java中的四种线程池详解及使用场景
前言在
Java并发编程
中,JDK提供了一套强大的线程池工具类java.util.concurrent.ThreadPoolExecutor以及它的四个便捷工厂方法,这四种线程池分别对应不同的使用场景和特性
李少兄
·
2024-01-30 13:10
Java
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
其他