A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 郭利超 高级黑马   /  2013-3-20 21:51  /  1138 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 郭利超 于 2013-3-21 08:14 编辑
  1. /*
  2. Collection
  3. |--List:元素是有序的,元素可以重复。因为该集合体系有索引。
  4. |--ArrayList:底层的数据结构使用的是数组结构。特点:查询速度很快。但是增删稍慢。线程不同步。
  5. |--LinkedList:底层使用的链表数据结构。特点:增删速度很快,查询稍慢。线程不同步。
  6. |--Vector:底层是数组数据结构。线程同步。被ArrayList替代了。因为效率低。


  7. |--Set:元素是无序,元素不可以重复。、


  8. List:
  9. 特有方法。凡是可以操作角标的方法都是该体系特有的方法。


  10. add(index,element);
  11. addAll(index,Collection);


  12. remove(index);


  13. set(index,element);

  14. get(index):
  15. subList(from,to);
  16. listIterator();
  17. int indexOf(obj):获取指定元素的位置。
  18. ListIterator listIterator();





  19. List集合特有的迭代器。ListIterator是Iterator的子接口。

  20. 在迭代时,不可以通过集合对象的方法操作集合中的元素。
  21. 因为会发生ConcurrentModificationException异常。

  22. 所以,在迭代器时,只能用迭代器的放过操作元素,可是Iterator方法是有限的,
  23. 只能对元素进行判断,取出,删除的操作,
  24. 如果想要其他的操作如添加,修改等,就需要使用其子接口,ListIterator。

  25. 该接口只能通过List集合的listIterator方法获取。

  26. */


  27. import java.util.*;
  28. class ListDemo
  29. {
  30. public static void sop(Object obj)
  31. {
  32. System.out.println(obj);
  33. }
  34. public static void method()
  35. {

  36. ArrayList al = new ArrayList();

  37. //添加元素
  38. al.add("java01");
  39. al.add("java02");
  40. al.add("java03");

  41. sop("原集合是:"+al);
  42. //在指定位置添加元素。
  43. al.add(1,"java09");

  44. //删除指定位置的元素。
  45. //al.remove(2);

  46. //修改元素。
  47. //al.set(2,"java007");

  48. //通过角标获取元素。
  49. sop("get(1):"+al.get(1));

  50. sop(al);

  51. //获取所有元素。
  52. for(int x=0; x<al.size(); x++)
  53. {
  54. System.out.println("al("+x+")="+al.get(x));
  55. }

  56. Iterator it = al.iterator();

  57. while(it.hasNext())
  58. {
  59. sop("next:"+it.next());
  60. }


  61. //通过indexOf获取对象的位置。
  62. sop("index="+al.indexOf("java02"));

  63. List sub = al.subList(1,3);

  64. sop("sub="+sub);
  65. }


  66. public static void main(String[] args)
  67. {

  68. //演示列表迭代器。
  69. ArrayList al = new ArrayList();

  70. //添加元素
  71. al.add("java01");
  72. al.add("java02");
  73. al.add("java03");

  74. sop(al);


  75. ListIterator li = al.listIterator();


  76. //sop("hasPrevious():"+li.hasPrevious());

  77. while(li.hasNext())
  78. {
  79. Object obj = li.next();

  80. if(obj.equals("java02"))
  81. //li.add("java009");
  82. li.set("java006");


  83. }

  84. while(li.hasPrevious())
  85. {
  86. sop("pre::"+li.previous());
  87. }
  88. //sop("hasNext():"+li.hasNext());
  89. //sop("hasPrevious():"+li.hasPrevious());


  90. sop(al);



  91. /*
  92. //在迭代过程中,准备添加或者删除元素。

  93. Iterator it = al.iterator();

  94. while(it.hasNext())
  95. {
  96. Object obj = it.next();

  97. if(obj.equals("java02"))
  98. //al.add("java008");
  99. it.remove();//将java02的引用从集合中删除了。

  100. sop("obj="+obj);


  101. }
  102. sop(al);
  103. */



  104. }
  105. }
复制代码
以上代码中为什么
while(li.hasNext())
{
Object obj = li.next();
while循环中 要用Object  别的可以吗 请举例 TKS

3 个回复

正序浏览
Iterator<E>是一个泛型类型的类,E next()方法返回的也是一个泛型类型,也就是说编译时期,编译器不并不能确定具体类型,
虽然说编译后会把泛型信息去掉,但实际的class文件中还会存泛型的信息,为了提高性能,编译器把class文件分为两部分,一部分是泛泛型信息,一部分是类的信息,
我想没有使用泛泛型时,为了提高代码的利用率,将Object作为形参,这样可以接收所有的类型的实参。

评分

参与人数 1技术分 +1 收起 理由
黄玉昆 + 1

查看全部评分

回复 使用道具 举报
Object 是上帝,是所有对象的父类,所以可以代表所有对象的类型,
而编译器是不知道你集合里面存放对象的类型的,所以取出时只能用Object 代表任意类型。
使用泛型就不用Object  ,用回对象本类型就可以了

评分

参与人数 1技术分 +1 收起 理由
黄玉昆 + 1

查看全部评分

回复 使用道具 举报
哎,技术分这么多...有点失水准的问题.
如果你学了泛型就会明白为什么用Object,第一是面向父类或接口编程,第二是因为专一类型会发生异常,因为你的集合里存的是字符,万一你硬把值赋给Person,就会出异常.你也可以这样String str=(String)li.next();

评分

参与人数 1技术分 +1 收起 理由
黄玉昆 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马