高效并发是从JDK 1.5到JDK 1.6的一个重要改进,HotSpot虚拟机开发团队在这个版本上花费了大量的精力去实现各种锁优化技术,如适应性自旋(Adaptive Spinning)、锁消除(Lock Elimina…
分类:java并发
java学习多线程之死锁
形成死锁的前提是同步代码块嵌套。 什么是死锁?当一个线程拿到锁以后在这个锁内部的代码需要访问另一段的代码的时候另外一个程序的锁被另外一个线程拿到,这样的话,就造成了两个锁互不想让程序没法往下执行的这种状况就是死锁。 1 …
Java可重入锁AQS 和 CAS原理
Java 实现同步的两种方式,一种是使用synchronized关键字来实现同步访问,另外一种是从Java 5之后,在java.util.concurrent.locks包下 提供了另外一种方式来实现同步访问,那就是…
Java多线程:AtomicInteger 原子更新基本类型类,Java多线程系列--“JUC原子类”02之 AtomicLong原子类
前言 原子是世界上的最小单位,具有不可分割性。比如 a=0;(a非long和double类型) 这个操作是不可分割的,那么我们说这个操作时原子操作。再比如:a++; 这个操作实际是a = a + 1;是可分割的,所以它不…
从一个简单的Java单例示例谈谈并发 JMM JUC
原文: http://www.open-open.com/lib/view/open1462871898428.html 一个简单的单例示例 单例模式可能是大家经常接触和使用的一个设计模式,你可能会这么写 p…
JUC-CopyOnWriteArrayList
CopyOnWriteArrayList 一、简介: 1.相当于线程安全的ArrayList。 2.对于可变的操作add,set,rem…
Java多线程 -- JUC包源码分析8 -- 对happen before的深刻理解
说到happen before,很多人都知道。但因为其理论的抽象,以及在语义上的微妙,使得对happen before的理解,往往陷入“隔靴搔痒“的境地。本文试图宏观性、多角度的来分析围绕happen before的诸多…
java线程池的创建使用
利用java的多线程编程可以大大的提高系统的并发运行效率,线程越多并发执行的任务就越多,但是并不意味着效率会一直提高,相反会得到适得其反的效果。 java中的多线程编程一共有三种方法: 继承Thread类…
Java输出导致死锁,at java.io.PrintStream.println(PrintStream.java:805) - waiting to lock
Java输出导致死锁,at java.io.PrintStream.println(PrintStream.java:805) – waiting to lock <0x0000000494fa8398…
100+经典Java面试题及答案解析
面向对象编程(OOP) Java是一个支持并发、基于类和面向对象的计算机编程语言。下面列出了面向对象软件开发的优点: 代码开发模块化,更易维护和修改。 代码复用。 增强代码的可靠性和灵活性。 增加代码的可理…
Java并发(基础知识)—— Executor框架及线程池
在Java并发(基础知识)—— 创建、运行以及停止一个线程中讲解了两种创建线程的方式:直接继承Thread类以及实现Runnable接口并赋给Thread,这两种创建线程的方式在…
你应该知道的JAVA面试题
经常面试一些候选人,整理了下我面试使用的题目,陆陆续续整理出来的题目很多,所以每次会抽一部分来问。答案会在后面的文章中逐渐发布出来。 基础题目 Java线程的状态 进程和线程的区别,进程间如何通讯,线程间如…