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并发
高频面试题
内容摘自我的学习网站:topjavaer.cn分享50道
Java并发
高频面试题。线程池线程池:一个管理线程的池子。为什么平时都是使用线程池创建线程,直接new一个线程不好吗?
·
2023-08-15 16:19
后端java
Java并发
编程:CAS和AQS
一、什么是CASCAS(CompareAndSwap),即比较并交换。是解决多线程并行情况下使用锁造成性能损耗的一种机制,CAS操作包含三个操作数————内存位置(V)、预期原值(A)和新值(B)。如果内存位置的值与预期原值相匹配,那么处理器会自动将该位置值更新为新值。否则,处理器不做任何操作。无论哪种情况,它都会在CAS指令之前返回该位置的值。CAS有效地说明了“我认为位置V应该包含值A;如果包
程序员116号
·
2023-08-15 11:43
Java并发
之ReentrantLock
AQSAQS(AbstractQueuedSynchronizer):抽象队列同步器,是一种用来构建锁和同步器的框架。在是JUC下一个重要的并发类,例如:ReentrantLock、Semaphore、CountDownLatch、LimitLatch等并发都是由AQS衍生出来的。理解CLH队列是一种基于链表的可扩展,高性能,公平的自旋锁。它的队列中每个节点等待前驱节点释放锁,当前置节点执行完成,
qq_27502511
·
2023-08-15 05:21
java
开发语言
Java 并发编程与CAS基本原理
一、
Java并发
基础知识Java里的程序天生就是多线程的,那么有几种新启线程的方式?
sziitjin
·
2023-08-15 05:19
java
android
java
开发语言
Java并发
编程之验证volatile指令重排-理论篇
Java并发
编程之验证volatile指令重排-理论篇
Java并发
包下的类中大量使用了volatile关键字。
凯哥Java
·
2023-08-15 04:06
Java并发
编程的艺术_Conc
Java并发
编程的艺术1并发编程的挑战1.1上下文切换即使是单核处理器也支持多线程执行代码,CPU通过给每个线程分配CPU时间片来实现这个机制。
silverbo1
·
2023-08-14 23:54
java并发编程的艺术
java
并发编程
编程之道
:构建优雅可维护代码的基石
编程世界犹如一座庞大的建筑群,而代码构建块则是这座建筑的基石。类比于建筑学中的基础构件,代码构建块是软件开发过程中不可或缺的元素。本文将深入探讨代码构建块的概念以及其在编写高质量代码方面的重要性。什么是代码构建块?在软件开发中,代码构建块是指将代码分解成可管理的、独立的小块的做法。这种方法类似于将一个大问题分解成更小的子问题,然后逐个解决它们。这些小块可以是函数、方法、类、模块等,它们通常负责执行
fans小知
·
2023-08-14 23:22
编程之道
代码规范
34张架构史上最全技术知识图谱
1.2Java架构师图谱1.3微服务架构秘籍1.4一致性图谱1.5互联网大流量的方法1.6安全秘籍1.7阿里巴巴常用小框架1.8架构方法论图谱1.9设计模式秘籍图谱22.1JVM虚拟机垃圾回收图谱2.2
Java
程序员BUG
·
2023-08-14 18:23
【死磕
Java并发
】-----深入分析synchronized的实现原理
记得刚刚开始学习Java的时候,一遇到多线程情况就是synchronized,相对于当时的我们来说synchronized是这么的神奇而又强大,那个时候我们赋予它一个名字“同步”,也成为了我们解决多线程情况的百试不爽的良药。但是,随着我们学习的进行我们知道synchronized是一个重量级锁,相对于Lock,它会显得那么笨重,以至于我们认为它不是那么的高效而慢慢摒弃它。诚然,随着JavsSE1.
Zal哥哥
·
2023-08-13 22:20
JUC线程池的实战问题 - 线程池参数应该如何配置?
在《
Java并发
编程实战》一书中,作者BrianGoetz等人指出,线程池的规模应该根据任务类型和计算密集度来确定,对于CPU密集型任务,应该将核心线程数设置为处理器核心数加1或者2;对于I/
@Autowire
·
2023-08-13 14:08
JUC面试题汇总
java
分布式定时任务系列5:XXL-job中blockingQueue的应用
传送门分布式定时任务系列1:XXL-job安装分布式定时任务系列2:XXL-job使用分布式定时任务系列3:任务执行引擎设计分布式定时任务系列4:任务执行引擎设计续
Java并发
编程实战1:java中的阻塞队列引子这篇文章的主要目不是讨论
kobe_t
·
2023-08-13 06:39
#
分布式调度
java
Java并发
编程(四)线程同步 中 [AQS/Lock]
概述Java中可以通过加锁,来保证多个线程访问某一个公共资源时,资源的访问安全性。Java提出了两种方式来加锁第一种是我们上文提到的通过关键字synchronized加锁,synchronized底层托管给JVM执行的,并且在java1.6以后做了很多优化(偏向锁、自旋、轻量级锁),使用很方便且性能也很好,所以在非必要的情况下,建议使用synchronized做同步操作;第二种是本文将要介绍的通过
奉先节度使
·
2023-08-12 23:33
#
Java
java
Java并发
编程(一)多线程基础概念
概述多线程技术:基于软件或者硬件实现多个线程并发执行的技术线程可以理解为轻量级进程,切换开销远远小于进程在多核CPU的计算机下,使用多线程可以更好的利用计算机资源从而提高计算机利用率和效率来应对现如今的高并发网络环境并发编程核心三要素原子性原子,即一个不可再被分割的颗粒。在Java中原子性指的是一个或多个操作要么全部执行成功要么全部执行失败有序性程序执行的顺序按照代码的先后顺序执行。(处理器可能会
奉先节度使
·
2023-08-12 23:03
#
Java
java
Java并发
编程(二)并发理论[JMM/重排序/内存屏障/Happens-Before 规则]
JMM(Java内存模型)概述JMM即Java内存模型(JavaMemoryModel),是一种抽象的概念,并不真实存在,JMM描述的是一组规则或规范,通过这组规范定义了程序中各个变量的访问方式Java内存模型中规定所有变量都存储在主内存,主内存是共享内存区域,所有线程都可以访问,但线程对变量的操作必须在工作内存中进行,所以首先要将变量从主内存拷贝的自己的工作内存空间,然后对变量进行操作,操作完成
奉先节度使
·
2023-08-12 23:03
#
Java
java
Java并发
编程(三)线程同步 上[synchronized/volatile]
概念当使用多个线程来访问同一个数据时,将会导致数据不准确,相互之间产生冲突,非常容易出现线程安全问题,比如多个线程都在操作同一数据,都打算修改商品库存,这样就会导致数据不一致的问题。所以我们通过线程同步机制来保证线程安全,加入同步锁以避免在该线程没有完成操作之前,被其他线程的调用,从而保证了该变量的唯一性和准确性。线程同步本质就是“排队“,多个线程之间要排队,然后一个一个对共享资源进行操作,而不是
奉先节度使
·
2023-08-12 23:30
#
Java
java
Java并发
编程:Callable、Future和FutureTask
在前面的文章中我们讲述了创建线程的2种方式,一种是直接继承Thread,另外一种就是实现Runnable接口。这2种方式都有一个缺陷就是:在执行完任务之后无法获取执行结果。如果需要获取执行结果,就必须通过共享变量或者使用线程通信的方式来达到效果,这样使用起来就比较麻烦。而自从Java1.5开始,就提供了Callable和Future,通过它们可以在任务执行完毕之后得到任务执行结果。今天我们就来讨论
小小哭包
·
2023-08-12 23:40
开发技巧经验分享
java
开发语言
Java并发
之ReentrantLock
一、什么是AQS?AQS是AbstractQueuedSynchronizer的简称,AQS提供了一种实现阻塞锁和一系列依赖FIFO等待队列的同步器的框架。AQS实现了等待队列、条件队列、独占或共享锁的获取。而在Java中也提供了许多基于AQS实现的锁:基于AQS实现的锁1.1AQS的特性阻塞的等待队列共享或独占公平或非公平可重入允许中断1.2AQS内部信息AQS中是基于一个volatile修饰的
枫叶红花
·
2023-08-12 11:02
java并发
执行代码获取数据库数据
importjava.util.concurrent.Callable;importjava.util.concurrent.ExecutionException;importjava.util.concurrent.ExecutorService;importjava.util.concurrent.Future;/***并发工具类**@authorhuayal*@since2022-12-22
huayal
·
2023-08-12 09:44
java
开发语言
什么是
Java并发
?怎么解决?
Java存在并发的原因是,当多个线程在同时访问共享资源(如内存中的变量)时,可能会导致线程安全问题。如果一个线程在更改共享资源的值,而另一个线程在读取该值,则可能会导致意外的结果。解决并发问题的方法有以下几种:使用synchronized关键字:可以使用synchronized关键字保护共享资源,以保证一次只有一个线程访问它。使用Lock对象:可以使用java.util.concurrent包中的
长征coder
·
2023-08-12 07:35
java
并发
java并发
-Condition接口
Condition的简单使用使用Condition实现的有界队列publicclassBoundedQueue{privateObject[]items;privateintaddIndex,removeIndex,count;privateLocklock=newReentrantLock();privateConditionnotFull=lock.newCondition();private
油多坏不了菜
·
2023-08-12 05:52
Java并发
机制的底层实现原理
一、前置知识缓存一致性协议:每个处理器通过嗅探在总线上传播的数据来检查自己缓存的值是不是过期了,当处理器发现自己缓存行对应的内存地址被修改,就会将当前处理器的缓存行设置成无效状态,当处理器对这个数据进行修改操作的时候,会重新从系统内存中把数据读理器缓存里。内存屏障:现代计算机为了提高效率,当前线程在分配的时间片下不够用时,在能保证结果不会改变的时候,将后边执行时间短的命令提前执行。内存屏障是为了在
呆猫不呆
·
2023-08-12 05:37
并发编程
java
开发语言
5. Java中的锁
本文将介绍
Java并发
包中与锁相关的API和组件,以及这些API和组件的使用方式和实现细节1.Lock接口锁是用来控制多个线程访问共享资源的方式,像独占锁,读写锁在Lock接口出现之前,java程序考synchronized
ygxing
·
2023-08-11 23:50
26.Netty源码之ThreadLocal
ThreadLocal可以理解为线程本地变量,它是
Java并发
编程中非常重要的一个类。
然而,然而
·
2023-08-11 15:22
.net
python
开发语言
Java并发
线程池原理解析
线程1.概述线程是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。2.生命周期:当线程被创建并启动以后,它既不是一启动就进入了执行状态,也不是一直处于执行状态。在线程的生命周期中,它要经过新建(New)、就绪(Runnable)、运行(Running)、阻塞(Block
愉悦滴帮主)
·
2023-08-11 14:09
并发编程
java
线程池
【
Java并发
】什么是AQS?
文章目录什么是AQS?AQS与Synchronized的区别AQS-基本工作机制AQS是公平锁与非公平锁什么是AQS?全称是AbstractQueuedSynchronizer,即抽象队列同步器。它是构建锁或者其他同步组件的基础框架所谓抽象,其实目的就是把具体的逻辑交给子类去实现,这样就可以实现不同的特性的锁:例如:AQS常见的实现类ReentrantLock阻塞式锁Semaphore信号量Cou
怎么还不写代码
·
2023-08-11 12:59
Java
java
开发语言
jvm
【
Java并发
】ReentrantLock的实现原理
文章目录ReentrantLock是什么?ReentrantLock底层源码:ReentrantLock底层原理图解:(以NonfairSync举例)ReentrantLock是什么?synchronized关键字是一种隐式锁,即它的加锁与释放是自动的,无需我们关心。而ReentrantLock是一种显式锁,需要我们手动编写加锁和释放锁的代码。相对于synchronized它具备以下特点:可中断可
怎么还不写代码
·
2023-08-11 12:59
Java
java
开发语言
【
Java并发
】如何进行死锁诊断?
文章目录1.什么是死锁2.死锁怎么产生的3.如何进行死锁诊断?3.1通过命令查看3.2jconsole可视化工具3.2VisualVM:故障处理工具1.什么是死锁死锁(Deadlock)是指两个或多个进程(线程)在执行过程中,由于竞争资源而陷入无限等待的状态,导致它们都无法继续执行下去。简单来说,就是一种互相等待对方释放资源的情况,从而造成所有参与者都无法继续执行的僵局。2.死锁怎么产生的产生的四
怎么还不写代码
·
2023-08-11 12:57
Java
java
开发语言
AbstractQueuedSynchronizer 队列同步器源码分析
(摘自《
Java并发
编程的艺术》)我们知道获取同步状态有独占和共享两种模式,本文先针对独占模式进行分析。变量定义privatetransientvolatileNodehead;head
断风雨_2669
·
2023-08-11 06:23
线程池的getPoolSize()方法只增不减?
在《
Java并发
编程的艺术》第九章9.2.5节中,对线程池的参数监控方法有以下描述:getPoolSize:线程池的线程数量。如果线程池不销毁的话,线程池里的线程不会自动销毁,所以这个大小只增不减。
Divenier
·
2023-08-11 02:02
Java并发
常见知识点
此页内容JMM(Java内存模型)volatile关键字如何保证变量的可见性?如何禁止指令重排序?volatile可以保证原子性么?乐观锁和悲观锁什么是悲观锁?什么是乐观锁?如何实现乐观锁?乐观锁存在哪些问题?synchronized关键字synchronized是什么?有什么用?如何使用synchronized?构造方法可以用synchronized修饰么?synchronized底层原理了解吗
其然乐衣
·
2023-08-10 14:37
juc
java
juc
Java并发
—Join使用及原理
一、理解阅读JDKJoin方法注释如下:Waitsforthisthreadtodie.//等待该线程死亡所以其作用是等待该线程死亡。简单理解就是,调用该方法的线程阻塞,直到被调用Join的线程死亡。我们回忆一下,线程的5种状态,如下:NEW:新建RUNNABLE:运行中BLOCKED:阻塞。等待锁,通常是通过synchronizeWAITING:等待。通常是调用Object.wait(),Thr
v2hoping
·
2023-08-10 13:27
Java
Java后端技术
【
Java并发
编程】再现ABA问题与解决ABA问题
文章目录1.什么是ABA问题2.如何解决ABA问题1.什么是ABA问题如果另一个线程把值A,先修改为B,再修改为A。当前线程看到的值还是A,并不知道值中间是否发生过变化。这就是ABA问题。举个:在你非常渴的情况下你发现一个盛满水的杯子,你一饮而尽。之后再给杯子里重新倒满水。然后你离开,当杯子的真正主人回来时看到杯子还是盛满水,他当然不知道是否被人喝完重新倒满。我们考虑下面一种ABA的情况:在多线程
Fire Fish
·
2023-08-10 06:33
java
java
开发语言
【
Java并发
编程】使用CompletableFuture最佳实践
文章目录1.什么是CompletableFuture2.为什么需要CompletableFuture3.使用CompletableFuture创建类接续类(thenXxx)4.使用CompletableFuture的一般范式CompletableFuture是Future的增强版,是多线程开发的利器。本文通俗易懂的介绍了CompletableFuture的用法,最后祭出CompletableFut
Fire Fish
·
2023-08-10 05:56
java
java
Java并发
---ForkJoin框架
介绍JDK1.7后,标准类库添加了ForkJoinPool,作为对Fork/Join型线程池的实现。Fork&Join的作用:Fork将大型任务递归拆分成多个小型任务,然后让小任务执行,Join则会等待获得小任务的结果,然后进行合并,将合并的结果作为大任务的结果。这使用的则是分治思想实现的,只是这些子任务都可以并行执行。Fork&JoinForkJoin的任务ForkJoin中的任务主要分为两个:
None_Ling
·
2023-08-10 01:59
java并发
之CyclicBarrier
java并发
之CyclicBarrier知识导读CyclicBarrier是一个阻塞器,当阻塞线程达到CyclicBarrier指定数量时,所有线程被唤醒执行,否则阻塞该线程CyclicBarrier可以循环使用
九戒k
·
2023-08-09 20:18
【连载】第3章-3.1.2-4可见性(long在多线程下不具有原子性)
《
JAVA并发
编程实战》解读【连载】第3章-3.1.2-4可见性回顾:上一节聊了共享变量,如果多线程共有,可能会导致失效的风险,增加synchronized保护后,可以避免风险的发生,这一节聊一聊可见性的其他问题和解决方式
可爱猪猪
·
2023-08-09 13:14
探索泛型与数据结构:解锁高效
编程之道
文章目录引言第一部分:了解泛型1.1为什么使用泛型1.2使用泛型的好处第二部分:泛型的使用场景2.1类的泛型2.2方法的泛型2.3接口的泛型第三部分:泛型通配符3.1通配符3.2通配符的受限泛型第四部分:数据结构和泛型的应用4.1常见的数据结构4.2泛型在ArrayList中的应用4.3红黑树的约束4.4List集合的常用方法结语引言在当今信息爆炸的时代,数据结构和算法成为了程序员必备的核心技能。
IT·陈寒
·
2023-08-09 10:28
Java学习路线
数据结构
java
开发语言
Java并发
之原子变量及CAS算法-下篇
Java并发
之原子变量及CAS算法-下篇概述本文主要讲在
Java并发
编程的时候,如果保证变量的原子性,在JDK提供的类中式怎么保证变量原子性的呢?。
凯哥Java
·
2023-08-09 08:06
Java并发
编程之顺序一致性
如果程序是正确同步的,程序的执行将具有顺序一致性(SequentiallyConsistent)——即程序的执行结果与该程序在顺序一致性内存模型中的执行结果相同。同步,即排队。同一时刻,只能有一个线程和内存交互!!顺序一致性内存模型两大特性一个线程中的所有操作必须按照程序的顺序来执行。(不管程序是否同步)所有线程都只能看到一个单一的操作执行顺序。在顺序一致性内存模型中,每个操作都必须原子执行且立刻
yYahoo~
·
2023-08-09 02:45
并发编程
Java
java
GO语言基础语法探究:简洁高效的
编程之道
文章目录前言Go词法单元token标识符关键字(25个)内置数据类型标识符(20个)内置函数(15个)常量值标识符(4个)空白标识符(1个)操作符和分隔符字面常量变量和常量变量常量基本数据类型布尔类型整型浮点型复数类型字符串rune类型复合数据类型指针数组数组初始化数组的特点数组相关操作切片切片的创建切片支持的操作字符串和切片的相关转换mapmap的创建map支持的操作structstruct类型
全栈ing小甘
·
2023-08-09 02:06
GO语言
golang
go基础语法
go
java并发
中批量任务的同步和管理
ExecutorServiceExecutorService是
Java并发
库中的一个接口,它提供了一种管理和控制线程池的方式,用于执行和管理多个异步任务。
FLGB
·
2023-08-08 22:40
java基础
java并发编程
java
开发语言
java并发
ForkJoinPool
ForkJoinPoolFork/Join框架是
Java并发
库中用于实现分治任务并行处理的工具。
FLGB
·
2023-08-08 22:40
java并发编程
java基础
java
开发语言
java并发
下如何使用SimpleDateFormat 和Random
1、SimpleDateFormat类1、SimpleDateFormat的错误使用@Slf4jpublicclassDateUtil{privatefinalstaticDateTimeFormatteryymmddhhmmss=DateTimeFormatter.ofPattern("yyyy-MM-ddHH:mm:ss");privatefinalstaticDateTimeFormatte
FLGB
·
2023-08-08 22:39
java基础
java
开发语言
java并发
中的同步器
同步器
Java并发
包中的同步器是一些用于协调多个线程执行的工具,用于实现线程之间的同步和互斥操作。这些同步器提供了不同的机制来控制线程的访问和执行顺序,以实现线程安全和并发控制。
FLGB
·
2023-08-08 22:08
java并发编程
java基础
java
python
开发语言
并发——线程的生命周期和状态
文章目录Java线程在运行的生命周期中的指定时刻只可能处于下面6种不同状态的其中一个状态(图源《
Java并发
编程艺术》4.1.4节)。
挨打且不服66
·
2023-08-08 15:16
java笔记整理
java
Java 编程之美:并发编程高级篇,必须码住了!
前言借用
Java并发
编程实践中的话:编写正确的程序并不容易,而编写正常的并发程序就更难了。
Java喵
·
2023-08-08 09:58
Java并发
总结
1.创建线程三种方式Runnable.Callable接口使用继承Thread类的方式创建多线程Runnable和Callable区别Callable规定(重写)的方法是call(),Runnable规定(重写)的方法是run()。Callable的任务执行后可返回值,而Runnable的任务是不能返回值的。Call方法可以抛出异常,run方法不可以。运行Callable任务可以拿到一个Futur
zhendeWD
·
2023-08-08 05:02
#
java并发编程
java
开发语言
Java并发
编程实战
线程安全性一个对象是否线程安全,取决于它是否被多个线程访问Java的同步机制关键字是synchronized,它提供了一种独占的加锁方式,但“同步”这个术语还包括volatile类型的变量,显式锁以及原子变量由于不恰当的执行时序而出现不正确的结果这种情况成为:静态条件(racecondition,这里的condition翻译成情况更合适)大多数竞态条件的本质:基于一种可能失效的观察结果做出判断或者
官大航
·
2023-08-08 01:18
一文搞懂Go语言并发【goroutine】
文章目录前言一、基本概念①并发、并行区分1.概念2.图解②从用户态线程,内核态线程阐述go与
java并发
的优劣1.用户态线程、内核态线程差异:2.java与go并发差异:②高并发为什么是Go语言强项?
酷尔。
·
2023-08-07 23:01
Go语言从入门到精通
golang
java
开发语言
Java并发
编程:什么是CAS?这回总算知道了
无锁的思想众所周知,Java中对并发控制的最常见方法就是锁,锁能保证同一时刻只能有一个线程访问临界区的资源,从而实现线程安全。然而,锁虽然有效,但采用的是一种悲观的策略。它假设每一次对临界区资源的访问都会发生冲突,当有一个线程访问资源,其他线程就必须等待,所以锁是会阻塞线程执行的。当然,凡事都有两面,有悲观就会有乐观。而无锁就是一种乐观的策略,它假设线程对资源的访问是没有冲突的,同时所有的线程执行
鄙人薛某
·
2023-08-07 23:32
上一页
19
20
21
22
23
24
25
26
下一页
按字母分类:
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
其他