当前位置:首页 » 编程语言 » java泛型参数

java泛型参数

发布时间: 2022-06-21 02:45:19

① 你真的了解java中的泛型E、T、K、V吗

Java 泛型(generics)是 JDK 5 中引入的一个新特性, 泛型提供了编译时类型安全检测机制,该机制允许开发者在编译时检测到非法的类型。泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。

但是如果换成其他的字母代替 T ,在可读性上可能会弱一些。通常情况下,T,E,K,V,?是这样约定的:?表示不确定的 java 类型。T (type) 表示具体的一个java类型。K V (key value) 分别代表java键值中的Key Value。E (element) 代表Element。

② java中什么叫泛型

泛就是广泛,泛指,型是数据类型. 在java中为了方便多种数据通用一个结构而引入了这个概念.
比如 class A<E> {}, 那么E就是一个泛型,它可以替换为任意类型.
class A<E> { E obj; }
在使用时, A<String>相当于定义了class A {String obj;}. A<Integer>相当于定义了class A{Integer obj;}
使用比如A<String> astr = new A<String>(); 那么astr.obj就是一个String

③ java泛型的参数问题

泛型和多态比较容易混淆, 简单来说:
泛型就是类型参数化, 好处是编译器会检查参数类型.
多态就是多个类由继承(实现接口)得到的一致外观, 好处是简化代码, 隔绝修改

实际上泛型和多态没有直接关系, 使用泛型在代码中就能按照指定类型的外观操作对象. 比较常用的泛型类型就是List<T>和Map<T, T>, 说个简单的例子吧:
List<String> list = ....; //具体类型, 就跟多态没什么关系了
for (String str : list) {
System.out.println(str.substring(1));
}

List<Animal> list = ...; //地球上但凡讲OO的都拿这个说事儿... 成员就是小猫小狗狮子老虎什么的
for (Animal animal : list) {
animal.say(); //喵, 汪....., 多态
}

④ java中的泛型 求详细解释

1、Java泛型
其实Java的泛型就是创建一个用类型作为参数的类。就象我们写类的方法一样,方法是这样的method(String str1,String str2 ),方法中参数str1、str2的值是可变的。而泛型也是一样的,这样写class Java_Generics<K,V>,这里边的K和V就象方法中的参数str1和str2,也是可变。下面看看例子:
//code list 1
import Java.util.Hashtable;
class TestGen0<K,V>{
public Hashtable<K,V> h=new Hashtable<K,V>();
public void put(K k, V v) {
h.put(k,v);
}
public V get(K k) {
return h.get(k);
}
public static void main(String args[]){
TestGen0<String,String> t=new TestGen0<String,String>();
t.put("key", "value");
String s=t.get("key");
System.out.println(s);
}
}
正确输出:value
这只是个例子(Java中集合框架都泛型化了,这里费了2遍事.),不过看看是不是创建一个用类型作为参数的类,参数是K,V,传入的“值”是String类型。这个类他没有特定的待处理型别,以前我们定义好了一个类,在输入输入参数有所固定,是什么型别的有要求,但是现在编写程序,完全可以不制定参数的类型,具体用的时候来确定,增加了程序的通用性,像是一个模板。
呵呵,类似C++的模板(类似)。
1.1. 泛型通配符
下面我们先看看这些程序:
//Code list 2
void TestGen0Medthod1(List l) {
for (Object o : l)
System.out.println(o);
}
看看这个方法有没有异议,这个方法会通过编译的,假如你传入String,就是这样List<String>。
接着我们调用它,问题就出现了,我们将一个List<String>当作List传给了方法,JVM会给我们一个警告,说这个破坏了类型安全,因为从List中返回的都是Object类型的,而让我们再看看下面的方法。
//Code list 3
void TestGen0Medthod1(List<String> l) {
for (Object o : l)
System.out.println(o);
}
因为这里的List<String>不是List<Object>的子类,不是String与Object的关系,就是说List<String>不隶属于list<Object>,他们不是继承关系,所以是不行的,这里的extends是表示限制的。
类型通配符是很神奇的,List<?>这个你能为他做什么呢?怎么都是“?”,它似乎不确定,他总不能返回一个?作为类型的数据吧,是啊他是不会返回一个“?”来问程序员的?JVM会做简单的思考的,看看代码吧,更直观些。
//code list 4
List<String> l1 = new ArrayList<String>();
li.add(“String”);
List<?> l2 = l1;
System.out.println(l1.get(0));
这段代码没问题的,l1.get(0)将返回一个Object。
1.2. 编写泛型类要注意:
1) 在定义一个泛型类的时候,在 “<>”之间定义形式类型参数,例如:“class TestGen<K,V>”,其中“K” , “V”不代表值,而是表示类型。
2) 实例化泛型对象的时候,一定要在类名后面指定类型参数的值(类型),一共要有两次书写。例如:
TestGen<String,String> t=new TestGen<String,String>();
3) 泛型中<K extends Object>,extends并不代表继承,它是类型范围限制。
2、泛型与数据类型转换
2.1. 消除类型转换
上面的例子大家看到什么了,数据类型转换的代码不见了。在以前我们经常要书写以下代码,如:
//code list 5
import Java.util.Hashtable;
class Test {
public static void main(String[] args) {
Hashtable h = new Hashtable();
h.put("key", "value");
String s = (String)h.get("key");
System.out.println(s);
}
}
这个我们做了类型转换,是不是感觉很烦的,并且强制类型转换会带来潜在的危险,系统可能会抛一个ClassCastException异常信息。在JDK5.0中我们完全可以这么做,如:
//code list 6
import Java.util.Hashtable;
class Test {
public static void main(String[] args) {
Hashtable<String,Integer> h = new Hashtable<String,Integer> ();
h.put("key", new Integer(123));
int s = h.get("key").intValue();
System.out.println(s);
}
}
这里我们使用泛化版本的HashMap,这样就不用我们来编写类型转换的代码了,类型转换的过程交给编译器来处理,是不是很方便,而且很安全。上面是String映射到String,也可以将Integer映射为String,只要写成HashTable<Integer,String> h=new HashTable<Integer,String>();h.get(new Integer(0))返回value。果然很方便。

