- 浏览: 325787 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
xuanyuanxiaoxue:
...
Android - LayoutInflater -
柴兴博:
不错 多谢
Android 悬浮Activity并可拖动(访悬浮歌词) -
di1984HIT:
写的很好,我收藏一下。
java之动态代理模式(JDK和cglib) -
chinacssnj:
待测试,明天测,测试的结果发给大家
网络开发上传文件到服务器 -
fx_199182:
...
Android之MediaPlayer
1.
Java集合类库中最重要的两个接口Collection<E>和Map<K,V>,其中Collection接口又再次划分为
List和Set两大子接口,List中可以包含重复的元素,Set中则不可以。以下列举出一些常用的集合实现类,他们均分别继承自这两个接口:
1) ArrayList: 一种可以动态增长和缩减的索引序列(动态数组,类似于C++中的vector);
2) LinkedList: 一种可以在任何位置进行高效的插入和删除操作的有序序列(类似于C++中list);
3) ArrayDeque: 一种用循环数组实现的双端队列(类似于C++中的deque);
4) HastSet:一种没有重复元素的无序集合(C++的标准库中并未提供hashset集合,但是Windows的VC和Linux平台下的gcc均各自提供了hashset容器);
5) TreeSet: 一种有序集(类似于C++中的set);
6) EnumSet: 一种包含枚举类型值的集;
7) LinkedHashSet: 一种可以记住元素插入次序的集,在其内部由LinkedList负责维护插入的次序,HashSet来维护Hash;
8) HashMap:一种存储键值对关联的数据结构(C++的标准库中并未提供hashmap集合,但是Windows的VC和Linux平台下的gcc均各自提供了hashmap容器);
9) TreeMap:一种键值有序排列的映射表(类似于C++中的map);
10) EnumMap:一种键值属于枚举类型的映射表;
11) LinkedHashMap:一种可以记住键值项插入次序的映射表;
2.
ArrayList:该集合的底层是通过动态数组来实现的,集合构造的时候可以指定一个初始容量,当插入的元素过多导致已有的容量不能容纳新元素是,其底
层数组的容量将自动增长原有容量的1.5
倍,这样会带来一定的空间浪费,但是为了避免经常扩张而带来的性能开销,只能是用空间换取时间了。如果在容器的中间添加或者删除一个元素都将会导致后面的
元素向后或向前移动一个位置,如果元素数量较多且该操作比较频繁,将会导致系统的性能降低,然而对于容器中元素的随机访问性能较好,以下为
ArrayList的常用示例代码:
1 public static void showIterator() { 2 ArrayList<String> list = new ArrayList<String>(); 3 list.add("Monday"); 4 list.add("Tuesdag"); 5 list.add("Wednesday"); 6 Iterator<String> iterator = null; 7 iterator = list.iterator(); 8 //while 9 while (iterator.hasNext()) { 10 String element = iterator.next(); 11 System.out.println(element); 12 } 13 //for 14 for (iterator = list.iterator(); iterator.hasNext();) { 15 String element = iterator.next(); 16 System.out.println(element); 17 } 18 //for each 19 for (String element : list) { 20 System.out.println(element); 21 } 22 } 23 24 public static void showSetAndGet() { 25 ArrayList<String> nums = new ArrayList<String>(); 26 nums.clear(); 27 nums.add("One"); 28 nums.add("Two"); 29 nums.add("Three"); 30 System.out.println(nums); 31 nums.set(0, "Uno"); 32 nums.set(1, "Dos"); 33 nums.set(2, "Tres"); 34 for (int i = 0; i < nums.size(); ++i) 35 System.out.println(nums.get(i)); 36 } 37 38 public static void showRemoveAndSize() { 39 ArrayList<String> al = new ArrayList<String>(); 40 System.out.println("Initial size of al: " + al.size()); 41 al.add("C"); 42 al.add("A"); 43 al.add("E"); 44 al.add("B"); 45 al.add(1, "A2"); 46 System.out.println("Size of al after additions: " + al.size()); 47 System.out.println("Contents of al: " + al); 48 al.remove("F"); 49 al.remove(2); 50 System.out.println("Size of al after deletions: " + al.size()); 51 System.out.println("Contents of al: " + al); 52 Iterator<String> it = al.iterator(); 53 //Notes:remove() must be called after next() 54 it.next(); 55 it.remove(); 56 System.out.println("Size of al after deletions: " + al.size()); 57 System.out.println("Contents of al: " + al); 58 } 59 60 public static void showSubListAndCopyToArray() { 61 ArrayList<String> arrayList = new ArrayList<String>(); 62 arrayList.add("1"); 63 arrayList.add("2"); 64 arrayList.add("3"); 65 arrayList.add("4"); 66 arrayList.add("5"); 67 List<String> lst = arrayList.subList(1, 3); 68 for (int i = 0; i < lst.size(); i++) 69 System.out.println(lst.get(i)); 70 // remove one element from sub list 71 String obj = lst.remove(0); 72 System.out.println(obj + " is removed"); 73 for (String str: arrayList) 74 System.out.println(str); 75 //get object array with normal method 76 Object[] objArray = arrayList.toArray(); 77 for (Object obj1 : objArray) 78 System.out.println(obj1); 79 //get object array with generic method 80 String[] strArray = arrayList.toArray(new String[0]); 81 for (String str : strArray) 82 System.out.println(str); 83 } 84 85 public static void showListIterator() { 86 ArrayList<String> aList = new ArrayList<String>(); 87 aList.add("1"); 88 aList.add("2"); 89 aList.add("3"); 90 aList.add("4"); 91 aList.add("5"); 92 93 ListIterator<String> listIterator = aList.listIterator(); 94 while (listIterator.hasNext()) { 95 System.out.println(listIterator.next()); 96 System.out.println("Previous: " + listIterator.previousIndex()); 97 System.out.println("Next: " + listIterator.nextIndex()); 98 } 99 while (listIterator.hasPrevious()) { 100 System.out.println(listIterator.previous()); 101 System.out.println("Previous: " + listIterator.previousIndex()); 102 System.out.println("Next: " + listIterator.nextIndex()); 103 } 104 listIterator = aList.listIterator(2); 105 listIterator.next(); 106 listIterator.set("100"); 107 listIterator.next(); 108 listIterator.remove(); 109 for (String str : aList) 110 System.out.println(str); 111 112 if (aList.contains("4")) 113 System.out.println("True"); 114 else 115 System.out.println("False"); 116 } 117 118 public static void showFillAndReplace() { 119 ArrayList<String> arrayList = new ArrayList<String>(); 120 arrayList.add("A"); 121 arrayList.add("B"); 122 arrayList.add("A"); 123 arrayList.add("C"); 124 arrayList.add("D"); 125 Collections.replaceAll(arrayList, "A", "Replace All"); 126 System.out.println(arrayList); 127 Collections.fill(arrayList, "REPLACED"); 128 System.out.println(arrayList); 129 } 130 131 public static void showCollectionOperation() { 132 List<String> colours = new ArrayList<String>(); 133 colours.add("red"); 134 colours.add("green"); 135 colours.add("blue"); 136 137 System.out.println(colours); 138 Collections.swap(colours, 0, 2); 139 System.out.println(colours); 140 141 Collections.reverse(colours); 142 System.out.println(colours); 143 144 Collections.sort(colours); 145 System.out.println(Arrays.toString(colours.toArray())); 146 Collections.sort(colours, Collections.reverseOrder()); 147 System.out.println(Arrays.toString(colours.toArray())); 148 149 int index = Collections.binarySearch(colours, "green"); 150 System.out.println("Element found at : " + index); 151 ArrayList<Integer> arrayList = new ArrayList<Integer>(); 152 arrayList.add(new Integer("3")); 153 arrayList.add(new Integer("1")); 154 arrayList.add(new Integer("8")); 155 arrayList.add(new Integer("3")); 156 arrayList.add(new Integer("5")); 157 System.out.println(Collections.min(arrayList)); 158 System.out.println(Collections.max(arrayList)); 159 } 160 161 public static void showMinMax() { 162 ArrayList<Integer> arrayList = new ArrayList<Integer>(); 163 arrayList.add(new Integer("3")); 164 arrayList.add(new Integer("1")); 165 arrayList.add(new Integer("8")); 166 arrayList.add(new Integer("3")); 167 arrayList.add(new Integer("5")); 168 System.out.println(Collections.min(arrayList)); 169 System.out.println(Collections.max(arrayList)); 170 } 171 172 public static void showSynchronizedList() { 173 ArrayList arrayList = new ArrayList(); 174 List list = Collections.synchronizedList(arrayList); 175 //list之后的并发操作将不再需要synchronized关键字来进行同步了。 176 } 转自:http://www.cnblogs.com/stephen-liu74/archive/2011/08/26/2155082.html
发表评论
-
java clone技术 浅谈
2011-10-23 14:58 8891.java里的clone分为: A:浅复制(浅克隆): ... -
java synchronized详解
2011-10-23 10:31 726记下来,很重要。 Java语言的关键字,当它用来修饰一 ... -
Java 多线程同步 锁机制与synchronized
2011-10-21 17:25 1361打个比方:一个object就像一个大房子,大门永远打开。房子里 ... -
Java多线程编程总结(转载)
2011-10-21 16:54 733http://www.blogjava.net/cmzy/ar ... -
java内部类的总结
2011-10-15 14:42 680从Java1.1开始引入 ... -
java中的io系统详解
2011-10-10 11:26 717参考:http://expert.iteye.com/blog ... -
Java代码编写的30条建议
2011-10-10 10:22 728(1) 类名首字母应该大写 ... -
Java中局部内部类可以访问它所在方法中定义的final修饰的局部变量的合理解释
2011-09-20 11:21 1277标题有点长,可能有点 ... -
六种异常处理的陋习
2011-09-19 14:42 683你觉得自己是一个Java专 ... -
Java中常见的异常
2011-09-19 14:05 921Java 中异常的分类 所有异常,都继承自 ... -
Java异常的分类 .
2011-09-18 21:52 7661. 异常机制 异 ... -
java数组反射
2011-09-13 17:35 2035数组反射 如果因为某种原因,您并不确定参数或对象是不是数组, ... -
Java中反射机制详解
2011-09-13 14:53 1219问题: 在运行时,对一个JAVA类,能否知道属性和方 ... -
java枚举之EnumSet and EnumMap
2011-09-12 20:17 2593一:EnumSet import java.util.*; ... -
java中获取日期函数应用
2011-09-10 17:11 831(1)String类型转换成日期(Date类型) Sim ... -
java 时间格式化问题
2011-09-10 17:05 976java 时间格式化问题 java.util.*; ... -
Java深度历险之Java泛型
2011-09-10 16:46 700Java泛型(generics)是JDK ... -
Comparable和Comparator接口
2011-09-06 13:13 741当需要排序的集合或数组不是单纯的数字型时,通常可以使用C ... -
Java对象初始化顺序
2011-09-06 10:56 1262前几天与fwb同学说起java笔试题,想起这个东西经常被考,重 ... -
全面接触Java集合框架
2011-09-05 23:33 851http://www.iteye.com/topic/1647 ...
相关推荐
超详细的Java面试题总结(三)之Java集合篇常见问题.docx
该文档主要详细总结了Java集合的相关知识,包括Collection和Map接口、Collection接口的子接口List和Set接口以及具体的实现类、存储原理等;Map接口的子接口HashMap、LinkedHashMap、TreeMap、Properties等
适合Java进阶集合篇,集合知识点详解
今天在网上搜索了一下,发现一篇关于java集合的博文,里面整理得非常好, 特意copy过来和大家分享一下
java集合体系结构完结篇-Map集合
学习收获:通过学习这篇文章,您可以对Java集合体系有完整的了解,对集合三大接口有细致的了解,能够掌握底层实现,开发中能够应用,面试中惊艳面试官。 适合人群:有编程基础和Java基础的小伙伴 适合场景:开发和...
整理了一下java基础的集合部分,有list,map,set等及其相关。
此篇文章是学习Java中的集合时自己总结的笔记,主要记录了集合的底层原理、List、Set、Queue等集合的特点、集合的实现类的特点以及各个实现类底层是原理。
本篇面试题集锦旨在帮助你更深入地了解Java集合框架的复杂概念和应用,以及如何准确解答与之相关的面试问题。通过这20道精心挑选的面试题和详细解析,你将能够在面试中脱颖而出,展现出对Java集合框架的熟练掌握和...
Java企业系列面试题(集合篇).docx
JAVA工程求职信集合7篇.doc
java中的常用的集合类,目前因为是第一篇文章只是作为测试使用
包含了JVM、java集合、多线程并发、java基础、spring生态原理、微服务、设计模式、NETTY与RPC、网络、日志、ZOOKEEPER、KAFKA、RABBITMQ、HBASE、MONGDB、CASSANDRA、负载均衡、数据库、一致性算法、java算法、数据...
Java企业系列面试题(集合篇).zip
非印影版版,全部都是文字,可再排版。...进阶篇主要介绍数据结构、高级GUI设计、多线程、集合架构、网络和Web程序 设计、算法效率和排序、MVC,以及高级Java数据库程序设计等方面的内容,循序渐进,可读性强。
进阶篇主要介绍线性表、栈、队列、集合 、映射表、排序、二叉查找树、AVL树、散列、图及及其应用、并行程序设计、网络、Java数据库程序设计以及JSF等内容。 本书可作为高等院校相关专业程序设计课程的基础教材,也可...
2022年java程序员辞职报告集合5篇.docx
2022年JAVA工程求职信集合9篇.docx