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并发编程
:线程安全的策略与实践
哈喽,各位小伙伴们,你们好呀,我是喵手。运营社区:C站/掘金/腾讯云/阿里云/华为云/51CTO;欢迎大家常来逛逛 今天我要给大家分享一些自己日常学习到的一些知识点,并以文字的形式跟大家一起交流,互相学习,一个人虽可以走的更快,但一群人可以走的更远。 我是一名后端开发爱好者,工作日常接触到最多的就是Java语言啦,所以我都尽量抽业余时间把自己所学到所会的,通过文章的形式进行输出,希望以这种方式
喵手
·
2025-01-20 19:47
零基础学Java
java
安全
开发语言
深入理解 Java 并发编程中的锁机制
深入理解
Java并发编程
中的锁机制在
Java并发编程
中,锁是一个至关重要的概念,它用于确保多个线程在访问共享资源时能够遵循正确的顺序和互斥规则。
向着开发进攻
·
2025-01-20 12:02
java并发编程
java
开发语言
Java并发编程
:线程池优化实战指南
Java并发编程
:线程池优化实战指南1.线程池的核心概念在
Java并发编程
中,线程池是管理线程的利器。它通过复用线程、减少线程创建和销毁的开销,显著提升了系统性能和资源利用率。
莫非技术栈
·
2025-01-17 11:48
java
java
开发语言
【Java】已解决:java.util.concurrent.CompletionException
分析问题背景出现问题的场景代码片段二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项已解决:java.util.concurrent.CompletionException一、分析问题背景在
Java
屿小夏
·
2024-09-16 04:11
java
开发语言
Java并发编程
-AQS详解及案例实战(上篇)
文章目录AQS概述AQS的核心概念AQS的工作原理AQS的灵活性使用场景使用指南使用示例AQS的本质:为啥叫做异步队列同步器AQS的核心机制“异步队列”的含义“同步器”的含义总结加锁失败的时候如何借助AQS异步入队阻塞等待AQS的锁队列加锁失败时的处理流程异步入队的机制总结ReentractLock如何设置公平锁策略以及原理设置公平锁策略公平锁的运作原理尝试获取锁释放锁性能与公平性的权衡tryLo
猿与禅
·
2024-09-15 02:56
Java技术栈源码分析
java
AQS
并发编程
原理
Java并发编程
:线程生命周期
Java并发编程
专栏文章收录于
Java并发编程
专栏线程生命周期 线程是
Java并发编程
的核心概念,理解线程生命周期对于编写高效的并发程序至关重要。
乐只乐之
·
2024-09-10 04:43
Java并发编程
java
职场和发展
后端
SpringBoot高并发!java分布式开发面试题
梳理知识后,夯实基础乃是刚需:深入进阶学习(28个主流Java知识点“一网打尽”)1、并发编程
Java并发编程
是整个Java开发体系中最难以理解,但也是最重要的知识点之一,一旦掌握你一定在市场上供不应求
spring面试题
·
2024-09-07 02:38
程序员
面试
后端
java
Java并发编程
(五)—ReetrantLock详解及应用
锁的可重入性可重入锁不可重入锁7、性能优化二、ReentrantLock和Synchronized的区别1、语法和使用方式2、锁的获取和释放3、高级特性4、条件变量5、性能总结三、ReentrantLock使用场景之前的文章
Java
echola_mendes
·
2024-09-06 17:05
Java并发编程
java
开发语言
Java修炼之道--并发编程
参考资料:《
Java并发编程
实战》第一部分:并发编程1.线程状态转换新建(New)创建后尚未启动。可运行(Runnable)可能正在运
weixin_30312557
·
2024-09-05 22:32
运维
面试
操作系统
深入理解 `ThreadLocal` 的 `set` 和 `get` 方法
ThreadLocal类在
Java并发编程
中非常有用,它允许每个线程拥有自己独立的变量副本。
CodeDunkster
·
2024-09-05 14:06
java
jvm
开发语言
Java 内存模型-锁的内存语义
章节目录锁的释放-获取建立的happens-before关系锁的释放-获取的内存语义锁的释放-获取建立的happens-before关系锁是
Java并发编程
中最重要的同步机制。
markfork
·
2024-09-03 20:20
Java8 关于最佳线程数
前言关于最佳线程数的设置,总是那么模糊,不知道该如何设置,偶然间在
Java并发编程
实践里看到了对他的定义:要使处理器达到期望的使用率,线程池的最佳大小等于:1695055395.jpg需要注意的是,我们需要制定一个
没有颜色的菜
·
2024-08-28 17:04
Java并发编程
的核心概念--线程与进程
原子性:操作或多个操作要么全部执行且不被打断,要么都不执行。这保证了线程在执行操作时不会被其他线程干扰。可见性:当多个线程访问同一个变量时,一个线程修改了这个变量的值,其他线程能够立即看到修改的值。这通过volatile关键字、synchronized和Lock等机制实现。有序性:程序执行的顺序按照代码的先后顺序执行。Java内存模型允许指令重排序,但提供了vola
纣王家子迎新
·
2024-08-27 09:22
java
开发语言
学习
线程与进程
Java并发编程
(四)—synchronized关键字的应用
目录1、synchronized适用场景2、synchronized的原理3、synchronized的锁升级4、synchronized的注意事项5、总结synchronized是Java中用于实现线程同步的关键字。它可以在方法级别或代码块级别使用,以确保同一时刻只有一个线程可以访问被同步的代码段。synchronized通过内部锁机制来实现线程间的互斥访问synchronized关键字可以在方
echola_mendes
·
2024-08-26 14:13
Java并发编程
java
开发语言
Java笔试面试题之多线程常见考点总结
Java多线程面试题涵盖了Java多线程编程的多个重要方面,主要考察面试者对
Java并发编程
的理解和应用能力。
工程师老罗
·
2024-08-25 17:03
Java笔试面试题AI答
java
开发语言
Java并发编程
学习总结
关于并发并发在开发中广泛的应用,非常的重要,最近在读《
Java并发编程
的艺术》艺术,希望写一些东西来记录和巩固。上下文切换、死锁上下文切换频繁的上下文切换不仅不能加快程序的运行,还会降低程序的性能。
Aries_Li
·
2024-08-24 11:27
架构面试题汇总:并发和锁(2024版)
通过这些问题,可以展示自己对
Java并发编程
的深入理解和实践经验。请注意,并发编程是一个复
码到三十五
·
2024-08-22 06:33
面试攻关
架构
java
面试
Java并发编程
:深入剖析ThreadLocal
想必很多朋友对ThreadLocal并不陌生,今天我们就来一起探讨下ThreadLocal的使用方法和实现原理。首先,本文先谈一下对ThreadLocal的理解,然后根据ThreadLocal类的源码分析了其实现原理和使用需要注意的地方,最后给出了两个应用场景。以下是本文目录大纲:一.对ThreadLocal的理解二.深入解析ThreadLocal类三.ThreadLocal的应用场景若有不正之处
「已注销」
·
2024-08-22 04:21
多线程
并发
并发
多线程
【转】-
Java并发编程
:阻塞队列
Java并发编程
:阻塞队列该博客转载自**Matrix海子的
Java并发编程
:阻塞队列**
Java并发编程
:阻塞队列在前面几篇文章中,我们讨论了同步容器(Hashtable、Vector),也讨论了并发容器
booleandev
·
2024-08-21 19:19
JUC
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
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并发编程
实战读书总结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
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
开发语言
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
后端
上一页
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
其他