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并发编程juc
社招两年半10个公司28轮面试面经
我看过的Java相关的书单如下:Java:《
Java并发编程
的艺术》、《
Java并发编程
实战》JVM:《深入理解Java虚拟机》第三版、《深入Java虚拟机:JVMG1GC的算法与实现》、《新一代垃圾回收器
java晴天过后
·
2023-10-18 15:17
面试
java
开发语言
JUC
下的并发集合类
HashTable的区别3.ConcurrentHashMap线程安全的具体实现方式/底层具体实现4.说说CopyOnWriteArrayList1.ConcurrentHashMapjava5.0在
juc
一只小星_
·
2023-10-18 12:44
秋招-准备计划
-准备计划基本信息时间:9月——10月岗位:java后端开发目标:中厂、大厂,有高用户量的项目、企业优先准备简历基本信息获奖情况项目经历(实习经历)笔试算法与数据结构面试Java篇:基本知识、JVM、
JUC
正如此时
·
2023-10-18 11:43
秋招
java
面试
JUC
-Lock
公平锁:多个线程按照申请锁的顺序获取锁,类似于队列。 非公平锁:上来直接尝试占有锁,如果尝试失败,再采用类似公平锁的方式,可能会产生优先级反转或饥饿现象。优点:吞吐量比公平锁大。Synchronized也是一种非公平锁。Locklock=newReentrantLock();//默认非公平锁 可重入锁(递归锁):同一线程外层函数获得锁之后,内存递归函数仍然能获取该锁的代码。同一线程在外层方
GIT提交不上
·
2023-10-18 10:04
【
JUC
】10. synchronized与锁升级
文章目录1.锁升级过程1.1无锁1.2偏向锁1.2.1偏向锁的撤销1.3轻量级锁1.4重量级锁2.锁关系之hashcode关系3.总结4.锁清除5.锁粗化1.锁升级过程为什么会出现锁升级呢?是因为synchronized虽然能实现数据的安全性,但是带来的却是性能下降无锁虽然能基于并行提升程序性能,但是带来的是安全性下降这中间需要求个平衡通过锁的升级,可以使得效率和安全性实现平衡换句话说,比如手机掉
起名方面没有灵感
·
2023-10-18 09:07
JUC
java
jvm
面试
JUC
第三十讲:
JUC
工具类:Exchanger详解
JUC
工具类:Exchanger详解本文是
JUC
第三十讲,
JUC
工具类:Exchanger详解。Exchanger是用于线程协作的工具类,主要用于两个线程之间的数据交换。
程序员 jet_qi
·
2023-10-18 07:06
java基础之多线程
JUC
工具类
Exchanger
线程数据交换
源码分析
JUC
并发编程——ForkJoin与异步回调
ForkJoin(分支合并)什么是ForkJoinForkJoin在JDK1.7出现,并行执行任务,在大数据量下,能够提高效率讯飞星火提供的说法:Forkjoin是一种并行计算的算法,用于将一个大任务分解为多个小任务,然后将这些小任务分配给不同的线程或进程来并行执行,最后再将结果合并。在计算机科学中,Forkjoin通常用于实现基于分治策略的程序和数据结构,例如排序算法、图遍历算法、哈希表等。它可
苏三有春
·
2023-10-18 06:12
JUC并发编程
java
开发语言
学习
JUC
并发编程——Stream流式计算(基于狂神说的学习笔记)
Stream流式计算什么是Stream流式计算Stream流式计算是一种基于数据流的计算模式,它可以对数据进行实时处理和分析,而不需要将所有数据存储在内存中。Stream流式计算是将数据源中的数据分割成多个小的数据块,然后对每个小的数据块进行并行处理,最后将处理结果合并。这种方式可以大大提高程序的执行效率,因为每个小的数据块都可以在一个独立的线程中进行处理,而不需要等待整个数据集被处理完毕。Str
苏三有春
·
2023-10-18 06:33
JUC并发编程
学习
笔记
java
Happens-Before保证线程可见
前言熟悉
Java并发编程
的都知道,JMM(Java内存模型)中的happen-before规则,该规则定义了Java多线程操作的有序性和可见性,防止了编译器重排序对程序结果的影响。
Perkinl
·
2023-10-18 05:17
java
java
多线程
Java进阶-
JUC
篇
依赖包org.projectlomboklombok1.18.8第二步,将project里的modules的languagelevel改为jdk8第三步,将javaCompile改为jdk81.什么是
JUC
java.util.concurrent
牛牛的Java学习之旅
·
2023-10-18 03:52
Java进阶
java
开发语言
【
JUC
并发编程_02】
JUC
并发编程(四)、共享模型之管程1.waitnotify(1).小故事_为什么需要wait(2).waitnotify的工作原理(3).API介绍2.waitnotify的正确使用步骤⭐(1).sleep
吉士先生
·
2023-10-18 00:04
java
网络
开发语言
LockSupport-LockSupport是什么及等待唤醒机制对比
而作用分别是阻塞线程和解除阻塞线程.4.3线程等待唤醒机制4.3.1三种让线程等待和唤醒的方法方式一:使用Object中的wait()方法让线程等待,使用Object中的notify()方法唤醒线程方式二:使用
JUC
ZHOU_VIP
·
2023-10-17 23:30
JUC并发编程与源码分析
java
JUC
并发工具类在大厂的应用场景详解
jdk提供了比synchronized更加高级的各种同步工具,包括ReentrantLock、Semaphore、CountDownLatch、CyclicBarrier等,可以实现更加丰富的多线程操作。(前三个是重点)一.ReentrantLockReentrantLock是一种可重入的独占锁,它允许同一个线程多次获取同一个锁而不会被阻塞。它的功能类似于synchronized是一种互斥锁,可以
玛卡巴咖
·
2023-10-17 20:25
java
开发语言
高并发
JUC
并发编程——四大函数式接口(基于狂神说的学习笔记)
四大函数式接口函数式接口:只有一个方法的接口,例如:Runnable接口Function函数型接口,有一个输入参数,有一个输出源码:/***Representsafunctionthatacceptsoneargumentandproducesaresult.**Thisisafunctionalinterface*whosefunctionalmethodisapply(Object).**@p
苏三有春
·
2023-10-17 18:37
JUC并发编程
学习
笔记
java
JUC
并发编程——线程池学习:基础概念及三大方法、七大参数、四大拒绝策略(基于狂神说的学习笔记)
线程池池化技术的本质:事先准备好一些资源,线程复用,用完即还,方便管理默认大小:2最大并发数max根据电脑去设置,CPU密集型,IO密集型线程池的好处:降低资源的消耗提高响应的速度,无需新建和销毁方便管理线程池学习:3大方法、7大参数、4大拒绝策略三大方法Executors.newSingleThreadExecutor();//单个线程Executors.newFixedThreadPool(5
苏三有春
·
2023-10-17 18:59
JUC并发编程
学习
笔记
java
AQS原理及源码解析
AQS通过对互斥锁、共享锁和条件等待的基础实现和封装,同时为
juc
包下其他类提供扩展,完善了java体系的锁、线程池和并发集合类的实现,主要包括:ReentrantLock(可重入锁,由AQS互斥锁扩展实现
zhang527294844
·
2023-10-17 16:21
JAVA并发编程
JUC包
java
java并发编程
实战——读书笔记
value++;包含三个独立操作:读取value,将value加1,并将计算结果写入value如果错误的假设程序中的操作将按照某种特定顺序来执行,那么会存在各种可能的危险。框架中如果有多线程并发性,那使用框架的应用程序代码也会遇到并发性问题,在代码中会访问应用程序的状态,所有访问这些状态的代码都应该考虑线程安全问题。Timer\Servlet、JSP\RMI远程方法调用\Swing和AWT都会引入
cyw2002509
·
2023-10-17 11:18
并发
并发
java
多线程
Java并发编程
之AQS源码阅读
1.父类AbstractOwnableSynchronizer该类有两个重要的方法,设置独占线程与获取独占线程。publicabstractclassAbstractOwnableSynchronizerimplementsjava.io.Serializable{/**UseserialIDeventhoughallfieldstransient.*/privatestaticfinallong
逍遥白亦
·
2023-10-17 01:14
java并发编程
cmpareAndSet_java CAS compareAndSet, compareAndSwap 区别
我看了
java并发编程
实战找到了答案。CAS是一种计算机的指令。CAS包含3个操作数,需要读写的内存位置V,进行比较的值A和拟写入的新值B。
weixin_39617405
·
2023-10-16 16:07
Java并发编程
——CAS(Compare And Swap)比较与交换
前言在
Java并发编程
中,处理共享数据的相关问题是保证并发安全的前提,对于一个共享数据,我们常常有两种处理方式,一种是方法是将数据和读写数据的操作锁起来,另一种就是不锁。
Viewwuyou
·
2023-10-16 16:37
java
多线程
并发编程
并发编程-CAS
说在前面的话正如我开篇所说,我要整理一些
java并发编程
的学习文档,这一篇就是第二篇:java中的CAS。这一篇主要说的CAS的原理,以及java中的CAS的一些应用吧!欢迎关注和点赞。
戴着假发的程序员
·
2023-10-16 16:34
java
java并发编程
java
并发编程
JUC
CAS
【锁】CAS(Compare And Swap)
—《
Java并发编程
实践》⭐️CompareAndSetCAS(CompareAndSet或CompareAndSwap),即比较并修改的意思
Abner G
·
2023-10-16 16:01
基础总结
锁
java
jvm
面试
深入了解CAS(Compare and Swap):
Java并发编程
的核心
什么是CASCAS(CompareandSwap)是一种多线程同步的原子操作,用于解决共享数据的并发访问问题。它允许一个线程尝试修改共享变量的值,但只有在变量的当前值与预期值匹配的情况下才会执行更新操作。CAS操作包括三个主要步骤:比较(Compare):线程首先读取共享变量的当前值,这个值通常是期望的值。比较预期值:线程将当前值与预期的值进行比较。如果它们匹配,表示变量的当前值与线程期望的值相同
qq_41956309
·
2023-10-16 16:30
并发编程
java
jvm
《
java并发编程
实战》-(2)-线程安全性-(安全发布)
(扯一段废话,第一次用markdown的方式写,只为更好的方便大家阅读。)我们在面试的时候经常会被问到工作中都用到了哪些设计模式?或者阅读源码的时候都见过哪些设计模式的应用?手写一个单例的设计模式等等吧。在手写单例的时候我们一般会写懒汉模式,饿汉模式,内部类模式,枚举模式。在写懒汉模式中有一个双重检测机制的写法(不会的自行百度,这里就做过多的演示),这个写法有效的解决了安全的懒汉模式,synchr
小超人爱小土豆
·
2023-10-16 15:12
阿里面试技巧来啦!!!3技术面+2交叉面+1代码面+1HR面,offer轻松拿
垃圾回收器你项目里用的什么数据库如果我有很多字段都需要建立索引,怎么办Mysql的存储引擎,你用的是哪种说一下Innodb数据库底层数据结构B+树的特征说一下你常用的api和包haspmap底层讲一讲那么
juc
阿里官方架构师
·
2023-10-16 11:16
Java
程序人生
架构
java
面试
后端
JUC
并发编程(二):线程相关知识点
1.背景实现编发编程的主要手段就是多线程。线程是操作系统里的一个概念。接下来先说说两者的定义、联系与区别。1.1进程和线程的区别进程进程是程序的一次执行过程,是系统运行程序的基本单位,因此进程是动态的。系统运行一个程序即是一个进程从创建,运行到消亡的过程。在Java中,当我们启动main函数时其实就是启动了一个JVM的进程,而main函数所在的线程就是这个进程中的一个线程,也称主线程。如下所示就是
shepherd126
·
2023-10-16 11:54
java
开发语言
JUC
并发编程(一):Java内存模型(JMM)及三大特性:可见性、有序性、原子性
1.简介在当今高流量、高并发的互联网业务场景下,并发编程技术显得尤为重要,不管是哪一门编程语言,掌握并发编程技术是个人进阶的必经之路。时隔一个半月没有写技术博客文章,有点生疏了。。。闲话少叙,接下来我将围绕并发编程知识点进行总结讲解,这里从并发编程入门开始,讲述Java内存模型和并发的三大特性。2.Java内存模型(JMM)Java内存模型(简称JMM):定义了线程和主内存之间的抽象关系,即JMM
shepherd126
·
2023-10-16 11:23
java
开发语言
【
JUC
】Volatile
Volatile文章目录Volatile1.概述2.内存屏障3.volatile可见性案例4.volatile重排序问题案例5.volatile变量的读写过程6.使用场景1.概述特点:可见性有序性-有时禁止指令重排(使用内存屏障禁止重排)内存含义:volatile的写内存语义是直接刷新到主内存中,读的内存语义是直接从主内存中读取当写一个volatile变量时,JMM会把该线程对应的本地内存中的共享
比尔高特
·
2023-10-16 11:13
#
03
JUC
java
【
JUC
】ThreadLocal
文章目录1.概述2.使用3.Thread、ThreadLocal和ThreadLocalMap4.内存泄露问题4.1为什么源代码用弱引用?4.2内存泄露再分析5.最佳实践6.小总结1.概述ThreadLocal提供线程局部变量。这些变量与正常的变量不同,因为每一个线程在访问ThreadLocal实例的时候(通过其get或set方法)都有自己的、独立初始化的变量副本。ThreadLocal实例通常是
比尔高特
·
2023-10-16 11:56
#
03
JUC
java
JUC
并发编程:Monitor和对象结构
JUC
并发编程:Monitor和对象结构1.Monitor1.1对象的结构1.1.1MarkWord1.1.2KlassWord1.1.3数组长度1.1.41.MonitorMonitor官方文档我们可以把
boy快快长大
·
2023-10-16 05:38
Java并发编程
java
10分钟搞定 Java 并发队列好吗?好的
youdoNOTunderstanditwellenough现陆续将Demo代码和技术文章整理在一起Github实践精选,方便大家阅读查看,本文同样收录在此,觉得不错,还请Star前言如果按照用途与特性进行粗略的划分,
JUC
日拱一兵
·
2023-10-16 03:04
Java并发编程
:ConcurrentModificationException异常出现的原因和解决方法
版权声明:本文为海子原创文章,转载请注明出处!在前面一篇文章中提到,对Vector、ArrayList在迭代的时候如果同时对其进行修改就会抛出java.util.ConcurrentModificationException异常。下面我们就来讨论以下这个异常出现的原因以及解决办法。一、ConcurrentModificationException异常出现的原因先看下面这段代码:publicclas
ZebraWei
·
2023-10-15 19:24
并发编程进阶类学习--
java并发编程
之美(二)
文章目录Random类原理及其局限性上述代码的执行流程应运而生的ThreadLocalRandomAtomicLong的介绍函数列表缺点使用LongAdder(jdk1.8新增)相比于AtomicLong的好处具体LongAdder实现原理LongAdder的设计结构简略图简单聊一下LongAdder的add方法LongAccumulator类(jdk1.8新增)相比于LongAdderRando
不洇
·
2023-10-15 18:21
并发编程
java
多线程
并发编程
Java并发编程
写在前面必读同步队列和等待队列同步队列:处于running状态的线程,有资格竞争锁的线程组成的等待获取同步资源的队列。等待队列:调用wait方法或await方法后线程进入等待队列,等待被唤醒后进入同步队列。必须明白并发编程的几个课题如何创建和结束多线程?进程线程概念,线程创建的几种方式,线程的几种状态,如何优雅结束线程。如何保证线程正确执行?并发编程三大特性保证原子性的锁如何控制线程执行顺序?掌握
塔◎
·
2023-10-15 18:46
Java知识点总结
java
并发编程
高并发
Java并发编程
面试题3
一、CountDownLatch,Semaphore的高频问题:1.1CountDownLatch是啥?有啥用?底层咋实现的?(可以融入到你的项目业务中。)CountDownLatch本质其实就是一个计数器。在多线程并形处理业务时,需要等待其他线程处理完,再做后续的合并等操作,再响应用户时,可以使用CountDownLatch做计数,等到其他线程出现完之后,主线程就会被唤醒。CountDownLa
茶晓i
·
2023-10-15 18:15
java
java
面试
开发语言
JUC
并发编程——读写锁(基于狂神说的学习笔记)
读写锁以下来自官方文档ReadWriteLock维护一对关联的locks,一个用于只读操作,另一个用于写入。只要没有写入器,readlock可以由多个读取器线程同时保持。writelock是独家的。所有ReadWriteLock实现必须保证writeLock操作的内存同步效果(如Lock接口中所指定)也相对于关联的readLock。也就是说,成功获取读锁定的线程将看到在先前释放写锁定时所做的所有更
苏三有春
·
2023-10-15 15:45
JUC并发编程
学习
笔记
java
JUC
并发编程——阻塞队列(基于狂神说的学习笔记)
阻塞队列顾名思义:当写入时:如果队列满了,则必须阻塞等待当读取时,如果队列为空,则必须阻塞等待BlockingQueueList、Set、BlockingQueue同级,都继承于Collection,且BlockingQueue下级有ArrayBlockingQueue以及LinkBlockingQueue,即BlockingQueue有两种表达形式,数组型以及链表型什么情况下我们会使用阻塞队列:
苏三有春
·
2023-10-15 15:37
JUC并发编程
学习
笔记
java
Java多线程系列--【
JUC
集合05】- ConcurrentSkipListMap
参考:http://www.cnblogs.com/skywang12345/p/3498556.html概要本章对Java.util.concurrent包中的ConcurrentSkipListMap类进行详细的介绍。内容包括:ConcurrentSkipListMap介绍ConcurrentSkipListMap原理和数据结构ConcurrentSkipListMap函数列表Concurre
ImportNewXXT0101
·
2023-10-15 14:09
Java多线程系列--“
JUC
集合”05之 ConcurrentSkipListMap
概要本章对Java.util.concurrent包中的ConcurrentSkipListMap类进行详细的介绍。内容包括:ConcurrentSkipListMap介绍ConcurrentSkipListMap原理和数据结构ConcurrentSkipListMap函数列表ConcurrentSkipListMap源码分析(JDK1.7.0_40版本)ConcurrentSkipListMap
NullPointerExcept
·
2023-10-15 14:37
JAVA并发编程
java
多线程
【
JUC
】JMM
文章目录1.概述2.三大特性2.1可见性2.2原子性2.3有序性3.多线程对变量的读写过程4.先行发生原则(happens-before)1.概述CPU的运行并不是直接操作内存而是先把内存里边的数据读到缓存,而内存的读和写操作的时候就会造成不一致的问题JVM规范中试图定义一种Java内存模型(javaMemoryModel,简称JMM)来屏献掉各种硬件和操作系统的内存访问差异以实现让Java程序在
比尔高特
·
2023-10-15 13:02
#
03
JUC
java
【
JUC
】线程通信与等待唤醒机制
文章目录1.线程通信2.Object类中的wait和notify方法实现等待和唤醒3.Condition接口中的await和signal方法实现等待和唤醒4.LockSupport实现等待和唤醒4.1优点1.线程通信多个线程在处理同一个资源,但是处理的动作(线程的任务)却不相同,于是这些线程之间就存在通信问题,称为线程间通信。比如:生产者消费者问题。当多个线程间存在通信问题时,我们希望它们能有规律
比尔高特
·
2023-10-15 12:55
#
03
JUC
java
Java开发,参数类型如何选?int, Integer, AtomicInteger?
概述int是基础的变量类型;Integer是包装类型;AtomicInteger是来自
JUC
的一个在并发编程场景下重要的包,对于Java开发人员来说,确实需要对其都有充分的认识与了解。
小智Chris
·
2023-10-15 11:04
Java
面试
银行
java
开发语言
多线程&
JUC
文章目录多线程一.什么是多线程二.多线程的两个概念三.线程的实现方式四.常见的成员方法五.线程安全的问题六.死锁七.生产者和消费者多线程一.什么是多线程进程:是程序的基本执行实体理解:每一个运行的软件就是一个进程线程:是操做系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位理解:应用软件中互相独立,可以同时运行的功能为什么要有多线程?有了多线程就可以让程序同时做多件事情可以
懒羊羊asd
·
2023-10-15 09:27
java入门笔记
java
多线程
【
JUC
】CompletableFuture
文章目录1.Future接口2.CompletableFuture的出现3.CompletableFuture四大静态方法4.使用演示5.常用方法5.1获得结果和触发计算5.2对计算结果进行处理5.3对计算结果进行消费5.4对计算速度进行选用5.5对计算结果进行合并1.Future接口Future接口(FutureTask实现类)定义了操作异步任务执行一些方法,如获取异步任务的执行结果、取消任务的
比尔高特
·
2023-10-15 07:14
#
03
JUC
java
【
JUC
】中断机制(interrupt,interrupted,isInterrupted)
中断机制文章目录中断机制1.概述2.三大方法3.中断运行中的线程的方式1.概述首先一个线程不应该由其他线程来强制中断或停止,而是应该由线程自己自行停止,自己来决定自己的命运。所以Thread.stop,Thread.suspend,Thread.resume都已经被废弃了其次在Java中没有办法立即停止一条线程,然而停止线程却显得尤为重要,如取消一个耗时操作。因此,Java提供了一种用于停止线程的
比尔高特
·
2023-10-15 07:08
#
03
JUC
java
理论:第八章:线程是什么,有几种实现方式,它们之间的区别是什么,线程池实现原理,
JUC
并发包,ThreadLocal与Lock和Synchronize区别
什么是线程?讲个故事给你听,让你没法去背这个题,地址:https://blog.csdn.net/java_wxid/article/details/94131223有几种实现方式?继承Thread类实现Runnable接口实现Callable接口线程池方式优缺点1.继承Thread类优点、代码简单。缺点、该类无法集成别的类。2.实现Runnable接口优点、继承其他类。同一实现该接口的实例可以共
我是廖志伟
·
2023-10-15 02:39
#
理论知识
java
多线程
JUC
并发
JUC
第二十八讲:
JUC
工具类: Semaphore详解
JUC
工具类:Semaphore详解本文是
JUC
第二十八讲,
JUC
工具类:Semaphore详解。Semaphore底层是基于AbstractQueuedSynchronizer来实现的。
程序员 jet_qi
·
2023-10-15 00:53
java基础之多线程
JUC
Semaphore
AQS
计数信号量
令牌
JUC
第二十九讲:
JUC
工具类: Phaser详解
JUC
工具类:Phaser详解本文是
JUC
第二十九讲,
JUC
工具类:Phaser详解。
程序员 jet_qi
·
2023-10-15 00:12
java基础之多线程
JUC
Phaser
同步辅助类
运行机制
实现原理
源码分析
黄聪:buffer overflow detected问题解决及gcc-4.1安装
gcc-4.1安装办法(转载自http://www.cnblogs.com/n
juc
slzh/archive/2010/06/04/1751703.html)由于学习的原因
weixin_34304013
·
2023-10-14 23:55
数据库
buffer overflow detected问题解决及gcc-4.1安装
gcc-4.1安装办法(转载自http://www.cnblogs.com/n
juc
slzh/archive/2010/06/04/1751703.html)由于学习的原因
iteye_20755
·
2023-10-14 23:51
c/c++
数据库
上一页
17
18
19
20
21
22
23
24
下一页
按字母分类:
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
其他