Java5范型研究

1、  java 范型的实现原理: Java 语言中的泛型基本上完全在编译器中实现,由编译器执行类型检查和类型推断,然后生成普通的非泛型的字节码。这种实现技术称为擦除( erasure )(编译器使用泛型类型信息保证类型安全,然后在生成字节码之前将其清除),所以说其实 java 的所谓的范型知识形式上的,仅仅是在编译期做了手脚,生成了一些标明范型的变量,应为这些都是编译期的行为,那么引用 buaawhl 的一句话就是说: java 只能支持 Field, Methodgeneric type 信息,这些信息存放在 class 文件的 contant pool 中,作为字符串常量出现,标志是 signature

2、  由于 Java 范型的实现采用的是 Erasure 方式,仅仅是在编译期进行检查,所以在运行过程中我们就不能进行范型的实例化,因为我们不知道到底要实例化什么类型的对象,与原来我们手动进行强制类型转换的一样,我们如果知道我们能够转换成什么对象,那么我们就可以将我们知道的类型的信息传递过去,也就是吧 XX.class 传递过去,这样 jvm 就知道我们要实例化什么样的对象了。
 

3、  原来 Class<T> 表示的是一个范型的 Class 类啊,为什么搞的像 List<T> 样式的范型声明呢?搞得我迷糊了好长时间,一致以为是一个类似容器的东西呢,这个语法感觉到有些奇怪,见笑了:),这个类一般用来接受 XX.class 返回的对象。

4、  要想在 java 中范型用得爽,还得配合使用反射才行啊。由于 Java 采用了擦拭法进行范型的支持,所以我们依旧不能在运行期获取到具体的类型的信息,而至能够在我们进行设计的时候对其类型信息进行指定,那么我们指定的类型的信息就可以存放在编译后生成的 class 文件中了,我们可以通过反射来获取到具体的存放的信息,要获取到动态的传入的信息就不行了。


如下所示:

定义一个超类:
 

 

1 ExpandedBlockStart.gif ContractedBlock.gif public   class  SuperClass < extends  Number >   dot.gif
2 ExpandedBlockEnd.gif}
 
3 None.gif

 

再定义一个子类: <o:p> </o:p>

<o:p> </o:p>

None.gif import  java.lang.reflect.ParameterizedType; 
None.gif
None.gif  
None.gif
ExpandedBlockStart.gifContractedBlock.gif
public   class  MyTest < T >   extends  SuperClass < Integer >   dot.gif
InBlock.gif
InBlock.gif    
private  Class clazz  =   null  ; 
InBlock.gif
ExpandedSubBlockStart.gifContractedSubBlock.gif    
public   void  printClassInf() dot.gif
InBlock.gif
InBlock.gif       System. out .println( 
this  .getClass().getName()); 
InBlock.gif
InBlock.gif       System. out .println( 
this  .getClass().getTypeParameters()[ 0 ].getName()); 
InBlock.gif
InBlock.gif       System. out .println( 
this  .getClass().getSuperclass().getTypeParameters()[ 0 ].getName()); 
InBlock.gif
InBlock.gif       clazz 
= (Class) ((ParameterizedType)  this  .getClass().getGenericSuperclass()).getActualTypeArguments()[ 0 ]; 
InBlock.gif
InBlock.gif       String out 
=  clazz .getName(); 
InBlock.gif
InBlock.gif       System. out .println(out); 
InBlock.gif
ExpandedSubBlockEnd.gif    }
 
InBlock.gif
ExpandedSubBlockStart.gifContractedSubBlock.gif    
public   static   void  main(String[] args) dot.gif
InBlock.gif
InBlock.gif       MyTest test 
=   new  MyTest < > (); 
InBlock.gif
InBlock.gif       test.printClassInf(); 
InBlock.gif
ExpandedSubBlockEnd.gif    }
 
InBlock.gif
ExpandedBlockEnd.gif}
 
None.gif
None.gif

 


那么我们只能够获得我们实现定义好的要传入到 SuperClass 类中的 Integer 类型的范型信息,而不能得到我们在程序中传入的 类的类型信息,因为 java 范型的信息不记录的实例中,仅仅在类中进行了记录(这点感觉 java 的范型还不够成熟,可能因为要向后兼容等原因吧)。

<o:p> </o:p>

参考资料:

http://www.duduwolf.com/wiki/2006/51.html

http://calvin.iteye.com/blog/33139    白衣的 SpringSide 中对范型使用的说明

http://www-128.ibm.com/developerworks/cn/java/j-jtp01255.html   Java 理论和实践关于范型的讲解

http://www.nirvanastudio.org/java/dont-repeat-the-dao.html   范型实现可重用 DAO 的文章

http://gceclub.sun.com.cn/Java_Docs/html/zh_CN/api/java/lang/reflect/ParameterizedType.html#getActualTypeArguments()

http://buaawhl.iteye.com/blog/22020   范型的实现原理,讲的比较清楚

<o:p> </o:p>

资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在 IT 领域,文档格式转换是常见需求,尤其在处理多种文件类型时。本文将聚焦于利用 Java 技术栈,尤其是 Apache POI 和 iTextPDF 库,实现 doc、xls(涵盖 Excel 2003 及 Excel 2007+)以及 txt、图片等格式文件向 PDF 的转换,并实现在线浏览功能。 先从 Apache POI 说起,它是一个强大的 Java 库,专注于处理 Microsoft Office 格式文件,比如 doc 和 xls。Apache POI 提供了 HSSF 和 XSSF 两个 API,其中 HSSF 用于读写老版本的 BIFF8 格式(Excel 97-2003),XSSF 则针对新的 XML 格式(Excel 2007+)。这两个 API 均具备读取和写入工作表、单元格、公式、样式等功能。读取 Excel 文件时,可通过创建 HSSFWorkbook 或 XSSFWorkbook 对象来打开相应格式的文件,进而遍历工作簿中的每个 Sheet,获取行和列数据。写入 Excel 文件时,创建新的 Workbook 对象,添加 Sheet、Row 和 Cell,即可构建新 Excel 文件。 再看 iTextPDF,它是一个用于生成和修改 PDF 文档的 Java 库,拥有丰富的 API。创建 PDF 文档时,借助 Document 对象,可定义页面尺寸、边距等属性来定制 PDF 外观。添加内容方面,可使用 Paragraph、List、Table 等元素将文本、列表和表格加入 PDF,图片可通过 Image 类加载插入。iTextPDF 支持多种字体和样式,可设置文本颜色、大小、样式等。此外,iTextPDF 的 TextRenderer 类能将 HTML
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值