java笔记:遍历集合,迭代器,泛型

1、遍历集合时(线性表)  
  1)不要添加元素进去
  2)不要删除元素
2.如果真有删除元素的需求 用迭代器实现

迭代器有两个作用:
1、为了统一接口的遍历方式:
   顺序表 还是 链表,遍历方式都是一致的,用户不需要关系内部
实现 (封装性)

泛型(Generic)
泛型出现的原因: 
   为了解决类似顺序表这样的结构,支持通用类型元素类型
                                                                             泛型
  1、泛型诞生的意义
      顺序表本身是一种抽象数据类型,保存的数据不只是int类型。如果没有泛型的支持,我们必须为每一种要保存的类型定义一个顺序表类
   为了解决这个问题:
  第一阶段:  1) Object 是所有类的基类,Object引用,可以指向任何类的对象
   class ArrayList{
        Object[] array;
        int size;
}
                     2)多态:基类的引用可以指向任何子类的对象
   这种解决方案,无法在编译期间快速找出一些问题
  ArrayList list=new ArrayList();
  list.add(new Person());
  String s=(String)list.get(0);
//list第0个下标处,实际的对象类型是Person
  String引用无法指向这个对象,运行期间会抛出异常ClassCastException
前提:错误越早发现越好
  1、写代码的时候IDEA用~提示错误
  2、编译器间javac报错
  3、运行期间去报错

为了让错误尽可能在编译期间出现,引入泛型
1、泛型类
  定义泛型类  .
 class ArrayList<类型变量形参 Type Variable Paramter>{}
class ArraList<E>{
   E[] array;
   int size;           
}
类型变量实参  Type Variable Argument
使用泛型类  new ArrayList<String>();

1、嵌套
ArrayList<String>p=....;
ArrayList<>    q=.....;   q的元素类型期望是ArrayList<String><ArrayList<ArrayList<String>> q;
Set<Map.Entry<String,String>>
2、类型推导 Type Inferer
ArrayList<String> p=new ArrayList<>();
p.add(new Person());
String s=(String)p.get(0);//这里编译错误
 
class ArrayList<E>{
   E[] array;   =>  Object[] array;
   int size;
}

泛型是编译期间的魔法
类的字节码就没有泛型了,运行期间更没有

ArrayList<String> list;
ArrayList<Person> plist;

 

包装类和自动装箱+自动拆箱
顺序表,里面的元素类型是int,怎么办?
class ArrayList{
   Object[] array;
   int size;
}
ArrayList<int>
int i=10;   Integer ii=new Integer(i);
ArrayList<Integer>
   

基本数据类型                  包装类
float                              java.lang.Float
double                          java.lang.Double
int                                 java.lang.Iteger
short                             java.lang.Short
byte                              java.lang.Byte
long                              java.lang.Long
char                              java.lang.Character
boolean                        java.lang.Boolean
int i=10;Integer ii=new Integer(i);
int binarySearch(int[] a,int v){}

Integer v;
binarySearch(a[],v.intValue());
//自动装箱(autobox)  自动拆箱(autounbox)
//只发生在编译期间的魔法

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值