⑤ java中泛型的使用

泛型可以避免强制类型转换,设定集合对象中存储的对象类型。
比如List<String> list = new ArrayList<String>();
那在这个list中,只能存储字符串对象。

⑥ 如何获取java泛型的参数类型

一般可以使用反射来获取泛型参数的实际类型,以下是详细代码:
import java.lang.reflect.Field;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.Map;

public class GenericTest {
/*使用反射来获取泛型信息*/
private Map<String, Integer> score;
public static void main(String[] args) throws SecurityException, NoSuchFieldException {
//Class clazz = GenericTest.class;
Class<GenericTest> clazz = GenericTest.class;
//System.out.println(clazz);
Field f = clazz.getDeclaredField("score");

//直接使用getType只对普通类型有效,无法取到泛型参数
Class<?> a = f.getType();
System.out.println("score的类型是:"+a);

//获得Field实例f的泛型类型
Type gType = f.getGenericType();
//如果gType类型是ParameterizedType的对象
if (gType instanceof ParameterizedType) {
ParameterizedType pType = (ParameterizedType) gType;
//获取原始类型
Type rType = pType.getRawType();
System.out.println("原始类型是:"+rType);
//取得泛型类型参数
Type[] tArgs = pType.getActualTypeArguments();
System.out.println("泛型类型是:");
for (int i = 0; i < tArgs.length; i++) {
System.out.println("第"+i+"个泛型类型是:"+tArgs[i]);
}
}else{
System.out.println("获取泛型类型出错!");
}
}
}
输出结果如下:
score的类型是:interface java.util.Map
原始类型是:interface java.util.Map
泛型类型是:
第0个泛型类型是:class java.lang.String
第1个泛型类型是:class java.lang.Integer

⑦ Java 泛型方法的入参参数如:id,如何id限制为String或者Number

首先,你要理解为什么使用集合框架:如果并不知道程序运行时会需要多少对象,或者需要更复杂方式存储对象—可以使用java集合框架。
其次,稍微理解一下泛型的机制:将对象的类型作为参数,指定到其它类或者方法上,从而保证类型转换的安全性和稳定性;本质是参数化类型;创建的集合只能存放<>中写的类型元素,不能存放别的类型的元素,因此取出元素时也就不需要强转了;泛型中不能存放基本数据类型等。
通俗的说,就是保证存入集合中的数据的安全性,例如,本来集合中可以存储各种数据类型的数据有int,string,char等等,只是存进去之后就自动变成Object类型的啦。现在用泛型的话,就是一种约束,即只能存放我们规定的数据类型的元素,如:
ArrayList<String> students = new ArrayList<String>();
现在在集合中只能存放String类型的参数了,此时你要传入的参数id就只能是String类型的啦。
ArrayList<Student>students = new ArrayList<Student>();
现在在集合中只能存放Studeng类型的参数了,存放其他数据类型时,就会出错,所以说保证了数据的安全性。
基本就这么多啦,可以多交流,相互帮助,希望可以帮到你呀!!!

