不然 泛型集合和ArrayList的装箱拆箱 常见的泛型类型 泛型类和泛型方法 泛型约束 泛型委托 ###泛型很难理解? 第一次接触泛型那还是在大二上学期的时候,那会是学c#面向对象的时候接触过泛型集合,但尴尬的是那会还没有“泛型”这个概念,仅仅只停留在泛型集合的使用。 2.创建泛型类,可在编译时创建类型安全的集合 3.避免装箱和拆箱操作降低性能,在大型集合中装箱和拆箱的影响非常大. 下面是一些基础的泛型类型 1.泛型类 class MyGenericClass<T> { //...... } 2.泛型接口 ,声明的时候还是和泛型类、泛型方法一样加个<坑> 站个坑,其实泛型委托使用的时候不是很多,要慎用。
> 四、泛型安全检查 五、完整代码示例 1、泛型类 / 方法 2、main 函数 一、泛型类用法 ---- 泛型类用法 : 使用时先声明泛型 , 如果不声明泛型 , 则表示该类的泛型是 Object getData2(T arg){ T data = arg; return data; } 指定泛型的方法 : 指定 泛型方法 的泛型类 , 泛型方法 的泛型声明 <String, Integer>getData2("Mouse"); 不指定泛型的方法 : 泛型方法 中 也可以不声明泛型类型 , 传入的参数是 泛型 T 类型 , 如果给传入参数设置 String 如果给传入参数设置 String , 隐含将泛型 T 设置为 String 类型 String data2 = student.getData2("Mouse"); 三、泛型通配符 <? = (String) student1.getData(); 四、泛型安全检查 ---- 注意下面 2 种泛型的用法 , 推荐使用第一种方法 ; // 泛型的安全检查
的性能 ; 二、泛型类 ---- 泛型类 : 在 类名后面 使用 <T> 声明泛型 , 则在该类中 , 可以使用该泛型类型 T 类型 ; 特别注意 , 该类中的 如下 2 个方法 不是 泛型方法 ---- 泛型方法 : 在方法的 返回值前 , 使用 <T> 声明泛型的方法 , 是泛型方法 ; 将某个类型作为参数传入 ; 泛型个数 : 该方法是泛型方法 , 且指定了 2 个泛型 , 泛型的个数可以有很多个 , 是将某个类型作为参数传入 * 方法指定泛型 , 写法如下 * * 该方法是泛型方法 * 方法指定了 2 个泛型 * return */ public <T, A> T getData2(T arg){ T data = arg; return data; } , 是将某个类型作为参数传入 * 方法指定泛型 , 写法如下 ; * * 该方法是泛型方法 * 方法指定了 2 个泛型 *
1.3 泛型定义(泛型类、泛型方法(泛型方法返回值是泛型的,泛型方法在普通类和泛型类里)): 1.4特点: 对于泛型特点(1)举个例子 : 没有使用泛型时的异常抛出 对于泛型特点(2)访问时不需要类型转换 (拆箱),举例子List list = new ArrayList(); 对于泛型特点(3)不同泛型之间不能相互赋值,举例 对于泛型特点(3)泛型不存在多态,举例 2.泛型类、泛型接口、泛型方法 不能存储基本类型int,double… 5.泛型擦除 5.1 泛型擦除概念: 5.2 由于泛型擦除出现的错误举例: ---- ---- 1.什么是泛型 1.1泛型概念: Java泛型是J2 SE1.5 定义一个泛型方法(不在泛型类里):publilc <T> void testMethod() { } 或定义一个返回值类型是泛型的方法(不在泛型类里): public <T> T testMethod2 (所以人家的真心不允许被辜负,就没多态了) 2.泛型类、泛型接口、泛型方法 2.1泛型类 语法:类名<T,……..> 举例: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
,默认为Object类型 2.泛型父类传入类型实参,子类既可以是泛型类,也可以不是 3.泛型父类传入类型实参,则子类必须是泛型类,且子类的类型形参列表必须包含父类的类型形参列表 泛型类的定义和实例化 = new test01<>(); gt2.sex ="男"; gt2.a("abc"); gt2.b(new String[]{"a","b","A"} ,那么子类在实例化的时候需要指定 static class SubGeneric2<e> extends test01<e>{ } 泛型类可以定义多个参数类型 ,不是带泛型的方法就是泛型方法,泛型方法有要求:这个方法的泛型参数类型要和当前类的泛型方法的泛型无关 换个角度:泛型方法对应的那个泛型参数类型和当前所在的这个类,是否为泛型类,泛型是啥,无关 泛型方法定义的时候 = new test02(); t2.a("1"); t2.b("abc"); } } 泛型参数存在继承的情况 前面两个引用类型,都可以赋值,为什么list不行?
文章目录 一、泛型类 二、泛型参数 三、泛型函数 四、多泛型参数 五、泛型类型约束 一、泛型类 ---- 定义一个 泛型类 , 将 泛型参数 T 放在 尖括号 <T> 中 , 该泛型参数放在 类名后 Student<Int> = Student(18) student2.log() } 执行结果 : item : Tom item : 18 二、泛型参数 ---- 通常情况下 , 泛型参数 Student<Int> = Student(18) println(student2.logT(student2.item)) } 执行结果 : item : Tom Tom item : Student<Int> = Student(18) println(student2.logT {true}) } 执行结果 : student 实例对象中 , 泛型 T 的实际类型是 String 类型 , 在 logT 中 泛型 R 的类型是 Double 类型 ; student2 实例对象中 , 泛型 T 的实际类型是 Int 类型 , 在 logT 中 泛型 R 的类型是 Boolean
= new ArrayList<String>().getClass(); System.out.println(a1 == a2); } } 如果仅凭直觉来看,该程序可能会输出 Java泛型是使用类型擦除来实现的。这表示在运行过程中任何和类型有关的信息都会被擦除,所有在运行中 ArrayList和ArrayList的具体信息都被擦除成它们的原生类型即ArrayList类型。 由于擦除机制,泛型不能用于显示地引用运行时类型的操作之中,例如转型、new表达式和instanceof操作。 若在泛型内部必须使用类型操作时,可以在运行时采用反射的方法将正在运行的类信息添加到泛型内部,这种方法称为补偿。 ."); } } public class TestF2<T> { Class<T> type; public TestF2(Class<T> type) {
泛型接口和泛型类 泛型接口的定义,public interface man<T>{...}。在接口名后面加上泛型类型参数T,这样就定义了一个泛型接口。 ? ,在类名后面加上泛型类型参数T,这样就定义了一个泛型类。 ? 泛型类 和泛型接口不同,类有构造器,并且构造器也可以使用泛型类型参数。 2.再看另一个问题,如果父类是泛型类型,如何定义子类? ? 泛型类的子类 如果将一个类定义为泛型类,那么在创建该泛型类的子类的时候不能将子类直接继承该泛型类,而是需要指定父类泛型的类型。 泛型提供了一个泛型通配符用于接收所有类型的泛型类型。 泛型的通配符 ? 通配符 泛型的通配符可以很好的解决所有泛型类型父类的问题,使用<?>来作为类或接口的泛型参数,这样就可以抽象出泛型类的父类。 在访问通配符泛型List<?>的时候,集合里的元素只能当做Object来访问,因为在定义的时候只是一个通配符,不是具体类型,所以不能进行类型转换只能作为Object访问。 2.不能使用add方法。
参考文章:Java 中的泛型(两万字超全详解)_java 泛型-CSDN博客 泛型绝对要注意的一点 在java中,我们无法直接实例化泛型的类型参数对象. 类型擦除 类型擦除的定义 在Java中,类型擦除是指在编译时期对泛型类型进行擦除,将泛型类型转换为原始类型。 1.当我们在创建一个 ArrayList< Integer > 泛型集合的时候,ArrayList 可以看作是演唱会场馆,而< T >就是场馆的验票系统,Integer 是验票系统设置的门票类型; 2. ,其内的所有泛型信息都会被擦除,并且类型参数 T 会被统一替换为其原始类型(默认是 Object 类,若有 extends 或者 super 则另外分析); 2.在泛型信息被擦除后,若还需要使用到对象相关的泛型信息 这是因为Java的泛型是在编译时期进行类型擦除的,即在运行时泛型信息被擦除,只保留原始类型,我们不清楚其原本的具体类型。因此,编译器不允许直接创建泛型对象。
泛型 Generic 泛型类 写一个泛型类 语法:类名 T就代表数据类型的占位符 运行的时候要表示一种引用类型,不可以是实际类型,同时可以写多个占位符,用逗号隔开即可。 使用泛型创建变量 还可以添加方法作为方法的参数 还可以使用泛型作为方法的返回值 需要注意 的是不同泛型对象不能相互 复制。 写一个泛型接口 是不能使用泛型创建 静态常量的,即不能new这个泛型。 由于接口是不能实例化的,所以需要写一个实现类。 在实现接口的时候必须在使用的 时候必须写清楚什么类。 联动泛型类和泛型接口。 泛型方法 如果是T那么就是就是返回T 类型的,void就不返回 就可以了。 泛型好处 泛型集合 参数化的类型、类型安全的集合,强制集合元素的类型必须一致。
简介 泛型是JDK 5引入的概念,泛型的引入主要是为了保证java中类型的安全性,有点像C++中的模板。 但是Java为了保证向下兼容性,它的泛型全部都是在编译期间实现的。 本文将会详细讲解泛型在java中的使用,以避免进入误区。 接下来我们考虑泛型的情况,List<Number> 是不是 List<Integer>的父类呢?很遗憾,并不是。 我们得出这样一个结论:泛型不是协变的。 为什么呢? >[10];List<String>[] list2 = new List<String>[10]; //compile error 泛型在使用中会遇到的问题 因为类型擦除的原因,List<String 所以我们在使用泛型时候的一些操作会遇到问题。 假如我们有一个泛型的类,类中有一个方法,方法的参数是泛型,我们想在这个方法中对泛型参数进行一个拷贝操作。
/ 创建泛型类对象 , 泛型类型设置为 int 类型 Cache<int> cache2 = Cache(); // 调用泛型方法时 , 传入的参数必须符合对应的泛型类型 // value2 = cache2.getCachedItem("age"); print("泛型测试, 类型整型, 获取的缓存内容为 ${value2}"); } } 打印结果 : I/flutter , 获取的缓存内容为 ${value}"); // 创建泛型类对象 , 泛型类型设置为 int 类型 Cache<int> cache2 = Cache(); // 调用泛型方法时 , 传入的参数必须符合对应的泛型类型 // 泛型约束 : 泛型使用时会进行类型检查约束 , 如果设置错误的类型 , 编译时报错 cache2.setCacheItem("age", 18 ); // 获取缓存内容 int value2 = cache2.getCachedItem("age"); print("泛型测试, 类型整型, 获取的缓存内容为 ${value2
泛型是为了解决方法逻辑相同,而数据类型不同造成的代码冗余问题。 1. 泛型方法 ? 为了能在一个方法里实现传入什么数据类型就返回什么数据类型,可以利用泛型将方法写成下面这样: ? 2. 泛型类 实现一个泛型类,List里面可以增加任意类型的数据,但是每次增加的数据类型必须统一。 ? 3. 泛型接口 实现数据缓存的功能:有文件缓存、和内存缓存。
本文首发于个人网站:Java中的泛型(二) 泛型可以应用于同一个类,该类可以针对多种类型使用,例如构建一个RedisTemplateService组件,用于处理当前应用中所有对象的缓存操作。 这篇文章主要介绍泛型应用于接口、方法和匿名内部类的一些知识点和使用案例,也包括《Java编程思想》中对应的练习题的解读。 泛型接口 泛型应用于接口,是工厂方法设计模式的一种应用。 在泛型中,基本类型无法作为类型参数,但是Java提供了自动打包和拆包的功能; 泛型方法 知识点总结 如果使用泛型方法可以取代将整个类(或接口)泛型化,那么就应该只使用泛型方法; static方法要使用泛型能力 在使用泛型类的时候,必须在创建对象的时候指定类型参数的值,但是在使用泛型方法时候,不必指明参数类型。 、泛型方法 本节练习用的代码:LearnJava
Go 泛型之泛型约束 目录 Go 泛型之泛型约束 一、引入 二、最宽松的约束:any 三、支持比较操作的内置约束:comparable 四、自定义约束 五、类型集合(type set) 六、简化版的约束形式 七、约束的类型推断 八、小结 一、引入 虽然泛型是开发人员表达“通用代码”的一种重要方式,但这并不意味着所有泛型代码对所有类型都适用。 2018 年 8 月由伊恩·泰勒和罗伯特·格瑞史莫主写的 Go 泛型第一版设计方案中,Go 引入了 contract 关键字来定义泛型类型参数的约束。 所以,在 Go 泛型版本中,interface 语法也得到了一些扩展,也正是这些扩展给那些刚刚入门 Go 泛型的 Go 开发者带来了一丝困惑,这也是约束被认为是 Go 泛型的一个难点的原因。 ,Go 泛型可以根据泛型函数的实参推断出类型实参。
一、实际类型 泛型的泛参可以使用实际类型。也就是类似于List<String>,直接指定泛型的类型。这时候泛型的表现最容易理解,输入和输出都为实际类型。 所以,不知道作者所说的we got (1)E(2)V(4)I(5)L(0)...是什么意思。可能是java某个老版本运行的结果。 我们可不想让(1)E(2)V(4)I(5)L(0)充满我们的代码。 2.上界通配符 上界通配符为”extends”,可以接受其指定类型或其子类作为泛参。其还有一种特殊的形式,可以指定其不仅要是指定类型的子类,而且还要实现某些接口。 在虚拟机看来,List<E>这个泛型类型只是普通的类型List而已,这种行为叫泛型擦除(Type Erasure)。 那么在Java中泛型是如何如何实现其目的的呢?Java的泛型充分利用了多态性。 并在相应的地方自动生成checkcast字节码进行类型检查和转换,这样就既可以实现泛型,又不需要在字节码层面的进行改动来支持泛型。这样的泛型叫做伪泛型。
EventArgs e) { MyClass<string, string> _MyClass = new MyClass<string, string>();//实例化泛型类 _MyDelegate = new MyDelegate<string, string>(DemoMethod);//实例化_MyClass的泛型委托 MessageBox.Show (_MyClass.GetValues("Jimmy's Book","Jimmy"));//此时编译器已经能确定参数的类型为String,进而通过委托调用泛型方法DemoMethod
= (Double)p.getX(); double y2 = (Double)p.getY(); System.out.println("x="+x2+",y="+y2 2、泛型的通配符? 3、泛型接口(重点) 在接口上用泛型,就是泛型接口。 4、泛型方法 若在一个方法使用了泛型,这个方法就称为泛型方法。 5、总结 1)泛型解决的问题就是向下转型所带来的安全隐患; 2)泛型的本质:类的属性或方法的参数可以由用户在使用时动态设置; 3)通配符?、? extends 类、? super 类。
2、泛型初体验:一个被举了无数次的栗子 List arrayList = new ArrayList(); arrayList.add("aaaa"); arrayList.add(100); for * 2)只有声明了<T>的方法才是泛型方法,泛型类中的使用了泛型的成员方法并不是泛型方法。 * 3)<T>表明该方法将使用泛型类型T,此时才可以在方法中使用泛型类型T。 list2.getClass()); } } 在这个例子中,我们定义了两个ArrayList数组,不过一个是ArrayList<String>泛型类型的,只能存储字符串;一个是ArrayList <Integer>泛型类型的,只能存储整数,最后,我们通过list1对象和list2对象的getClass()方法获取他们的类的信息,最后发现结果为true。 2、类型擦除后保留的原始类型 原始类型 就是擦除去了泛型信息,最后在字节码中的类型变量的真正类型,无论何时定义一个泛型,相应的原始类型都会被自动提供,类型变量擦除,并使用其限定类型(无限定的变量用Object
Student<Int> = Student(18) student2.log() } 执行结果 : item : Tom item : 18 二、泛型参数 ---- 通常情况下 , 泛型参数 Student<Int> = Student(18) student2.log() } 执行结果 : item : Tom item : 18 三、泛型函数 ---- 函数 的 参数 或 返回值 Student<Int> = Student(18) println(student2.logT(student2.item)) } 执行结果 : item : Tom Tom item : Student<Int> = Student(18) println(student2.logT {true}) } 执行结果 : student 实例对象中 , 泛型 T 的实际类型是 String 类型 , 在 logT 中 泛型 R 的类型是 Double 类型 ; student2 实例对象中 , 泛型 T 的实际类型是 Int 类型 , 在 logT 中 泛型 R 的类型是 Boolean