泛型的理解和好处:
1.不能对加入到集合ArrayList中的数据类型进行约束(不安全)
2.遍历的时候,需要进行类型转换,如果集合中的数据量较大,对效率有影响
3.在类型声明或实例化时只要指定好需要的具体类型即可
4.泛型的作用是:可以在类型声明是通过一个标识类型中某个属性的类型,或者是某个方法的返回值的类型,或者是差数类型。
public class Application {
@SuppressWarnings({"all"})
public static void main(String[] args) {
Nerson<String> person = new Nerson<String>("100");
System.out.println(person.getS());
}
}
class Nerson<E>{
E s;
public Nerson(E s) {
this.s = s;
}
public E getS() {
return s;
}
public void setS(E s) {
this.s = s;
}
}


public class Application {
@SuppressWarnings({"all"})
public static void main(String[] args) {
//再给泛型指定具体类型后,可以传入该类型或者其子类类型
Pig<A> aPig = new Pig<A>(new A());
//因为我给定的泛型是A这里却用了B类的对象
//Pig<A> aPig1 = new Pig<A>(new B());
Pig<A> pig = new Pig<>(new B());
}
}
class A {};
class B extends A{};
class Pig<E> {
E e;
public Pig(E e) {
this.e = e;
}
}
自定义泛型
普通泛型的数组,不能初始化
静态方法中不能使用类型泛型
泛型类的类型,实在创建对象是确定的(因为创建对象时,需要指定确定类型)
如果在创建对象时,没有指定类型,默认为Object
/*
基本语法:
class 类名<T,R....>{//...表示可以有多个泛型
成员
}
*/
public class Application {
@SuppressWarnings({"all"})
public static void main(String[] args) {
}
}
class Tiger<T, R, M>{
String name;
R r;
M m;
T t;
public Tiger(String name, R r, M m, T t) {
this.name = name;
this.r = r;
this.m = m;
this.t = t;
//因为数组在new不能确定T的类型,就无法在内存开空间
T[] ts = new T[8];
}
//静态方法中不能使用类型泛型
public static void m1(M m){}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public R getR() {
return r;
}
public void setR(R r) {
this.r = r;
}
public M getM() {
return m;
}
public void setM(M m) {
this.m = m;
}
public T getT() {
return t;
}
public void setT(T t) {
this.t = t;
}
@Override
public String toString() {
return "Tiger{" +
"name='" + name + '/'' +
", r=" + r +
", m=" + m +
", t=" + t +
'}';
}
}
自定义泛型接口
在接口中静态成员不能使用泛型(这个和泛型类规定一样)
泛型接口的类型,在继承接口或者实现接口时确定
没有指定类型,默认为Object
基本语法
interface 接口名<T,R..>{
}
public class Application {
@SuppressWarnings({"all"})
public static void main(String[] args) {
}
}
//泛型接口的类型,在继承接口或者实现接口时确定
class aa implements IUsb<String,String>{
@Override
public String get(String i) {
return null;
}
@Override
public void hi(String s) {
}
@Override
public void run(String r1, String r2, String u1, String u2) {
}
}
//当我们去实现IA接口时,因为IA在继承IUsb接口,指定U为String R为Double
//在实现IUsb接口方法时,使用Sting替代U,使用Double替换R
class AA implements IA {
@Override
public Double get(String s) {
return null;
}
@Override
public void hi(Double aDouble) {
}
@Override
public void run(Double r1, Double r2, String u1, String u2) {
}
}
interface IUsb<U,R>{
int n = 10;
//普通方法中,可以这样使用
R get(U u);
void hi(R r);
void run(R r1, R r2, U u1,U u2);
//在jdk8中,可以在接口中使用默认方法,也可容易使用泛型
default R method(U u){
U name;
return null;
}
}
//让IA接口去继承TUsb接口
interface IA extends IUsb<String,Double>{
}
原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/275896.html