集合
			 2017-02-08 
									
		
	
		     
	       
		     
	
		
		
			 2017-02-01 
									
		
	
		     
问题
- 集合(Collection)和集合(Set)有什么区别?
 - HashSet怎么保证添加元素不重复?
 - HashSet是否允许null元素?
 - HashSet是有序的吗?
 - HashSet是同步的吗?
 - 什么是fail-fast?
 
			 2016-08-11 
									
		
	
		     
简介
WeakHashMap是一种弱引用map,内部的key会存储为弱引用,当jvm gc的时候,如果这些key没有强引用存在的话,会被gc回收掉,下一次当我们操作map的时候会把对应的Entry整个删除掉,基于这种特性,WeakHashMap特别适用于缓存处理。
			 2016-07-19 
									
		
	
		     
	       
		     
	
		
		
			 2016-07-15 
									
		
	
		     
	       
		     
	
		
		
			 2016-07-11 
									
		
	
		     
简介
LinkedHashMap内部维护了一个双向链表,能保证元素按插入的顺序访问,也能以访问顺序访问,可以用来实现LRU缓存策略。
LinkedHashMap可以看成是 LinkedList + HashMap。
实战另见 LinkedHashMap
			 2016-07-08 
									
		
	
		     /pexels-photo-1208696.jpeg)
二叉树的遍历
我们知道二叉查找树的遍历有前序遍历、中序遍历、后序遍历。
- 前序遍历,先遍历我,再遍历我的左子节点,最后遍历我的右子节点;
 - 中序遍历,先遍历我的左子节点,再遍历我,最后遍历我的右子节点;
 - 后序遍历,先遍历我的左子节点,再遍历我的右子节点,最后遍历我;
 
这里的前中后都是以“我”的顺序为准的,我在前就是前序遍历,我在中就是中序遍历,我在后就是后序遍历。
			 2016-07-06 
									
		
	
		     /pexels-photo-346700.jpeg)
删除元素
删除元素本身比较简单,就是采用二叉树的删除规则。
- 如果删除的位置有两个叶子节点,则从其右子树中取最小的元素放到删除的位置,然后把删除位置移到替代元素的位置,进入下一步。
 - 如果删除的位置只有一个叶子节点(有可能是经过第一步转换后的删除位置),则把那个叶子节点作为替代元素,放到删除的位置,然后把这个叶子节点删除。
 - 如果删除的位置没有叶子节点,则直接把这个删除位置的元素删除即可。
 - 针对红黑树,如果删除位置是黑色节点,还需要做再平衡。
 - 如果有替代元素,则以替代元素作为当前节点进入再平衡。
 - 如果没有替代元素,则以删除的位置的元素作为当前节点进入再平衡,平衡之后再删除这个节点。
 



/smoothie-fruit-beverage-drink-161600.jpeg)
/beverage-citrus-close-up-1265910.jpg)