Java知识点梳理(二)

接着上一篇Java知识点梳理(一) 继续简单的总结一下Java中的集合和访问控制。

---

11. Collection集合
集合是对象的容器,可以用来存储和管理对象的对象。集合可以扩展,可以存储不同类型的数据。
















List, Set, Map是集合中最主要的3个接口。其中,List和Set继承自Collection接口。

List有序且允许元素重复。主要实现类有ArrayList和LinkedList(还有Vector)。
Set不允许元素重复。主要实现类有HashSet和TreeSet。
Map属于集合Java Collection Framework,但是和Collection不同,以key/value的方式对元素进行管理。其中key不能重复,value可以重复。主要实现类有HashMap,TreeMap(还有HashTable)。

ArrayList和LinkedList
---
1. ArrayList是基于动态数组的数据结构,LinkedList是基于链表的数组结构;
2. 对于随机访问来说,ArrayList比LinkedList要快,因为LinkedList还要移动指针;
3. 对于新增和删除操作来说,LinkedList比ArrayList要快,因为ArrayList要移动数据。

HashSet和TreeSet
---
1. HashSet是基于hash算法实现的,性能优于TreeSet(TreeSet是通过TreeMap实现的);
2. TreeSet是一个有序集合,默认按照自然顺序排序,需要实现Comparable接口,HashSet则是无序的;
(可以在创建TreeSet对象时传递一个比较器来实现自己的排序方式)
3. HashSet和TreeSet都没有get()方法,只能通过迭代器来获取元素;

HashMap和TreeMap
---
1. HashMap是基于哈希表实现的,TreeMap基于红黑树实现的;
2. HashMap适用于在Map中插入,删除和定位元素,TreeMap适用于有序遍历。

注意:在使用集合时,有经验的Java程序员一般都定义接口类而不是实现类,因为这样可用性更高。
对于下例中的两种情况,推荐使用第二种。
——example 1——
public ArrayList<String> prefixList( String prefixArrayList<String> strs) {
ArrayList<String> ret = new ArrayList<String>(strs.size());
for (String s: strs
     ret.add(prefix + s);

return ret
}  

——example 2——
public List<String> prefix( String prefixList<String> strs) {
List<String> ret = new ArrayList<String>(strs.size()); 

for (String s: strs)  
     ret.add(prefix + s); 
return ret;



12. Access Modifiers访问控制符
Java有3个访问控制的关键字:public,protected,private。

private是限制最强的,只有在同一个class才能访问;
protected是在private的基础上增加了给子类的访问权限;
public则是限制最低的,从任何地方都能访问。
另外,在没有用关键字修饰的时候,默认属于包访问控制权限,类似与C++中的friend关键字。


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值