泛型

问题使用ArrayList的集合存储元素遍历的时候按照正常的操作出现了问题

泛型将明确的集合类型的工作推迟到了创建对象或者调用方法的时候属于一种参数化类型可以作为参数传递

例如:

// 创建集合对象

ArrayList <String> array = new ArrayList <String>();

泛型的好处

  1)将运行时期异常提前到了编译时期

2)优化了设计解决了黄色警告线问题

  3)避免了强制类型转换

泛型的引出可以提供程序的安全性!

泛型的应用在接口中类中方法上应用在集合中应用最多

1> 把泛型定义在类上提高程序安全性

public class ObjectTool<T> {

	private T obj ;
	
	public T getObj() {
		return obj ;
	}
	
	public void setObj(T obj) {
		this.obj = obj ;
	}
}
public class ObjectToolDemo {
	
	public static void main(String[] args) {
		
		//创建ObjectTool对象
		ObjectTool<String> ot = new ObjectTool<String>() ;
		
		//赋值
		ot.setObj(new String("高圆圆"));
		String s = ot.getObj() ;
		System.out.println("姓名是:"+s);
		
//		ot.setObj(new Integer(27)); 直接隐藏的问题解决了
		System.out.println("---------------");
		
		ObjectTool<Integer> ot2 = new ObjectTool<Integer>() ;
		ot2.setObj(new Integer(27));
//		ot2.setObj(new String("高圆圆"));
		Integer i = ot2.getObj() ;
		System.out.println("年龄是:"+i);
	}
}

 

 2> 泛型是可以在方法上定义的

例如:

public class ObjectTool{
	
	//泛型是可以在方法上定义的
	public <T> void show(T t) {
		System.out.println(t);
	}



3> 接口中泛型

public interface Inter<T> {

	//接口中变量是常量: public static final  int num ;
	
	public abstract void show() ; //抽象方法
	
	
}
//接口中泛型,子实现类的第一种情况,就是已经知道是什么类型了
//public class InterImpl implements Inter<String> {
//
// @Override
// public void show() {
// System.out.println("hello");
// }
//
//}




//第二种情况,就是不知道具体的类型是什么
public class InterImpl<T> implements Inter<T>{

@Override
public void show() {
System.out.println("hello");
}
}

 

泛型高级通配符

  <?>:代表任意类型对象类型或者任意的Java

<?扩展E>:向下限定,E 的子类或者E 这个类型

<?super E>:向上限定,E 及其他的父类

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值