⑧ JAVA 回调泛型参数应该怎么写

要么就这样public
class
Main
{
public
void
test()
public
void
handleCallBack()
{
new
CallBack()
.onFinish(new
Info());
}
public
interface
CallBack
;
public
class
Info
}必须要泛型指定的类型T
在方法内是可见的才能指定吧。。。不过这样写和你原本的意图应当不一样了。。。因为这样回调和定义必须写在一起
否则就不能指定泛型T的类型了。。。

⑨ java泛型的规则限制

1、泛型的类型参数只能是类类型(包括自定义类),不能是简单类型。
2、同一种泛型可以对应多个版本(因为参数类型是不确定的),不同版本的泛型类实例是不兼容的。
3、泛型的类型参数可以有多个。
4、泛型的参数类型可以使用extends语句,例如<T extends superclass>。习惯上称为“有界类型”。
5、泛型的参数类型还可以是通配符类型。例如Class<?> classType = Class.forName("java.lang.String");
泛型还有接口、方法等等,内容很多,需要花费一番功夫才能理解掌握并熟练应用。在此给出我曾经了解泛型时候写出的两个例子(根据看的印象写的),实现同样的功能,一个使用了泛型,一个没有使用,通过对比,可以很快学会泛型的应用,学会这个基本上学会了泛型70%的内容。
例子一:使用了泛型 classGen<T>{privateTob;//定义泛型成员变量publicGen(Tob){this.ob=ob;}publicTgetOb(){returnob;}publicvoidsetOb(Tob){this.ob=ob;}publicvoidshowType(){System.out.println("T的实际类型是:"+ob.getClass().getName());}}publicclassGenDemo{publicstaticvoidmain(String[]args){//定义泛型类Gen的一个Integer版本Gen<Integer>intOb=newGen<Integer>(88);intOb.showType();inti=intOb.getOb();System.out.println("value="+i);System.out.println("----------------------------------");//定义泛型类Gen的一个String版本Gen<String>strOb=newGen<String>("HelloGen!");strOb.showType();Strings=strOb.getOb();System.out.println("value="+s);}}例子二:没有使用泛型 classGen2{privateObjectob;//定义一个通用类型成员publicGen2(Objectob){this.ob=ob;}publicObjectgetOb(){returnob;}publicvoidsetOb(Objectob){this.ob=ob;}publicvoidshowTyep(){System.out.println("T的实际类型是:"+ob.getClass().getName());}}publicclassGenDemo2{publicstaticvoidmain(String[]args){//定义类Gen2的一个Integer版本Gen2intOb=newGen2(newInteger(88));intOb.showTyep();inti=(Integer)intOb.getOb();System.out.println("value="+i);System.out.println("---------------------------------");//定义类Gen2的一个String版本Gen2strOb=newGen2("HelloGen!");strOb.showTyep();Strings=(String)strOb.getOb();System.out.println("value="+s);}}运行结果:
两个例子运行Demo结果是相同的,控制台输出结果如下:
T的实际类型是:
java.lang.Integer
value= 88
----------------------------------
T的实际类型是: java.lang.String
value= Hello Gen!
Process finished with exit code 0
看明白这个,以后基本的泛型应用和代码阅读就不成问题了。

热点内容
c语言中的void是什么意思 发布:2025-02-06 04:05:26 浏览:233
加密狗是啥 发布:2025-02-06 03:48:03 浏览:552
phpcopy文件 发布:2025-02-06 03:41:26 浏览:410
系统配置页面怎么设置 发布:2025-02-06 03:36:34 浏览:693
家庭电脑搭建流媒体服务器 发布:2025-02-06 03:19:02 浏览:342
matlab稀疏矩阵存储 发布:2025-02-06 03:07:54 浏览:838
国际服2b2t服务器地址 发布:2025-02-06 03:06:28 浏览:390
c语言输出b 发布:2025-02-06 03:06:27 浏览:31
普通火车wifi密码多少 发布:2025-02-06 03:04:20 浏览:436
可编程监控 发布:2025-02-06 03:03:33 浏览:645