关闭

泛型第二遍

125人阅读 评论(0) 收藏 举报
分类:
泛型 的好处:
1. 把运行时出现 的问题提前至了编译时。
2. 避免了无谓的强制类型转换。

注意: 在泛型中没有多态的概念,两边的数据必须要一致。 或者是只写一边 的泛型类型。


推荐使用: 两边的数据类型都写上一致的。

泛型:

import java.util.ArrayList;

public class demo1 {
	public static void main(String[] args) {
		ArrayList<String> list=new ArrayList<String>();
		list.add("aa");
		list.add("bb");
		//list.add(12);
		for (int i = 0; i < list.size(); i++) {
			String str=list.get(i);
			System.out.println(str.toUpperCase());
		}
	}
}

泛型方法:

  当函数中使用了一个不明确的数据类型,那么在函数上就可以进行泛型的定义。

 

        public <泛型的声明> 返回值类型 函数名( 泛型 变量名 ){

        

        

         }

注意:
1. 在方法上的自定义泛型的具体数据类型是调用该方法的时候传入实参的时候确定的。
2. 自定义泛型使用的标识符只要符合标识符的命名规则即可。

public class demo2 {
	public static void main(String[] args) {
		Integer i=print(12);
		String str=print("abc");
		

	}
	public static <T> T print(T o){
		return o;
	}
}


泛型类:

泛型类的定义格式:

class 类名<声明自定义的泛型>{




注意的事项: 
1. 在类上自定义的泛型的具体数据类型是在创建对象的时候指定的。
2. 在类上自定义了泛型,如果创建该类的对象时没有指定泛型的具体类型,那么默认是Object类型。

//自定义泛型类
class Father<T>{
	private T t;
	public Father() {
		// TODO Auto-generated constructor stub
	}
	public Father(T t){
		super();
		this.t=t;
	}
	public void setT(T t) {
		this.t = t;
	}
	public T getT() {
		return t;
	}
}
//泛型类的继承方式1:子类也需要使用泛型
class Son1<T> extends Father<T>{
	
}
//泛型类的继承方式2:子类指定了具体的类型
class Son2 extends Father<String>{
	
}
//错误写法,父类上定义有泛型需要进行处理
/*class Son3 extends Father<T>{
	
}*/

public class demo3 {
	public static void main(String[] args) {
		
		//在类上自定义的泛型的具体数据类型是在创建对象的时候指定的。
		Father<String> f1=new Father<String>("jack");
		System.out.println(f1.getT());
		Father<Integer> f2=new Father<Integer>(20);
		System.out.println(f2.getT());
		
		
	}
}


泛型接口:


泛型接口的定义格式:

interface 接口名<声明自定义的泛型>{

}


在接口上自定义泛型要注意的事项:
1. 在接口上自定义泛型的具体数据类型是在实现该接口的时候指定的。
2. 如果一个接口自定义了泛型,在实现该接口的时候没有指定具体的数据类型,那么默认是Object数据类型。 

interface Inter<T>{
	void print(T t);
}
//实现不知为何类型时可以这样定义
class myInter<T> implements Inter<T>{
	@Override
	public void print(T t) {
		// TODO Auto-generated method stub
		System.out.println("myprint:"+t);
	}
}
//使用接口时明确具体类型。
class myInter2 implements Inter<String>{
	@Override
	public void print(String t) {
		// TODO Auto-generated method stub
		System.out.println("myprint2:"+t);
	}
}
public class demo4 {
	public static void main(String[] args) {
		myInter<String> str=new myInter<String>();
		str.print("泛型");
		myInter2 str2=new myInter2();
		str2.print("只能传字符串");
	}
}




0
0

猜你在找
【直播】机器学习&数据挖掘7周实训--韦玮
【套餐】系统集成项目管理工程师顺利通关--徐朋
【直播】3小时掌握Docker最佳实战-徐西宁
【套餐】机器学习系列套餐(算法+实战)--唐宇迪
【直播】计算机视觉原理及实战--屈教授
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之矩阵--黄博士
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之凸优化--马博士
【套餐】Javascript 设计模式实战--曾亮
查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:11447次
    • 积分:1040
    • 等级:
    • 排名:千里之外
    • 原创:97篇
    • 转载:3篇
    • 译文:0篇
    • 评论:0条