上一页 1 ··· 4 5 6 7 8 9 10 11 12 13 下一页
摘要: Map是Java最常用的集合类之一。它有很多实现类,我总结了几种常用的Map实现类,如下图所示。本篇文章重点总结几个Map实现类的特点和区别: 特点总结: 实现类 HashMap LinkedHashMap TreeMap Hashtable ConcurrentHashMap 允许key/valu 阅读全文
posted @ 2019-11-19 19:10 windpoplar 阅读(524) 评论(0) 推荐(0) 编辑
摘要: 1. ArrayList ArrayList 是一个数组队列,相当于动态数组。与Java中的数组相比,它的容量能动态增长。它继承于AbstractList,实现了List, RandomAccess, Cloneable, java.io.Serializable这些接口。默认容量是10(从源码中可 阅读全文
posted @ 2019-11-18 22:33 windpoplar 阅读(281) 评论(0) 推荐(0) 编辑
摘要: 为什么需要线程池 java中为了提高并发度,可以使用多线程共同执行,但是如果有大量线程短时间之内被创建和销毁,会占用大量的系统时间,影响系统效率。 为了解决上面的问题,java中引入了线程池,可以使创建好的线程在指定的时间内由系统统一管理,而不是在执行时创建,执行后就销毁,从而避免了频繁创建、销毁线 阅读全文
posted @ 2019-11-16 08:42 windpoplar 阅读(3836) 评论(0) 推荐(1) 编辑
摘要: 概述 CAS(Compare-and-Swap),即比较并替换,是一种实现并发算法时常用到的技术,Java并发包中的很多类都使用了CAS技术。CAS也是现在面试经常问的问题,本文将深入的介绍CAS的原理。 案例 介绍CAS之前,我们先来看一个例子。 /** * @author joonwhee * 阅读全文
posted @ 2019-11-15 22:18 windpoplar 阅读(647) 评论(0) 推荐(0) 编辑
摘要: 学习Java中常用的开源框架,Mybatis、Hibernate中线程通过数据库连接对象Connection,对其数据进行操作,都会使用ThreadLocal类来保证Java多线程程序访问和数据库数据的一致性问题。就想深入了解一下ThreadLocal类是怎样确保线程安全的!详解如下: 一、对Thr 阅读全文
posted @ 2019-11-15 21:26 windpoplar 阅读(833) 评论(0) 推荐(0) 编辑
摘要: 一、volatile的作用 通常情况下我们可以通过Synchronized关键字来解决这些个问题,不过如果对Synchronized原理有了解的话,应该知道Synchronized是一个比较重量级的操作,对系统的性能有比较大的影响,所以,如果有其他解决方案,我们通常都避免使用Synchronized 阅读全文
posted @ 2019-11-14 22:49 windpoplar 阅读(1159) 评论(0) 推荐(0) 编辑
摘要: Java并发包(JUC)中提供了很多并发工具,这其中,很多我们耳熟能详的并发工具,譬如ReentrangLock、Semaphore,它们的实现都用到了一个共同的基类--AbstractQueuedSynchronizer,简称AQS。AQS是一个用来构建锁和同步器的框架,使用AQS能简单且高效地构 阅读全文
posted @ 2019-11-14 17:45 windpoplar 阅读(341) 评论(0) 推荐(0) 编辑
摘要: ReentrantLock是Java并发包中提供的一个可重入的互斥锁。ReentrantLock和synchronized在基本用法,行为语义上都是类似的,同样都具有可重入性。只不过相比原生的Synchronized,ReentrantLock增加了一些高级的扩展功能,比如它可以实现公平锁,同时也可 阅读全文
posted @ 2019-11-10 20:33 windpoplar 阅读(378) 评论(0) 推荐(0) 编辑
摘要: 前言 一、synchronized的特性 1.1 原子性 1.2 可见性 1.3 有序性 1.4 可重入性 二、synchronized的用法 三、synchronized锁的实现 3.1 同步方法 3.2 同步代码块 四、synchronized锁的底层实现 五、JVM对synchronized的 阅读全文
posted @ 2019-11-10 19:56 windpoplar 阅读(2538) 评论(1) 推荐(2) 编辑
摘要: 一、线程同步 线程同步:即当有一个线程在对内存进行操作时,其他线程都不可以对这个内存地址进行操作,直到该线程完成操作, 其他线程才能对该内存地址进行操作,而其他线程又处于等待状态,实现线程同步的方法有很多,临界区对象就是其中一种。 在多线程编程里面,一些敏感数据不允许被多个线程同时访问,此时就使用同 阅读全文
posted @ 2019-11-09 22:02 windpoplar 阅读(623) 评论(0) 推荐(0) 编辑
上一页 1 ··· 4 5 6 7 8 9 10 11 12 13 下一页