/*** An object that maps keys to values. A map cannot contain duplicate keys;* each key can map to at most one value.** <p>This interface takes the place of the <tt>Dictionary</tt> class, which* was a totally abstract class rather than an interface.** <p>The <tt>Map</tt> interface provides three <i>collection views</i>, which* allow a map‘s contents to be viewed as a set of keys, collection of v...
ReentrantLock是一个较为常用的锁对象。在上次分析的uil开源项目中也多次被用到,下面谈谈其概念和基本使用。概念一个可重入的互斥锁定 Lock,它具有与使用 synchronized 相同的一些基本行为和语义,但功能更强大。名词解释:互斥表示同一时刻,多个线程中,只能有一个线程能获得该锁。但是多个线程都可以调用lock方法,只有一个会成功,其他的线程会被阻塞,直到该锁被释放可重入模仿synchronized 的语义;如果线程进入由线程已经...
在百度百科上找了一段定义ORM的话:对象关系映射(英语:ObjectRelational Mapping,简称ORM,或O/RM,或O/Rmapping),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。从效果上说,它其实是创建了一个可在编程语言里使用的“虚拟对象数据库”。那么ORM Framework就是提供对象到数据库关系映射的一套编程模型。现在流行的MyBaits、Hibernate都是这种框架。本章开始我们就来分析下这两种框架源码的分析,...
There is no getter for property named ‘*‘ in ‘class java.lang.String‘,此错误之所以出现,是因为mybatis在对parameterType="String"的sql语句做了限制,假如你使用<when test="username != null">这样的条件判断时,就会出现该错误,不过今天我们来刨根问底一下。一、错误再现想要追本溯源,就需要错误再现,那么假设我们有这样一个sql查询:<selectid="getRiskMember"resultMap="BaseResultMap"parameterType="String"><...
本文的目录结构如下:一、LinkedHashSet 的 Javadoc 文档注释和简要说明二、LinkedHashSet 的内部实现:构造函数三、LinkedHashSet 的 add 操作和 remove 操作一、LinkedHashSet 的 Javadoc 文档注释和简要说明 还是以官方 javadoc 作为参考进行说明:LinkedHashSet 是 Set 接口的 hash table 和 linked list 实现,而且迭代顺序可预测(按照元素的插入顺序),实际上 LinkedHashSet 继承了 HashSet,内部使用了 LinkedHashMap ...
在JDK1.6,JDK1.7中,HashMap采用位桶+链表实现,即使用链表处理冲突,同一hash值的链表都存储在一个链表里。但是当位于一个桶中的元素较多,即hash值相等的元素较多时,通过key值依次查找的效率较低。而JDK1.8中,HashMap采用位桶+链表+红黑树实现,当链表长度超过阈值(8)时,可能会将链表转换为红黑树,这样大大减少了查找时间。简单说下HashMap的实现原理:首先存在一个table数组,里面每个元素都是一个node链表,当添加一个元...
ThreadLocal内部是用一张哈希表来存储: 1staticclass ThreadLocalMap {2staticclass Entry extends WeakReference<ThreadLocal<?>> {3/** The value associated with this ThreadLocal. */ 4 Object value;5 6 Entry(ThreadLocal<?> k, Object v) {7super(k);8 value = v;9 }
10 }
11privatestaticfinalint INITIAL_CAPACITY = 16;
12private Entry[] table;
13privateint ...
首先放上参考链接,博主分析比较细致:https://fangjian0423.github.io/2016/03/22/java-threadpool-analysis/1. 首先必须清楚这么几个常量,主要思想是用一个int型表示线程池状态及数量,用int高三位表示状态,低29位表示线程数,所以,线程池最大线程数为 :1 << 29 - 1 而不是 1 << 32 - 1。2. 基于以上基础,线程池状态可以用 当前线程所表示的数字 c & ~((1 << 29) - 1) 可得线程状态, 当前线程所表示的数字 c & (1 << 29) -...
欢迎关注我的公众号“彤哥读源码”,查看更多源码系列文章, 与彤哥一起畅游源码的海洋。简介TreeMap使用红黑树存储元素,可以保证元素按key值的大小进行遍历。继承体系TreeMap实现了Map、SortedMap、NavigableMap、Cloneable、Serializable等接口。SortedMap规定了元素可以按key的大小来遍历,它定义了一些返回部分map的方法。public interface SortedMap<K,V> extends Map<K,V> {// key的比较器Comparator<? super K> comparator(...
Java的异步编程是一项非常常用的多线程技术。之前通过源码详细分析了ThreadPoolExecutor《你真的懂ThreadPoolExecutor线程池技术吗?看了源码你会有全新的认识》。通过创建一个ThreadPoolExecutor,往里面丢任务就可以实现多线程异步执行了。但之前的任务主要倾向于线程池,并没有讲到异步编程方面的内容。本文将通过介绍Executor+Future框架(FutureTask是实现的核心),来深入了解下Java的异步编程。万事从示例开始,我们先通过示...
一、异常原因与异常源码分析 对集合(List、Set、Map)迭代时对其进行修改就会出现java.util.ConcurrentModificationException异常。这里以ArrayList为例,例如下面的代码:ArrayList<String> list = new ArrayList<>();
list.add("1");
list.add("2");
list.add("3");
//遍历1for (String s : list){if (s.equals( "3")) {list.remove(s); // error }
}
//遍历2
Iterator<String> it = list.iterator();
for (; it.hasNext()...
ArrayBlockingQueue原理介绍 ArrayBlockingQueue,是基于数组的阻塞队列,队列中的元素按照FIFO顺序。 创建ArrayBlockingQueue,是需要制定队列的容量的(不可省);指定队列容量后,会一次性创建capacity个长度的数组,用来存放队列元素; 需要注意的是,ArrayBlockingQueue使用的是循环数组来实现队列,也就是说,有takeIndex指向下一个出队元素,当takeIndex指向了capacity-1的位置(最后一个位置),那么元素出队后,...
wifisetting : wifimanager WiFienable:native 申明本地接口:jni 关联本地接口和底层实现:driver wifi实现2)Wifi启动流程 (1)使能Wifi (2) 扫描AP (3)连接 (4)获取IP地址 启动dhcp https://blog.csdn.net/lp542718520/article/details/76578235WPAS wpa_supplicant 原文:https://www.cnblogs.com/zeng-iauto/p/12022291.html
使用: 1import javax.swing.text.html.HTMLDocument.HTMLReader.IsindexAction;2 3publicclass Test {4 5publicstaticvoid main(String[] args) {6 7 ThreadGroup tg = new ThreadGroup("threadGroup-001"); 8 9 Thread t1 = new Thread(tg, new MyThread());
10 t1.start();
1112 Thread t2 = new Thread(tg, new MyThread());
13 t2.start();
1415// 返回线程组中活动线程的估计数16 ...
纸上得来终觉浅,绝知此事要躬行 --陆游 问渠那得清如许,为有源头活水来 --朱熹HashSet是一个没有重复元素的集合,HashSet是由HashMap实现的,不保证元素的顺序,并且HashSet允许使用null元素。HashSet不是线程安全的,当多个线程同时访问HashSet时,会出现问题,解决的方法是通过对自然封装该Set的对象执行同步操作来完成的。还可以使用Collections.synchronizedSet方法来包装set。Set s=Collectins.synchronizedSet(new Has...