Java笔记之泛型

版权声明:关注微信公众号:摸鱼科技资讯,联系我们 https://blog.csdn.net/qq_36949176/article/details/87903142

泛型:
    jdk1.5出现的安全机制。
    
好处:
    1,将运行时期的问题ClassCastException转到了编译时期。
    2,避免了强制转换的麻烦。

<>:什么时候用?当操作的引用数据类型不确定的时候。就使用<>。将要操作的引用数据类型传入即可.
   其实<>就是一个用于接收具体引用数据类型的参数范围。
   
在程序中,只要用到了带有<>的类或者接口,就要明确传入的具体引用数据类型 。

泛型技术是给编译器使用的技术,用于编译时期。确保了类型的安全。

运行时,会将泛型去掉,生成的class文件中是不带泛型的,这个称为泛型的擦除。
为什么擦除呢?因为为了兼容运行的类加载器。

泛型的补偿:在运行时,通过获取元素的类型进行转换动作。不用使用者在强制转换了。


泛型的通配符:? 未知类型。 

泛型的限定:
? extends E: 接收E类型或者E的子类型对象。上限
一般存储对象的时候用。比如 添加元素 addAll.

? super E: 接收E类型或者E的父类型对象。 下限。
一般取出对象的时候用。比如比较器。

自定义泛型类:

泛型类:

package change.bean;

public class Tool<Q> {
	private Q q;

	public Q getObject() {
		return q;
	}

	public void setObject(Q object) {
		this.q = object;
	}
	
}

Test类

package change;

import change.bean.Person;
import change.bean.Tool;

public class fanxin {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Tool<Person> t=new Tool<Person>();
		t.setObject(new Person());
		Person p=t.getObject();
	}

}

泛型定义在方法上

public <w> void  show(w str){
		System.out.println("show:"+str.toString());
	}

 当方法静态时,不能访问类上定义的泛型,如果静态方法使用泛型
只能将泛型定义在方法上

/*
	 * 当方法静态时,不能访问类上定义的泛型,如果静态方法使用泛型
	 * 只能讲泛型定义在方法上
	 */
	public static <Y> void Method(Y obj){
		System.out.println("method:"+obj);
	}

猜你喜欢

转载自blog.csdn.net/qq_36949176/article/details/87903142