Java泛型(来就有分)解决办法
Java泛型(来就有分)请各位高手具体的给我讲下Java中各泛型的相同于却别,尽量具体[解决办法]1、泛型的类型参
Java泛型(来就有分) 请各位高手具体的给我讲下Java中各泛型的相同于却别,尽量具体[解决办法] 1、泛型的类型参数只能是类类型(包括自定义类),不能是简单类型。 2、同一种泛型可以对应多个版本(因为参数类型是不确定的),不同版本的泛型类实例是不兼容的。 3、泛型的类型参数可以有多个。 4、泛型的参数类型可以使用extends语句,例如<T extends superclass>。习惯上称为“有界类型”。 5、泛型的参数类型还可以是通配符类型。例如Class<?> classType = Class.forName(java.lang.String);[解决办法] 我来了给分吧![解决办法] 举个例子吧 有一个篮子工厂,负责生产篮子,但是这个篮子将来是用来做什么的,在设计它的时候并不能确定,有可能是装水果的,也有可能是装馒头的 实际上用的时候,你跟厂家说,我要水果篮子,于是厂家就生产水果篮子,但并不是重新设计制造,而只是在制造的时候把你的要求给记录下来,比如生产出来的篮子只能放你规定的东西,如水果,放其他的就不行,取出来的也是水果,如此这般![解决办法] 泛型就是泛型 哪有各种泛型。。 容器里经常用到泛型用<>包含着。 如:
Java code //此容器只能装字符串。 ArrayList<String> array = new ArrayList<String>(); Integer i = new Integer(123); array.add(i);//Error,不能将Integer类型装入容器中 String s = "123456"; array.add(s);//只能装入String类型 //个人觉得泛型是将错误提前到编译期间 而不是让错误在运行时产生[解决办法] 不如找本Thinking in java自己看效率高~[解决办法] 路过接分帮楼主实现承诺[解决办法] 学习学习[解决办法] 探讨 举个例子吧 有一个篮子工厂,负责生产篮子,但是这个篮子将来是用来做什么的,在设计它的时候并不能确定,有可能是装水果的,也有可能是装馒头的 实际上用的时候,你跟厂家说,我要水果篮子,于是厂家就生产水果篮子,但并不是重新设计制造,而只是在制造的时候把你的要求给记录下来,比如生产出来的篮子只能放你规定的东西,如水果,放其他的就不行,取出来的也是水果,如此这般![解决办法] 探讨 引用: 举个例子吧 有一个篮子工厂,负责生产篮子,但是这个篮子将来是用来做什么的,在设计它的时候并不能确定,有可能是装水果的,也有可能是装馒头的 实际上用的时候,你跟厂家说,我要水果篮子,于是厂家就生产水果篮子,但并不是重新设计制造,而只是在制造的时候把你的要求给记录下来,比如生产出来的篮子只能放你规定的东西,如水果,放其他的就不行,取出来的也是水果,如此这般……[解决办法] 太抽象了,帮顶吧[解决办法] Thinking in java的泛型讲解得相当深入!建议楼主去看看[解决办法] 我来了给点分。我也不清楚,学习了。[解决办法] 我来了给点分。我也不清楚,学习了。[解决办法] 探讨 举个例子吧 有一个篮子工厂,负责生产篮子,但是这个篮子将来是用来做什么的,在设计它的时候并不能确定,有可能是装水果的,也有可能是装馒头的 实际上用的时候,你跟厂家说,我要水果篮子,于是厂家就生产水果篮子,但并不是重新设计制造,而只是在制造的时候把你的要求给记录下来,比如生产出来的篮子只能放你规定的东西,如水果,放其他的就不行,取出来的也是水果,如此这般![解决办法] 泛型就是放你指定类型的,放其子类也可以 好像有向上或者向下的 一个概念 楼主查查![解决办法] 探讨 举个例子吧 有一个篮子工厂,负责生产篮子,但是这个篮子将来是用来做什么的,在设计它的时候并不能确定,有可能是装水果的,也有可能是装馒头的 实际上用的时候,你跟厂家说,我要水果篮子,于是厂家就生产水果篮子,但并不是重新设计制造,而只是在制造的时候把你的要求给记录下来,比如生产出来的篮子只能放你规定的东西,如水果,放其他的就不行,取出来的也是水果,如此这般![解决办法] 探讨 引用: 举个例子吧 有一个篮子工厂,负责生产篮子,但是这个篮子将来是用来做什么的,在设计它的时候并不能确定,有可能是装水果的,也有可能是装馒头的 实际上用的时候,你跟厂家说,我要水果篮子,于是厂家就生产水果篮子,但并不是重新设计制造,而只是在制造的时候把你的要求给记录下来,比如生产出来的篮子只能放你规定的东西,如水果,放其他的就不行,取出来的也是水果,如此这般……
[解决办法] 泛型是Java SE 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。 在Java SE 1.5之前,没有泛型的情况的下,通过对类型Object的引用来实现参数的“任意化”,“任意化”带来的缺点是要做显式的强制类型转换,而这种转换是要求开发者对实际参数类型可以预知的情况下进行的。对于强制类型转换错误的情况,编译器可能不提示错误,在运行的时候才出现异常,这是一个安全隐患。 Java语言引入泛型的好处是安全简单。泛型的好处是在编译的时候检查类型安全,并且所有的强制转换都是自动和隐式的,提高代码的重用率。 泛型在使用中还有一些规则和限制: 1、泛型的类型参数只能是类类型(包括自定义类),不能是简单类型。 2、同一种泛型可以对应多个版本(因为参数类型是不确定的),不同版本的泛型类实例是不兼容的。 3、泛型的类型参数可以有多个。 4、泛型的参数类型可以使用extends语句,例如<T extends superclass>。习惯上成为“有界类型”。 5、泛型的参数类型还可以是通配符类型。例如Class<?> classType = Class.forName(Java.lang.String); 泛型还有接口、方法等等,内容很多,需要花费一番功夫才能理解掌握并熟练应用。在此给出我曾经了解泛型时候写出的两个例子(根据看的印象写的),实现同样的功能,一个使用了泛型,一个没有使用,通过对比,可以很快学会泛型的应用,学会这个基本上学会了泛型70%的内容。 例子一:使用了泛型 public class Gen<T> { private T ob; //定义泛型成员变量 public Gen(T ob) { this.ob = ob; } public T getOb() { return ob; } public void setOb(T ob) { this.ob = ob; } public void showTyep() { System.out.println("T的实际类型是: " + ob.getClass().getName()); } } public class GenDemo { public static void main(String[] args){ //定义泛型类Gen的一个Integer版本 Gen<Integer> intOb=new Gen<Integer>(88); intOb.showTyep(); int i= intOb.getOb(); System.out.println("value= " + i); System.out.println("----------------------------------"); //定义泛型类Gen的一个String版本 Gen<String> strOb=new Gen<String>("Hello Gen!"); strOb.showTyep(); String s=strOb.getOb(); System.out.println("value= " + s); } } 例子二:没有使用泛型 public class Gen2 { private Object ob; //定义一个通用类型成员 public Gen2(Object ob) { this.ob = ob; } public Object getOb() { return ob; } public void setOb(Object ob) { this.ob = ob; } public void showTyep() { System.out.println("T的实际类型是: " + ob.getClass().getName()); } } public class GenDemo2 { public static void main(String[] args) { //定义类Gen2的一个Integer版本 Gen2 intOb = new Gen2(new Integer(88)); intOb.showTyep(); int i = (Integer) intOb.getOb(); System.out.println("value= " + i); System.out.println("----------------------------------"); //定义类Gen2的一个String版本 Gen2 strOb = new Gen2("Hello Gen!"); strOb.showTyep(); String s = (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 看明白这个,以后基本的泛型应用和代码阅读就不成问题了 我刚刚学,就知道这么点儿。。。。。。 有什么不对的大家多多指教啊( ⊙ o ⊙ )啊![解决办法] 学习学习[解决办法] C++的模板了解吗? 泛型其实就是java的模板-template[解决办法] 探讨 引用: 引用: 举个例子吧 有一个篮子工厂,负责生产篮子,但是这个篮子将来是用来做什么的,在设计它的时候并不能确定,有可能是装水果的,也有可能是装馒头的 实际上用的时候,你跟厂家说,我要水果篮子,于是厂家就生产水果篮子,但并不是重新设计制造,而只是在制造的时候把你的要求给记录下来,比如生产出来的篮子只能放你规定的东西,如水果……[解决办法] Java 中的泛型其实就是参考了C++里面的模板技术。[解决办法] 道理我就不说了,直接给个例子看看吧Java code
package main;import java.lang.reflect.Field;import java.lang.reflect.ParameterizedType;import java.lang.reflect.Type;import java.util.Map;/** * 仅用于帮助理解Java中的五个TYPE * @author Administrator * * @param <E> */public class TypePojo<E> { private int primitive_type; private Map<String, ? extends Integer> parameterized_type; private E type_variable; private E[] array_type; public static void main(String[] args) { Class pojoClass = TypePojo.class; try { // get primitive type System.out.println("get primitive type-->"); Field primitive_type_field = pojoClass.getDeclaredField("primitive_type"); Type primitive_type = primitive_type_field.getGenericType(); System.out.println("Type Class: " + primitive_type.getClass() + " Type: " + primitive_type); // get parameterized type System.out.println("\nget parameterized type-->"); Field parameterized_type_field = pojoClass.getDeclaredField("parameterized_type"); Type parameterized_type = parameterized_type_field.getGenericType(); System.out.println("Type Class: " + parameterized_type.getClass() + " Type: " + parameterized_type); // get WildcardType System.out.println("get actual types-->"); ParameterizedType real_parameterized_type = (ParameterizedType) parameterized_type; Type[] actualTypes = real_parameterized_type.getActualTypeArguments(); for (Type type : actualTypes) { System.out.println("Type Class: " + type.getClass() + " Type: " + type); } // get type variables System.out.println("\nget type variables-->"); Field type_variable_field = pojoClass.getDeclaredField("type_variable"); Type type_variable = type_variable_field.getGenericType(); System.out.println("Type Class: " + type_variable.getClass() + " Type: " + type_variable); // get array type System.out.println("\nget array type-->"); Field array_type_field = pojoClass.getDeclaredField("array_type"); Type array_type = array_type_field.getGenericType(); System.out.println("Type Class: " + array_type.getClass() + " Type: " + array_type); } catch (SecurityException e) { e.printStackTrace(); } catch (NoSuchFieldException e) { e.printStackTrace(); } }}[解决办法] 来接分的。。。。[解决办法] 探讨 路过接分帮楼主实现承诺[解决办法] List<?> ss = new List<?>(); ?你想放啥类型就放啥类型,这就叫泛型[解决办法] 泛型就是放你指定类型的,放其子类也可以[解决办法] 接分,帮顶。。[解决办法] 我学习学习顶起。。。[解决办法] 其实最早没引入泛型的时候,就只不过相当于List<Object>这样的形式罢了。 现在只不过把Object换成自己订制的Class而已[解决办法] 学习知识还拿分,LZ真好人yeah[解决办法] 就是提前规定盒子里放什么东西------解决方案--------------------
接分,学习![解决办法] 前面的人扯了那么多了,我就不扯了,接分[解决办法] 探讨 引用: 引用: 举个例子吧 有一个篮子工厂,负责生产篮子,但是这个篮子将来是用来做什么的,在设计它的时候并不能确定,有可能是装水果的,也有可能是装馒头的 实际上用的时候,你跟厂家说,我要水果篮子,于是厂家就生产水果篮子,但并不是重新设计制造,而只是在制造的时候把你的要求给记录下来,比如生产出来的篮子只能放你规定的东……[解决办法] 来学习泛型类[解决办法] 探讨 举个例子吧 有一个篮子工厂,负责生产篮子,但是这个篮子将来是用来做什么的,在设计它的时候并不能确定,有可能是装水果的,也有可能是装馒头的 实际上用的时候,你跟厂家说,我要水果篮子,于是厂家就生产水果篮子,但并不是重新设计制造,而只是在制造的时候把你的要求给记录下来,比如生产出来的篮子只能放你规定的东西,如水果,放其他的就不行,取出来的也是水果,如此这般![解决办法] 泛型的确是一个类模板。具体可参考我的blog:java泛型。[解决办法] 其实在我觉得 蛮简单的建议多看看书,多写写代码[解决办法] 接分。[解决办法] 学习下,帮顶![解决办法] 我接分,呵呵。。。。。。。。。[解决办法] 我是来看的回复的....[解决办法] 抽象了 参数类型VS 类型参数 有什么区别啊??[解决办法] 接分的来了!!!!![解决办法] 一种多态的表现[解决办法] java引用泛型机制还是为了提高类的编译和执行效率,在没有以前要对某些集合进行匹配和转化,大大减慢了程序的运行效率,引用泛型完全解决了这个问题[解决办法] 简单的说 泛型就是用来表示一个不确定的类型的。把这个类型当参数。这是我的理解[解决办法] 能说明一下的不同就行:) List List<Object> List<? extends Object> List<?>[解决办法] 泛型的引入 大大提高了 代码可重用性 和 可读性[解决办法] 来了就有分 来了!!! 给分!!![解决办法] 多编一下就知道了。JDK5.0的新特性[解决办法] 有一分时一分,就怕分分没有啊![解决办法] 要深入学习还是看书,要多使用。其实大多在开发过程中用得到都比较简单。[解决办法] 我只是看见被推荐了才进来看看有没有什么好的需要学习, 结果,貌似就那么几个人针对问进行了答。 徒有其表的推荐 (以上不针对LZ与各位回答的朋友,只是单纯的质疑一下推荐而已,...而已而已。)