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并发
面试问题之公平锁与非公平锁是啥?
一、写在前面上篇文章(《大白话聊聊
Java并发
面试问题之谈谈你对AQS的理解?》)聊了一下
java并发
包中的AQS的工作原理,也间接说明了ReentrantLock的工作原理。
Anchor M
·
2023-10-31 17:02
java
锁
面试题
并发
编程之美
线程基础文章目录线程基础创建线程以及运行继承Thread类实现Runnable接口实现Callable接口线程的通知和等待wait()函数notify()和notifyAll()函数等待线程执行终止的join()函数使线程睡眠的sleep()函数使CPU让出执行权的yield()函数线程中断线程的上下文切换线程死锁守护线程和用户线程ThreadLocal实现原理key为弱引用重点多线程并发编程并发
今天学不学?
·
2023-10-31 13:15
线程
线程
别再问什么是Java内存模型了!!
网上有很多关于Java内存模型的文章,在《深入理解Java虚拟机》和《
Java并发
编程的艺术》等书中也都有关于这个知识点的介绍。但是,很多人读完之后还是搞不清楚,甚至有的人说自己更懵了。
扑棱扑棱yo
·
2023-10-31 08:39
java
内存结构
优秀程序员修炼手册,Offer拿不停,JVM+
Java并发
+Java集合+Spring全家桶+Redis+中间件+分布式+数据库
作为一名优秀的程序员,技术面试都是不可避免的一个环节,一般技术面试官都会通过自己的方式去考察程序员的技术功底与基础理论知识。如果你参加过一些面试,肯定会遇到一些这样的问题:1、看你项目都用的框架,熟悉Spring、mybatis等框架实现原理吗?2、看你上面有接触过消息中间件,负载均衡、RPC框架等技术吗,MySQL分库分表有做过吗?3、分布式架构设计,Redis分布式锁呢?是不是看上去很难,是不
SpringBoot_
·
2023-10-31 06:42
Java
架构师
面试
分布式
数据库
spring
java
编程语言
Java并发
编程实战
第一章编写线程安全的代码,本质上就是管理对状态(state)的访问,通常是共享的、可变的状态。--所以不变的状态在多线程里可以用final修饰只要有一个以上的线程访问给定状态的变量,并且其中某个线程会写入该变量,就必须用同步来协调对该变量的访问。---所以没有写只有读就可以随便修复线程不安全性:3.1不要用多线程访问同一个变量3.2使变量不可变3.3使用同步关键字修饰无状态对象永远是线程安全的。-
心疼我这个废物
·
2023-10-31 00:04
并行和并发有什么区别?
并行和并发并行和并发最早其实描述的是
Java并发
编程里面的概念。他们强调的是CPU处理任务的能力。简单来说:并发,就是同一个时刻,CPU能够处理的任务数量,并且对于应用程序来说,不会出现卡顿现象。
无语堵上西楼
·
2023-10-30 21:04
java面试题
java
开发语言
java源码系列之初识ConcurrentHashMap(JDK1.8)
ConcurrentHashMap是在
java并发
包(java.util.concurrent)下的一个类,在
爱偷懒的程序源
·
2023-10-30 20:54
基础
java
java
并发容器
Java中的锁升级
Java中锁升级的过程首先先看一下《
Java并发
编程的艺术》中的一段话,也是对整个锁升级过程的一个总结和描述。
既然头发留不住
·
2023-10-30 18:12
多线程
java
多线程
Java并发
编程:锁
1.Lock从JDK5.0开始,Java提供了更强大的线程同步机制——通过显式定义同步锁对象来实现同步。同步锁使用Lock对象充当。java.util.concurrent.locks.Lock接口是控制多个线程对共享资源进行访问的工具。锁提供了对共享资源的独占访问,每次只能有一个线程对Lock对象加锁,线程开始访问共享资源之前应先获得Lock对象。ReentrantLock类实现了Lock,它拥
coder1qiang
·
2023-10-30 18:35
Java并发编程
并发编程
多线程
java
原子类:
Java并发
编程的利器
在多线程环境下,确保数据的一致性和原子性是至关重要的。Java提供了一些原子类,用于解决多线程并发问题。这些原子类能够确保操作在多线程环境下是原子的,即不会被其他线程干扰。本文将介绍Java中的原子类及其应用。一、原子类概述原子类是Java提供的一组实现原子操作的类,包括AtomicInteger、AtomicLong、AtomicBoolean等。这些类中的每个方法都是原子的,这意味着它们在并发
佩奇的胖爸爸
·
2023-10-30 18:03
java
数据库
开发语言
一文带你 API 网关从入门到放弃
源码解析数据库中间件Sharding-JDBC和MyCAT源码解析作业调度中间件Elastic-Job源码解析分布式事务中间件TCC-Transaction源码解析Eureka和Hystrix源码解析
Java
公众号-芋道源码
·
2023-10-30 13:21
【并发编程十一:CopyOnWriteMap 和 CopyOnWriteArraySet】
CompletableFuture的应用】一、介绍CopyOnWriteMap是org.apache.kafka.common.utils中个类,CopyOnWriteArraySet与CopyOnWriteArrayList是
Java
北城小林
·
2023-10-30 12:25
07_并发编程专题
java
由一个单例模式引发的思考-holder类方式
前言:最近在看《
Java并发
编程实践》,里面提到了一种实现单例模式的方式,并大致说明了机制,但仍不是很清晰,今日有空,查阅相关书籍,尝试解释其中道理。
不随意的风
·
2023-10-30 12:31
JVM
设计模式
单例模式
java
jvm
Java并发
——Netty线程模型
BIO1.BIO即阻塞式IO,使用BIO模型,一般会为每个Socket分配一个独立的线程为了避免频繁创建和销毁线程,可以采用线程池,但Socket和线程之间的对应关系不会发生变化2.BIO适用于Socket连接不是很多的场景,但现在上百万的连接是很常见的,而创建上百万个线程是不现实的因此BIO线程模型无法解决百万连接的问题3.在互联网场景中,连接虽然很多,但每个连接上的请求并不频繁,因此线程大部分
Java_苏先生
·
2023-10-30 11:47
[
Java并发
]-----第4章
Java并发
包中原子操作类原理剖析
JUC包(java.util.concurrent)提供了一系列原子性操作类,这些类都是使用非阻塞算法CAS实现的,相比使用锁实现原子性操作在性能上有很大提高.1.原子变量操作类JUC并发包包含有AtomicInteger,AtomicLong,AtomicBoolean等原子性操作类,原理都是CAS算法.一下都是以AtomicLong类为例.(1).递增和递减操作//自增,然后获取值public
Benjamin_Lee
·
2023-10-30 11:59
分布式锁实践指南:Redis篇
目前越来越多的应用使用负载均衡,以往传统单体应用单机部署的情况下使用的
JAVA并发
处理资源竞争方式(J.U.C或synchronized等)在集群部署中已经无法保证资源的安全访问。
DawnOfTan
·
2023-10-30 07:10
【原创】腾讯面试官:线程池要设置多大
Hunter心想,这不难啊,曾经在《
Java并发
编程》一书中有看到过线程池中线程数目设置的讲述,于是张
Dali王
·
2023-10-30 05:33
谈谈AQS加锁、释放锁、等待队列
解释:关系大了去了,因为
Java并发
包下很多API都是基于AQS来实现加锁和释放锁的功能的,AQS是
Java并发
包的基础类。R
徐大叔学JAVA
·
2023-10-30 00:52
Java
java
CountDownLatch、CyclicBarrier、Semaphore、Exchanger 的详细解析
本文主要介绍和对比我们常用的几种并发工具类,主要涉及CountDownLatch、CyclicBarrier、Semaphore、Exchanger相关的内容,如果对多线程相关内容不熟悉,可以看笔者之前的一些文章:《
Java
AnonyStar
·
2023-10-29 23:40
ETCD 分布式锁
概述在传统单体应用单机部署的情况下,可以使用
Java并发
处理相关的API(如ReentrantLock或Synchronized)进行互斥控制。在单机环境中,Java中提供了很多并发处理相关的API。
程序员札记
·
2023-10-29 16:06
Java并发
编程学习笔记
Java并发
编程学习笔记CPU多级缓存模型计算机为什么要设计高速缓存架构CPU与主存运行速度的差异CPU长时间空闲引入高速缓存,减少CPU等待时间,提升运行效率多核CPU的多级缓存架构是怎么样的多核CPU
NewBee.Mu
·
2023-10-29 13:27
从头开始学java
知识点总结
java
java
九、【Java 并发】锁的概述
乐观锁&悲观锁乐观锁和悲观锁是在数据库中引入的名词,但是在
Java并发
包锁里面也引入了类似的思想。
deve_雨轩
·
2023-10-29 10:59
Java高并发编程学习(三)java.util.concurrent包
简介我们已经学习了形成
Java并发
程序设计基础的底层构建块,但对于实际编程来说,应该尽可能远离底层结构。使用由并发处理的专业人士实现的较高层次的结构要方便得多、要安全得多。
小夏陌
·
2023-10-29 10:49
Java开发
java
并发编程
多线程
Java并发
类库提供的线程池有哪几种?
既然创建或销毁线程存在一定的开销,所以利用线程池技术来提高系统资源利用效率,并简化线程管理,已经是非常成熟的选择。典型回答通常开发者都是利用Executors提供的通用线程池创建方法,去创建不同配置的线程池,主要区别在于不同的ExecutorService类型或者不同的初始参数。Executors目前提供了5种不同的线程池创建配置:newCachedThreadPool(),它是一种用来处理大量短
wiseph
·
2023-10-29 05:25
Java编程面试
Java并发
类库提供的线程池有哪几种? 分别有什么特点?
Java并发
类库提供的线程池有哪几种?分别有什么特点?
IT枫斗者
·
2023-10-29 04:22
面试技巧
java
开发语言
maven
eclipse
数据库
Java并发
编程指南:如何正确使用信号量和线程池熔断机制
前言:在分布式系统中,选择合适的熔断机制是保护系统免受故障影响的关键。本文将介绍使用信号量和线程池两种常见的熔断机制,并提供Java和SpringCloudAlibaba框架下的示例代码,帮助您深入理解和应用。1.信号量熔断机制信号量熔断机制基于并发请求的数量进行熔断,可限制系统的并发访问量。它适用于资源有限且对请求响应时间要求较高的场景。下面是使用Java和SpringCloudAlibaba框
热心码民阿振
·
2023-10-29 02:59
Java
java
开发语言
spring
cloud
分布式
【
java并发
系列】Controller是线程安全吗_ 安全方式如何
大家好,我是walker一个从文科自学转行的程序员~爱好编程,偶尔写写编程文章和生活欢迎关注公众号【IamWalker】,回复“电子书”,就可以获得200多本编程相关电子书哈~我的gitee:https://gitee.com/shen-chuhao/walker.git里面很多技术案例!controller是线程不安全的,因为controller使用的是单例模式,不同的线程会对数据进行共享,导致
WalkerShen
·
2023-10-28 20:46
java并发
java
《
Java并发
编程实战》机械工业出版社 童云兰译 PDF下载(Java Concurrency in Practice中文版)
下载地址:http://www.ishare1.cn/archives/813.html《
Java并发
编程实战》机械工业出版社童云兰译PDF电子书下载(JavaConcurrencyinPractice
sunjian286
·
2023-10-28 19:26
大厂面试题-
Java并发
编程基础篇(五)
目录一、为什么ConcurrentHashMap中key不允许为null考察目标问题解析回答二、ThreadLocal会出现内存泄漏吗?考察目的问题解析回答三、什么是CompletableFuture?问题分析问题解答四、什么条件下会产出死锁,如何避免死锁?1、什么是死锁?2、产生死锁的原因3、如何避免死锁?五、ConcurrentHashMap是如何保证线程安全的?1、JDK1.7实现原理2、J
似来
·
2023-10-28 16:40
面试题
java
数据结构
开发语言
java并发
关键字:volatile深入浅出:可见性、防止指令重排
文章目录一.volatile的作用1.防止重排序2.变量修改的可见性3.保证单次的读/写的原子性二.volatile的实现原理1.可见性的实现2.有序性的实现2.1.volatile的happens-before关系2.2.volatile禁止重排序三.volatile的应用场景1.双重检查(double-checked)2.独立观察(independentobservation)3.开销较低的读
roman_日积跬步-终至千里
·
2023-10-28 14:20
java并发
java
开发语言
java并发
怎么控制资源
以下是一些用于控制资源的主要
Java并发
机制:Synchronized关键字:使用synchronized关键字可以控制对共享资源的访问。
mywaya2333
·
2023-10-28 12:48
java
开发语言
Java并发
编程解析 | 基于JDK源码解析Java领域中并发锁之StampedLock锁的设计思想与实现原理 (三)
苍穹之边,浩瀚之挚,眰恦之美;悟心悟性,善始善终,惟善惟道!——朝槿《朝槿兮年说》写在开头在并发编程领域,有两大核心问题:一个是互斥,即同一时刻只允许一个线程访问共享资源;另一个是同步,即线程之间如何通信、协作。主要原因是,对于多线程实现实现并发,一直以来,多线程都存在2个问题:线程之间内存共享,需要通过加锁进行控制,但是加锁会导致性能下降,同时复杂的加锁机制也会增加编程编码难度过多线程造成线程之
朝槿木兮
·
2023-10-28 05:38
mybatis 连接池探究
起因是目前再看《
Java并发
编程的艺术》并发基础那章实现了一个简单的连接池,虽然只是为了展示等待/通知,但是我对平时常用的mybatis的连接池是怎么实现的感到很好奇,所以就有了这次的记录。
上重楼
·
2023-10-28 02:54
《
Java并发
编程之美
》学习笔记
成功上岸,进入华为,之前花5W买的JAVA课程合集,整整420集,拿走不谢,公粮上交,手把手教学,学完即可就业_哔哩哔哩_bilibili1.并发编程基础1.1什么是线程线程是进程中的一个实体,线程本身是不会独立存在的。进程是代码在数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,线程则是进程的一个执行路径,一个进程中至少有一个线程,进程中的多个线程共享进程的资源操作系统在分配资源时是
jmysql
·
2023-10-28 01:18
java
学习
大数据
《
Java并发
编程之美
》笔记
Java并发
编程之美
阅读开源框架的一点心得为什么要看源码由经验不足导致的问题不知道如何去设计,就看当前系统类似需求的设计,然后去仿照设计的时候,考虑不周全工作经验的积累来自于年限与实践,看源码可以扩展思路可以解决经验不足的办法通过学习开源框架
老干妈炒饭
·
2023-10-27 23:40
Java并发
指南16:JUC中常用的Unsafe和Locksupport
说一说Java的Unsafe类最近在看
Java并发
包的源码,发现了神奇的Unsafe类,仔细研究了一下,在这里跟大家分享一下。Unsafe类是在sun.misc包下,不属于Java标准。
weixin_34198797
·
2023-10-27 14:48
java
运维
大数据
Java并发
编程之深入理解线程池原理及实现
如果需要先行了解
Java并发
编程的基础知识,可参考以下随
weixin_34132768
·
2023-10-27 14:47
java
设计模式
数据结构与算法
深入理解wait()、notify()和notifyAll()方法为什么属于Object,为什么要在synchronized代码块中
关于synchronized的详细介绍请移步大神所写的博客:深入理解
Java并发
之synchronized实现原理,这篇文档稍微有点长,我会用自己的话总结一下关于wait()、notify()和notifyAll
goodluckwj
·
2023-10-27 13:26
java并发
synchronized
wait()
Object
Java并发
编程40道面试题及答案——面试稳了
1、线程与进程的区别?进程是操作系统分配资源的最小单元,线程是操作系统调度的最小单元。一个程序至少有一个进程,一个进程至少有一个线程。文末有福利,思维导图和视频资料等你来领2、什么是多线程中的上下文切换?多线程会共同使用一组计算机上的CPU,而线程数大于给程序分配的CPU数量时,为了让各个线程都有执行的机会,就需要轮转使用CPU。不同的线程切换使用CPU发生的切换数据等就是上下文切换。3、死锁与活
Java黎先生
·
2023-10-27 09:21
讲真,我发现这本书有个地方写错了!
可恶的标题党首先,我先说一下我发现的《
Java并发
编程的艺术》写错的地方吧。我手上这本《
Java并发
编程的艺术》的版次是:2019年3月第1版第14次印刷。
why技术
·
2023-10-27 03:32
java技术
面试题
【JAVA】:万字长篇带你了解
JAVA并发
编程【二】
目录【JAVA】:万字长篇带你了解
JAVA并发
编程【二】3.线程池池化技术线程池的概念与作用什么是线程池?
无难事者若执
·
2023-10-27 03:30
Java开发知识
java
多线程
并发
RESTful 架构基础
源码解析数据库中间件Sharding-JDBC和MyCAT源码解析作业调度中间件Elastic-Job源码解析分布式事务中间件TCC-Transaction源码解析Eureka和Hystrix源码解析
Java
芋道源码
·
2023-10-26 23:22
一文总结
Java并发
中的锁
一、锁的类型1.自旋锁自旋锁是计算机科学用于多线程同步的一种锁,线程反复检查锁变量是否可用。由于线程在这一过程中保持执行,因此是一种忙等待。一旦获取了自旋锁,线程会一直保持该锁,直至显式释放自旋锁。自旋锁避免了进程上下文的调度开销,因此对于线程只会阻塞很短时间的场合是有效的。因此操作系统的实现在很多地方往往用自旋锁。线程的阻塞和唤醒需要CPU从用户态转为核心态,频繁的阻塞和唤醒对CPU来说是一件负
要记录的Ivan
·
2023-10-26 16:23
Java并发
编程解析 | 基于JDK源码解析Java领域中ReentrantLock锁的设计思想与实现原理 (一)
苍穹之边,浩瀚之挚,眰恦之美;悟心悟性,善始善终,惟善惟道!——朝槿《朝槿兮年说》写在开头在并发编程领域,有两大核心问题:一个是互斥,即同一时刻只允许一个线程访问共享资源;另一个是同步,即线程之间如何通信、协作。主要原因是,对于多线程实现实现并发,一直以来,多线程都存在2个问题:线程之间内存共享,需要通过加锁进行控制,但是加锁会导致性能下降,同时复杂的加锁机制也会增加编程编码难度过多线程造成线程之
朝槿木兮
·
2023-10-26 08:12
(十)深入理解
Java并发
编程之ThreadPool线程池、工作原理、复用原理及源码分析
一、引言一般在开发过程中,一个功能是运行时长太久了,一般是通过什么方式去优化的?异步/多线程,对于一个业务方法而言,如果其中的调用链太长势必会引起程序运行时间延长,导致整个系统吞吐来量下降,而我们使用多线程方式来对该方法的调用链进行优化,对于一些耦合度不是特别高的调用关系可以直接通过多线程来走异步的方式进行处理,大大的缩短了程序的运行时长,但是如果我们的多线程创建方式是通过newThread();
竹子爱熊猫
·
2023-10-26 04:16
并发编程
java
多线程
面试
Java并发
——线程池原理解析
前言可以说,线程池是
Java并发
场景中应用到的最多并发框架了。几乎所有需要异步或者并发执行的任务程序都可以使用线程池。在开发过程中,合理的使用线程池会带来以下3个好处:降低资源的消耗。
兵临奇点
·
2023-10-26 04:43
并发编程
多线程
线程池原理
java
Java并发
线程池原理源码深入分析与调优实战
一,开篇:java中提供了多线程设计的Api,为什么还要用线程池呢?下来看两个例子:1.使用多线程跑十万次2.使用线程池跑十万次使用多线程跑十万次packagecom.laoyang.ThreadPool.公开课;importjava.util.ArrayList;importjava.util.Random;/***@author:Kevin*@create:2023-10-2518:27*@D
玛卡巴咖
·
2023-10-26 04:33
并发编程
java
开发语言
线程池
JAVA并发
面试题【转】
一、多线程1、java中有几种方法可以实现一个线程?1)继承Thread类;2)实现Runnable接口;3)实现Callable接口通过FutureTask包装器来创建Thread线程;4)使用ExecutorService、Callable、Future实现有返回结果的多线程(也就是使用了ExecutorService来管理前面的三种方式)。详情参见:https://radiancel.git
天草二十六_简村人
·
2023-10-26 04:09
【JAVA】:万字长篇带你了解
JAVA并发
编程【一】
目录【JAVA】:万字长篇带你了解
JAVA并发
编程1.并发编程基础并发与并行并发(Concurrency)并行(Parallelism)线程与进程线程的状态与生命周期线程同步与锁2.
Java并发
工具类准备
无难事者若执
·
2023-10-26 02:57
Java开发知识
java
多线程
并发
volatile关键字的原理及适用场景(摘选)
一、volatile的作用在《
Java并发
编程:核心理论》一文中,我们已经提到过可见性、有序性及原子性问题,通常情况下我们可以通过Synchronized关键字来解决这些个问题,不过如果对Synchronized
阿斯蒂芬2
·
2023-10-25 17:51
上一页
9
10
11
12
13
14
15
16
下一页
按字母分类:
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
其他