??xml version="1.0" encoding="utf-8" standalone="yes"?>亚洲av无码潮喷在线观看,国产亚洲老熟女视频,亚洲精品美女久久777777http://www.tkk7.com/liulu/category/14912.htmlOpen & Open <a title="Free Web Counter"><font color="red"><script src="http://fastwebcounter.com/secure.php?s=www.tkk7.com/liulu"></script>hits</font></a>zh-cnThu, 08 Mar 2007 06:58:36 GMTThu, 08 Mar 2007 06:58:36 GMT60抽象cd接口的区?/title><link>http://www.tkk7.com/liulu/archive/2007/03/08/102584.html</link><dc:creator>刘璐</dc:creator><author>刘璐</author><pubDate>Thu, 08 Mar 2007 05:27:00 GMT</pubDate><guid>http://www.tkk7.com/liulu/archive/2007/03/08/102584.html</guid><wfw:comment>http://www.tkk7.com/liulu/comments/102584.html</wfw:comment><comments>http://www.tkk7.com/liulu/archive/2007/03/08/102584.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.tkk7.com/liulu/comments/commentRss/102584.html</wfw:commentRss><trackback:ping>http://www.tkk7.com/liulu/services/trackbacks/102584.html</trackback:ping><description><![CDATA[ <span style="FONT-WEIGHT: 400"> <span id="jpldlff" class="unnamed4"> <font style="FONT-SIZE: 9pt">abstract class和interface是Java语言中对于抽象类定义q行支持的两U机Ӟ正是׃q两U机制的存在Q才赋予了Java强大的面向对象能力。abstract class和interface之间在对于抽象类定义的支持方面具有很大的怼性,甚至可以怺替换Q因此很多开发者在q行抽象cd义时对于abstract class和interface的选择昑־比较随意。其实,两者之间还是有很大的区别的Q对于它们的选择甚至反映出对于问题领域本质的理解、对于设计意囄理解是否正确、合理。本文将对它们之间的区别q行一番剖析,试图l开发者提供一个在二者之间进行选择的依据。 ?br /><br />理解抽象c ?br /><br />abstract class和interface在Java语言中都是用来进行抽象类Q本文中的抽象类q从abstract class译而来Q它表示的是一个抽象体Q而abstract class为Java语言中用于定义抽象类的一U方法,误者注意区分)定义的,那么什么是抽象c,使用抽象c能为我们带来什么好处呢Q ?br /><br />在面向对象的概念中,我们知道所有的对象都是通过cL描绘的,但是反过来却不是q样。ƈ不是所有的c都是用来描l对象的Q如果一个类中没有包含够的信息来描l一个具体的对象Q这Lcd是抽象类。抽象类往往用来表征我们在对问题领域q行分析、设计中得出的抽象概念,是对一pd看上M同,但是本质上相同的具体概念的抽象。比如:如果我们q行一个图形编辑Y件的开发,׃发现问题领域存在着圆、三角Şq样一些具体概念,它们是不同的Q但是它们又都属于Ş状这样一个概念,形状q个概念在问题领域是不存在的Q它是一个抽象概c正是因为抽象的概念在问题领域没有对应的具体概念Q所以用以表征抽象概늚抽象cL不能够实例化的。 ?br /><br />在面向对象领域,抽象cM要用来进行类型隐藏。我们可以构造出一个固定的一l行为的抽象描述Q但是这l行为却能够有Q意个可能的具体实现方式。这个抽象描q就是抽象类Q而这一lQ意个可能的具体实现则表现为所有可能的zcR模块可以操作一个抽象体。由于模块依赖于一个固定的抽象体,因此它可以是不允怿改的Q同Ӟ通过从这个抽象体zQ也可扩展此模块的行为功能。熟悉OCP的读者一定知道,Z能够实现面向对象设计的一个最核心的原则OCP(Open-Closed Principle)Q抽象类是其中的关键所在。 ?br /><br /><br />从语法定义层面看abstract class和interface  <br /><br />在语法层面,Java语言对于abstract class和interfacel出了不同的定义方式Q下面以定义一个名为Demo的抽象类Z来说明这U不同。 ?br /><br />使用abstract class的方式定义Demo抽象cȝ方式如下Q ?br /><br />abstract class Demo { ?br /> abstract void method1();  <br /> abstract void method2();  <br /> … ?br />} ?br /><br />使用interface的方式定义Demo抽象cȝ方式如下Q ?br /><br />interface Demo {  <br /> void method1();  <br /> void method2();  <br /> … ?br />}  <br /><br />在abstract class方式中,Demo可以有自q数据成员Q也可以有非abstarct的成员方法,而在interface方式的实CQDemo只能够有静态的不能被修改的数据成员Q也是必须是static final的,不过在interface中一般不定义数据成员Q,所有的成员Ҏ都是abstract的。从某种意义上说Qinterface是一U特DŞ式的abstract class。 ?br /><br />      从编E的角度来看Qabstract class和interface都可以用来实?design by contract"的思想。但是在具体的用上面还是有一些区别的。 ?br /><br />首先Qabstract class在Java语言中表C的是一U承关p,一个类只能使用一ơ承关pR但是,一个类却可以实现多个interface。也许,q是Java语言的设计者在考虑Java对于多重l承的支持方面的一U折中考虑吧。 ?br /><br />其次Q在abstract class的定义中Q我们可以赋予方法的默认行ؓ。但是在interface的定义中Q方法却不能拥有默认行ؓQؓ了绕q这个限Ӟ必须使用委托Q但是这会 增加一些复杂性,有时会造成很大的麻烦。 ?br /><br />在抽象类中不能定义默认行存在另一个比较严重的问题Q那是可能会造成l护上的ȝ。因为如果后来想修改cȝ界面Q一般通过abstract class或者interface来表C)以适应新的情况Q比如,d新的Ҏ或者给已用的方法中d新的参数Q时Q就会非常的ȝQ可能要p很多的时_对于zcd多的情况Q尤为如此)。但是如果界面是通过abstract class来实现的Q那么可能就只需要修改定义在abstract class中的默认行ؓ可以了。 ?br /><br />同样Q如果不能在抽象cM定义默认行ؓQ就会导致同LҎ实现出现在该抽象cȝ每一个派生类中,q反?one ruleQone place"原则Q造成代码重复Q同样不利于以后的维护。因此,在abstract class和interface间进行选择时要非常的小心。 ?br /><br /><br />从设计理念层面看abstract class和interface  <br /><br />上面主要从语法定义和~程的角度论qCabstract class和interface的区别,q些层面的区别是比较低层ơ的、非本质的。本节从另一个层面:abstract class和interface所反映出的设计理念Q来分析一下二者的区别。作者认为,从这个层面进行分析才能理解二者概늚本质所在。 ?br /><br />前面已经提到q,abstarct class在Java语言中体C一U承关p,要想使得l承关系合理Q父cdzcM间必d?is a"关系Q即父类和派生类在概忉|质上应该是相同的Q参考文献?〕中有关?is a"关系的大幅深入的论qͼ有兴的读者可以参考)。对于interface 来说则不Ӟq不要求interface的实现者和interface定义在概忉|质上是一致的Q仅仅是实现了interface定义的契U而已。ؓ了便于理解Q下面将通过一个简单的实例q行说明。 ?br /><br />考虑q样一个例子,假设在我们的问题领域中有一个关于Door的抽象概念,该Doorh执行两个动作open和closeQ此时我们可以通过abstract class或者interface来定义一个表C抽象概念的类型,定义方式分别如下所C:  <br /><br />使用abstract class方式定义DoorQ ?br /><br />abstract class Door {  <br /> abstract void open();  <br /> abstract void close()Q ?br />}  <br /><br />   <br />使用interface方式定义DoorQ ?br /><br /><br />interface Door {  <br /> void open();  <br /> void close();  <br />}  <br /><br />   <br />其他具体的Doorcd可以extends使用abstract class方式定义的Door或者implements使用interface方式定义的Door。看h好像使用abstract class和interface没有大的区别。 ?br /><br />如果现在要求Doorq要h报警的功能。我们该如何设计针对该例子的cȝ构呢Q在本例中,主要是ؓ了展Cabstract class和interface反映在设计理念上的区别,其他斚w无关的问题都做了化或者忽略)Q下面将|列出可能的解决ҎQƈ从设计理念层面对q些不同的方案进行分析。 ?br /><br />解决Ҏ一Q ?br /><br />单的在Door的定义中增加一个alarmҎQ如下:  <br /><br />abstract class Door {  <br /> abstract void open();  <br /> abstract void close()Q ?br /> abstract void alarm();  <br />}  <br /><br />   <br />或者 ?br /><br />interface Door {  <br /> void open();  <br /> void close();  <br /> void alarm();  <br />}  <br /><br />   <br />那么h报警功能的AlarmDoor的定义方式如下:  <br /><br />class AlarmDoor extends Door {  <br /> void open() { … }  <br /> void close() { … }  <br /> void alarm() { … }  <br />}  <br /><br />   <br />或者 ?br /><br />class AlarmDoor implements Door { ?br /> void open() { … }  <br /> void close() { … }  <br /> void alarm() { … }  <br />} ?br /><br />q种Ҏq反了面向对象设计中的一个核心原则ISPQInterface Segregation PricipleQ,在Door的定义中把Door概念本n固有的行为方法和另外一个概?报警?的行为方法؜在了一赗这样引L一个问题是那些仅仅依赖于Doorq个概念的模块会因ؓ"报警?q个概念的改变(比如Q修改alarmҎ的参敎ͼ而改变,反之依然。 ?br /><br />解决Ҏ二:  <br /><br />既然open、close和alarm属于两个不同的概念,ҎISP原则应该把它们分别定义在代表q两个概늚抽象cM。定义方式有Q这两个概念都用abstract class方式定义Q两个概念都使用interface方式定义Q一个概念用abstract class方式定义Q另一个概念用interface方式定义。 ?br /><br />昄Q由于Java语言不支持多重承,所以两个概念都使用abstract class方式定义是不可行的。后面两U方式都是可行的Q但是对于它们的选择却反映出对于问题领域中的概念本质的理解、对于设计意囄反映是否正确、合理。我们一一来分析、说明。 ?br /><br />如果两个概念都用interface方式来定义,那么反映出两个问题Q?、我们可能没有理解清楚问题领域,AlarmDoor在概忉|质上到底是Doorq是报警器?2、如果我们对于问题领域的理解没有问题Q比如:我们通过对于问题领域的分析发现AlarmDoor在概忉|质上和Door是一致的Q那么我们在实现时就没有能够正确的揭C我们的设计意图Q因为在q两个概늚定义上(均用interface方式定义Q反映不Zq含义。 ?br /><br />如果我们对于问题领域的理解是QAlarmDoor在概忉|质上是DoorQ同时它有具有报警的功能。我们该如何来设计、实现来明确的反映出我们的意思呢Q前面已l说q,abstract class在Java语言中表CZU承关p,而承关pd本质上是"is a"关系。所以对于Doorq个概念Q我们应该用abstarct class方式来定义。另外,AlarmDoor又具有报警功能,说明它又能够完成报警概念中定义的行ؓQ所以报警概念可以通过interface方式定义。如下所C:  <br /><br />abstract class Door {  <br /> abstract void open();  <br /> abstract void close()Q ?br />}  <br />interface Alarm {  <br /> void alarm();  <br />}  <br />class AlarmDoor extends Door implements Alarm {  <br /> void open() { … }  <br /> void close() { … }  <br />    void alarm() { … }  <br />}  <br /><br />   <br />q种实现方式基本上能够明的反映出我们对于问题领域的理解Q正的揭示我们的设计意图。其实abstract class表示的是"is a"关系Qinterface表示的是"like a"关系Q大家在选择时可以作Z个依据,当然q是建立在对问题领域的理解上的,比如Q如果我们认为AlarmDoor在概忉|质上是报警器Q同时又hDoor的功能,那么上述的定义方式就要反q来了?/font> </span> </span> <img src ="http://www.tkk7.com/liulu/aggbug/102584.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.tkk7.com/liulu/" target="_blank">刘璐</a> 2007-03-08 13:27 <a href="http://www.tkk7.com/liulu/archive/2007/03/08/102584.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>?J2EE开发之常用开源项目介l?/title><link>http://www.tkk7.com/liulu/archive/2006/12/28/90547.html</link><dc:creator>刘璐</dc:creator><author>刘璐</author><pubDate>Thu, 28 Dec 2006 09:36:00 GMT</pubDate><guid>http://www.tkk7.com/liulu/archive/2006/12/28/90547.html</guid><wfw:comment>http://www.tkk7.com/liulu/comments/90547.html</wfw:comment><comments>http://www.tkk7.com/liulu/archive/2006/12/28/90547.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.tkk7.com/liulu/comments/commentRss/90547.html</wfw:commentRss><trackback:ping>http://www.tkk7.com/liulu/services/trackbacks/90547.html</trackback:ping><description><![CDATA[ <div twffan="done">主要我所了解的J2EE开发的框架或开源项目做个介l?可以Ҏ需求选用适当的开源组件进行开?主要q是以Spring为核?也ȝ了一些以前web开发常用的开源工具和开源类?/div> <div twffan="done"> </div> <div twffan="done">1持久?</div> <div style="TEXT-INDENT: 21pt" twffan="done">1)Hibernate</div> <div style="TEXT-INDENT: 21pt" twffan="done">q个不用介绍?用的很频J?用的比较多的是映?包括l承映射和父子表映射</div> <div style="TEXT-INDENT: 21pt" twffan="done">对于DAO在这里介l个在它基础上开发的包bba96,目前最新版本是bba96 2.0它对Hibernateq行了封? 查询功能包括执行hsql或者sql查询/更新的方法,如果你要多层ơ逻辑的条件查询可以自q装QueryObject.可以参考它做HibernateDAO.也可以直接利用它</div> <div style="TEXT-INDENT: 21pt" twffan="done">2) iBATIS</div> <div style="TEXT-INDENT: 21pt" twffan="done">另一个ORM工具,Apache?没有Hibernate那么集成,自由度比较大</div> <div twffan="done">2:SpringMVC</div> <div twffan="done"> <span twffan="done">       </span>原理说明和快速入?</div> <div twffan="done"> <span twffan="done">       </span>配置文g?</div> <div style="TEXT-INDENT: 21pt" twffan="done">Spring的配|文仉认ؓWEB-INF/xxxx-servelet.xm其中xxx为web.xml中org.springframework.web.servlet.DispatcherServlet的servlet-name?/div> <div twffan="done"> <span twffan="done">       Action</span>分发:</div> <div style="TEXT-INDENT: 21pt" twffan="done">Spring按照配|文件定义的URLQMapping到具体Controllerc,再根据URL里的action= xxx或其他参敎ͼ利用反射调用Controller里对应的ActionҎ?/div> <div style="TEXT-INDENT: 21pt" twffan="done">输入数据l定:</div> <div style="TEXT-INDENT: 21pt" twffan="done">Spring提供Binder 通过名字的一一对应反射l定PojoQ也可以直接从request.getParameter()取数据?/div> <div style="TEXT-INDENT: 21pt" twffan="done">输入数据验证</div> <div style="TEXT-INDENT: 21pt" twffan="done">Sping 提供了Validator接口当然q可以用开源的Commons-Validaor支持最?/div> <div style="TEXT-INDENT: 21pt" twffan="done">Interceptor(拦截?</div> <div style="TEXT-INDENT: 21pt" twffan="done">Spring的拦截器提供接口需要自q?在这点不如WebWork做的?全面 </div> <div twffan="done"> <span twffan="done">       (</span>q里提一下WebWork和Struts的区别最主要的区别在于WebWork在徏立一个Action时是新New一个对象而Struts是SingleMoule所有的都承它的一个Action,所以根据项目需要合适的选择.)</div> <div twffan="done">3:View?/div> <div style="TEXT-INDENT: 21pt" twffan="done">1) 标签?JSP2.0/JSTL</div> <div style="TEXT-INDENT: 21pt" twffan="done">׃Webwork或Spring的标{实很有限,一般view层用JSTL标签,而且据说JSTL设计很好速度是所有标{中最快的使用h也很?/div> <div style="TEXT-INDENT: 21pt" twffan="done"> </div> <div style="TEXT-INDENT: 21pt" twffan="done">2) 富客L:DOJO Widgets, YUI(YahooUI),FCKEditor, Coolest日历控g</div> <div style="TEXT-INDENT: 21pt" twffan="done">Dojo主要提供Tree, Tab{富客户端控?可以用其q行辅助客户端开?/div> <div style="TEXT-INDENT: 21pt" twffan="done">YahooUI和DOJO一样它有自q一套javascript调试控制?主要支持ajax开发也有很多Tree,Table,Menu{富客户端控?/div> <div style="TEXT-INDENT: 21pt" twffan="done">FCKEditor 最行的文本编辑器</div> <div style="TEXT-INDENT: 21pt" twffan="done">Coolest日历控g 目前很多日历控g可用,集成在项目中也比较简?q个只是其中的一?界面不错的说..</div> <div style="TEXT-INDENT: 21pt" twffan="done"> </div> <div style="TEXT-INDENT: 21pt" twffan="done">3) JavaScript:Prototype.js</div> <div style="TEXT-INDENT: 21pt" twffan="done">Prototype.js作ؓjavascript的成功的开源框Ӟ装了很多好用的功能,通过它很Ҏ~写AJAX应用,现在AJAX技术逐渐成熟,框架资源比较丰富,比如YUI,DWR{等,也是因ؓJavaScript没有合适的调试工具,所以没有必要从零开始编写AJAX应用,个h认ؓ多用一些成熟的Ajax框架实现无刷新更新页面是不错的选择.</div> <div style="TEXT-INDENT: 21pt" twffan="done"> </div> <div style="TEXT-INDENT: 21pt" twffan="done">4)表格控g:Display Tag ,Extreme Table</div> <div style="TEXT-INDENT: 21pt" twffan="done">q两个的功能差不?都是View层表格的生成,界面也比较相?可以导出Excel,Pdf,对Spring支持很容?</div> <div style="TEXT-INDENT: 21pt" twffan="done">相比较而言比较推荐ExtremeTable,它的设计很好功能上比DisplayTag多一?支持Ajax,装了一些拦截器,而且最斚w的是在主wiki中有详细的中文用文?</div> <div style="TEXT-INDENT: 21pt" twffan="done"> </div> <div style="TEXT-INDENT: 21pt" twffan="done">5):OSCache</div> <div style="TEXT-INDENT: 21pt" twffan="done">OSCache是OpenSymphonyl织提供的一个J2EE架构中Web应用层的~存技术实现组?Cache是一U用于提高系l响应速度、改善系l运行性能的技术。尤其是在Web应用中,通过~存面的输出结果,可以很显著的改善pȝ的稳定性和q行性能?/div> <div style="TEXT-INDENT: 21pt" twffan="done">它主要用在处理短旉或一定时间内一些数据或面不会发生变化,或将一些不变的l计报表,~冲在内?可以充分的减L务器的压?防治负蝲q,快速重启服务器(通过盘~存).</div> <div style="TEXT-INDENT: 21pt" twffan="done"> </div> <div style="TEXT-INDENT: 21pt" twffan="done">6)SiteMesh</div> <div style="TEXT-INDENT: 21pt" twffan="done">sitemesh应用Decorator模式主要用于提高面的可l护性和复用性,其原理是用Filter截取request和response,把页面组件head,content,bannerl合Z个完整的视图。通常我们都是用include标签在每个jsp面中来不断的包含各Uheader, stylesheet, scripts and footerQ现在,在sitemesh的帮助下Q我们删掉他们轻松达到复合视图模?</div> <div style="TEXT-INDENT: 21pt" twffan="done">Sitemesh也是<span twffan="done"> OpenSymphony</span>的一个项目现在最q的版本?.2,目前OpenSymphony自从04q就没有更新的版本了..感觉它还是比较有创新的一U页面组装方? OpenSymphony开源组l的代码一般写的比较漂?可以改其源代码对自己的项目进行适配.</div> <div style="TEXT-INDENT: 21pt" twffan="done">试发现Sitemeshq存在一些问?比如中文问题,它的默认~码是iso-8859-1在用时候需要做一些改?</div> <div style="TEXT-INDENT: 21pt" twffan="done"> </div> <div style="TEXT-INDENT: 21pt" twffan="done">7)CSS,XHTML</div> <div style="TEXT-INDENT: 21pt" twffan="done">q个不用说了,遵@W3C标准的web面开?</div> <div style="TEXT-INDENT: 21pt" twffan="done"> </div> <div style="TEXT-INDENT: 21pt" twffan="done">8)分页标签: pager-tagliblg</div> <div style="TEXT-INDENT: 21pt" twffan="done">Pager-taglib 是一套分|{ֺQ可以灵zd实现多种不同风格的分导航页面,q且可以很好的与服务器分逻辑分离.使用h也比较简?</div> <div style="TEXT-INDENT: 21pt" twffan="done"> </div> <div style="TEXT-INDENT: 21pt" twffan="done">9)Form: Jodd Form taglib</div> <div style="TEXT-INDENT: 21pt" twffan="done">Jodd Form taglib使用比较?只要?lt;form>的头以<jodd:form bean= "mybean">包住</div> <div twffan="done">׃自动l定mybean, 自动l定mybean的所有同名属性到普通html标记input, selectbox, checkbox,radiobox.....在这些input框里不用再写M代码?/div> <div twffan="done"> <span twffan="done">       </span> </div> <div style="TEXT-INDENT: 21pt" twffan="done">10)Ajax:DWR</div> <div twffan="done"> <span twffan="done">       J2EE</span>应用最常用的ajax框架</div> <div twffan="done"> <span twffan="done">       </span> </div> <div twffan="done"> <span twffan="done">       11)</span>报表 图表</div> <div style="MARGIN-LEFT: 21pt" twffan="done">Eclipse BIRT功能比较强大,也很庞大..好几?span twffan="done">M,一般没有特别需求或别的图表设计软g可以解决的不用它</span></div> <div style="TEXT-INDENT: 21pt" twffan="done">JasperReports+ iReport是一个基于Java的开源报表工P它可以在Java环境下像其它IDE报表工具一h制作报表。JasperReports支持PDF、HTML、XLS、CSV和XML文g输出格式。JasperReports是当前Java开发者最常用的报表工兗?/div> <div style="TEXT-INDENT: 21pt" twffan="done">JFreeChart主要是用来制作各U各L图表Q这些图表包括:饼图、柱状图(普通柱状图以及堆栈q?、线图、区域图、分布图、؜合图、甘特图以及一些A表盘{等?/div> <div twffan="done"> <span twffan="done">      琴棋报表,国?.重点推荐,适合中国的情?开放源代码Q用完全免贏V纯JAVA开发,适用多种pȝq_。特别适合B/Sl构的系l。官方网站有其优点介l?看来用它q是不错的选择,最重要的是支持国呵呵</span> </div> <div twffan="done"> </div> <div twffan="done">4:权限控制: Acegi</div> <div style="TEXT-INDENT: 21pt" twffan="done">Acegi是Spring Framework 下最成熟的安全系l,它提供了强大灉|的企业安全服务Q如完善的认证和授权机制QHttp资源讉K控制QMethod 调用讉K控制{等,支持CAS</div> <div twffan="done">(耉大学的单点登陆技?q个单点登陆Ҏ比较出名.我也q行q配|?可以Ҏ目需?如果用户分布在不同的地方不同的系l通用一套登陆口令可以用它进行解?一般注册机登陆机就是这栯决的)</div> <div twffan="done"> <span twffan="done">       Acegi</span>只是于Springl合最好的安全框架,功能比较强大,当然q有一些其他的安全框架,q里列D一些比较流行的是我从网上找到的,使用Ҏ看其官方文档把?/div> <div style="TEXT-INDENT: 21pt" twffan="done">JAAS, Seraph, jSai - Servlet Security, Gabriel, JOSSO, Kasai, jPAM, OpenSAML都是些安全控制的框架..真够多的呵呵</div> <div twffan="done"> </div> <div twffan="done">5:全文?/div> <div twffan="done"> <span twffan="done">       1) Lucene</span> </div> <div twffan="done"> <span twffan="done">       Lucene</span>是一套全文烦引接?可以通过它将数据q行倒排文g处理加入索引文g,它的索引速度和查询速度是相当快?查询百万U数据毫U出结?现在最火的Apache开源项?版本更新速度很快现在已经C2.0,每个版本更新的都比较?目前用的最多的版本应该?.4.3,但它有个不太斚w的地方单个烦引文件有2G文g限制,现在2.0版本没有q个限制,我研I的比较?它的扩展性比较好,可以很方面的扩充其分词接口和查询接口.</div> <div twffan="done"> <span twffan="done">       </span>Z它的开发的pȝ很多,比如最常用的Eclipse的搜索功?q有一些开源的软g比如Compass,Nutch,Lius,q有我最q做的InSearch(企业UFTP文g|页搜烦)</div> <div twffan="done">6:公共Utilc?/div> <div twffan="done"> <span twffan="done">       </span>主要是Jakarta-Commonscd,其中最常用得是以下几个cd</div> <div style="TEXT-INDENT: 21pt" twffan="done">1) Jakarta-Commons-Language</div> <div style="TEXT-INDENT: 21pt" twffan="done"> <span twffan="done">       </span>最常用得类是StringUtilsc?提供了用的字符串处理的常用Ҏ效率比较?/div> <div style="TEXT-INDENT: 21pt" twffan="done">2) Jakarta-Commons-Beantuils</div> <div style="TEXT-INDENT: 21pt" twffan="done"> <span twffan="done">       </span>主要用Beantuils能够获得反射函数装及对嵌套属性,map,array型属性的d?/div> <div style="TEXT-INDENT: 21pt" twffan="done">3) Jakarta-Commons-Collections</div> <div style="TEXT-INDENT: 21pt" twffan="done"> <span twffan="done">       </span>里面有很多UtilsҎ</div> <div style="TEXT-INDENT: 21pt" twffan="done"> </div> <div twffan="done">7 日志理</div> <div twffan="done"> <span twffan="done">       Log4J</span> </div> <div twffan="done"> <span twffan="done">       </span>d是日志记?分ؓInfo,Warn,error几个层次可以更好的调试程?/div> <div twffan="done"> </div> <div twffan="done">8 开源的J2EE框架</div> <div twffan="done"> <span twffan="done">       1) Appfuse</span> </div> <div twffan="done"> <span twffan="done">              Appfuse</span>是Matt Raible 开发的一个指导性的入门UJ2EE框架, 它对如何集成行的Spring、Hibernate、iBatis、Struts、Xdcolet、JUnit{基框架l出了示? 在持久层QAppFuse采用了Hibernate O/R映射工具Q在容器斚wQ它采用了Spring,用户可以自由选择Struts、Spring/MVCQWebworkQJSFq几个Web框架?/div> <div twffan="done"> <span twffan="done">       </span> </div> <div twffan="done"> <span twffan="done">       2) SpringSide</span> </div> <div twffan="done"> <span twffan="done">       .SpringSide</span>较完整的演示了企业应用的各个斚w,是一个电子商务网站的应用 SpringSide也大量参考了Appfuse中的优秀l验。最重要的是它是国内的一个开源项?可以了解到国内现在的一些实际技术动态和方向很有指导意义?/div> <div twffan="done"> </div> <div twffan="done">9:模版 Template </div> <div style="TEXT-INDENT: 21pt" twffan="done">主要有Veloctiy和Freemarker</div> <div style="TEXT-INDENT: 21pt" twffan="done">模板用Servlet提供的数据动态地生成 HTML。编译器速度快,输出接近静态HTML<span twffan="done">             </span>面的速度?/div> <div style="TEXT-INDENT: 21pt" twffan="done"> </div> <div twffan="done">10:工作?/div> <div twffan="done"> <span twffan="done">       </span>我所知道比较出名的主要有JBpm Shark Osworkflow,׃对它没有q多的研I所以还不是很清楚之间有什么区?</div> <div twffan="done"> </div> <div twffan="done">目理软g</div> <div style="TEXT-INDENT: 21pt" twffan="done">dotProject:是一个基于LAMP的开源项目管理Y件。最出名的项目管理Y?/div> <div style="TEXT-INDENT: 21pt" twffan="done">JIRA: 目计划QQ务安排,错误理</div> <div style="TEXT-INDENT: 21pt" twffan="done">Bugzilla:提交和管理bug,和eclipse集成,可以通过安装MyEclipse配置一下即可?/div> <div style="MARGIN-LEFT: 52.5pt; TEXT-INDENT: -31.5pt" twffan="done">BugFree借鉴微Y公司软g研发理念、免费开放源代码、基于Web的精版Bug理</div> <div style="TEXT-INDENT: 21pt" twffan="done">CVS:q个׃介绍了都在用.</div> <div style="MARGIN-LEFT: 47.25pt; TEXT-INDENT: -26.25pt" twffan="done">SVN: SubVersion已逐渐越CVSQ更适应于JavaEE的项目。Apache用了它很久后QSourceforge刚刚推出SVN的支持?/div> <div style="MARGIN-LEFT: 47.25pt; TEXT-INDENT: -26.25pt" twffan="done">试用例:主要JUnit单元试,~写TestCase,Spring也对Junit做了很好的支?/div> <div twffan="done"> </div> <div twffan="done">后记:</div> <div twffan="done"> <span twffan="done">       </span>以SpringZ的应用开发可选用的组件中间g真是D~ؕ,所以针对不同的目需求可以利用不同的开源品解?比如用Spring+Hibernate/ iBATIS或Spring+WebWork+Hibernate/ iBATIS或Spring+Struts+Hibernate/ iBATIS,合理的框架设计和代码复用设计寚w目开发效率和E序性能有很大的提高,也有利于后期的维?</div> <img src ="http://www.tkk7.com/liulu/aggbug/90547.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.tkk7.com/liulu/" target="_blank">刘璐</a> 2006-12-28 17:36 <a href="http://www.tkk7.com/liulu/archive/2006/12/28/90547.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>JAVA断言使用http://www.tkk7.com/liulu/archive/2006/10/24/77005.html刘璐刘璐Tue, 24 Oct 2006 08:17:00 GMThttp://www.tkk7.com/liulu/archive/2006/10/24/77005.htmlhttp://www.tkk7.com/liulu/comments/77005.htmlhttp://www.tkk7.com/liulu/archive/2006/10/24/77005.html#Feedback0http://www.tkk7.com/liulu/comments/commentRss/77005.htmlhttp://www.tkk7.com/liulu/services/trackbacks/77005.html

断言概述


  ~写代码Ӟ我们L会做Z些假设,断言是用于在代码中捕捉q些假设
  可以断a看作?b>异常处理的一U高UŞ?/b>
  断言表示Z些布表辑ּQ程序员怿在程序中的某个特定点该表辑ּgؓ?br />  可以在Q何时候启用和用断言验证Q因此可以在试时启用断a而在部v时禁用断a。同PE序投入q行后,最l用户在遇到问题时可以重新v用断a?br />  使用断言可以创徏更稳定,品质更好且易于除错的代码
  当需要在一个gؓFALSE时中断当前操作的话,可以使用断言
  单元试必须使用断言QJunit/JunitXQ?br />  除了cd查和单元试外,断言q提供了一U确定个U特性是否在E序中得到维护的极好的方?br />  使用断言使我们向按契U式设计更近了一?br />

常见的断aҎ?/h3>
  前置条g断言Q代码执行之前必d备的Ҏ?br />  后置条g断言Q代码执行之后必d备的Ҏ?br />  前后不变断言Q代码执行前后不能变化的Ҏ?br />

断言使用方式


  断言可以有两UŞ?br />  1.assert Expression1
  2.assert Expression1:Expression2
  其中Expression1应该L一个布|Expression2是断ap|时输出的p|消息的字W串。如果Expression1为假Q则抛出一个 AssertionErrorQ这是一个错误,而不是一个异常,也就是说是一个不可控制异常(unchecked Exception),AssertionError׃是错误,所以可以不捕获Q但不推荐这样做Q因为那样会使你的系l进入不E_状态?br />

L断言


  断言在默认情况下是关闭的Q要在编译时启用断言Q需要用source1.4标记 既javac source1.4 Test.java ,在运行时启用断言需要用?ea参数 。要在系l类中启用和用断言可以使用 -esa 和?dsa参数?br />  
例如Q?br />public class AssertExampleOne{
   public AssertExampleOne(){}
   public static void main(String args[]){
      int x=10;
      System.out.println("Testing Assertion that x==100");
      assert x==100:"Out assertion failed!";
      System.out.println("Test passed!");
   }
}

如果~译时未加?source1.4,则编译通不q?br />在执行时未加 -ea 时输Zؓ
Testing Assertion that x==100
Test passed
jre忽略了断a的就代码Q而用了该参数就会输Zؓ
Testing Assertion that x==100
Exception in thread "main" java.lang.AssertionError: Out assertion failed!
        at AssertExampleOne.main(AssertExampleOne.java:6)

断言的副作用


  ׃E序员的问题Q断a的用可能会带来副作用 ,例如Q?br />  boolean isEnable=false;
  //...
  assert isEnable=true;
  q个断言的副作用是因为它修改了程序中变量的值ƈ且未抛出错误Q这L错误如果不细心的查是很难发现的。但是同时我们可以根据以上的副作用得C个有用的Ҏ,Ҏ它来试断言是否打开?br />
 public class AssertExampleTwo{

   public static void main(String args[]){
     boolean isEnable=false;
     //...
     assert isEnable=true;
     if(isEnable==false){
       throw new RuntimeException("Assertion shoule be enable!");
     }
   }
}

何时需要用断a


  1.可以在预计正常情况下E序不会到达的地Ҏ|断a Qassert false
  2.断言可以用于查传递给U有Ҏ的参数。(对于公有ҎQ因为是提供l外部的接口Q所以必dҎ中有相应的参数检验才能保证代码的健壮性)
  3.使用断言试Ҏ执行的前|条件和后置条g
  4.使用断言查类的不变状态,保M情况下,某个变量的状态必L뀂(如age属性应大于0于某个合适|

什么地方不要用断a


  断言语句不是永远会执行,可以屏蔽也可以启?br />因此Q?br />  1.不要使用断言作ؓ公共Ҏ的参数检查,公共Ҏ的参数永q都要执?br />  2.断言语句不可以有M边界效应Q不要用断a语句M改变量和改变Ҏ的返回?br />
参考:
http://jcp.org/en/jsr/detail?id=41
http://java.sun.com/j2se/1.4.2/docs/guide/lang/assert.html
http://www-128.ibm.com/developworkers/cn/java/jdiag0723/
http://www-128.ibm.com/developworkers/cn/java/jmerlin/part9/

刘璐 2006-10-24 16:17 发表评论
]]>
staticҎ不应该被重写http://www.tkk7.com/liulu/archive/2006/10/24/76933.html刘璐刘璐Tue, 24 Oct 2006 03:47:00 GMThttp://www.tkk7.com/liulu/archive/2006/10/24/76933.htmlhttp://www.tkk7.com/liulu/comments/76933.htmlhttp://www.tkk7.com/liulu/archive/2006/10/24/76933.html#Feedback0http://www.tkk7.com/liulu/comments/commentRss/76933.htmlhttp://www.tkk7.com/liulu/services/trackbacks/76933.html如果你认为重写只是在子类中简单的替换了一个方法,你就很容易认为static Ҏ也能
被重写。事实上Q我有很多包含h们D例指明static Ҏ能被重写的代码的邮g。然而,q?br />些ƈ没有考虑Ҏ重写在运行时军_哪个版本的方法被调用的细节问题。下面的代码g?br />明static Ҏ是怎样被重写的?br />class Base{
   static void amethod(){
   System.out.println("Base.amethod");
   }
}
public class Cravengib extends Base{
   public static void main(String arg[]){
      Cravengib cg = new Cravengib();
      cg.amethod();
   }
   static void amethod(){
      System.out.println("Cravengib.amethod");
   }
}
如果你编译ƈq行q段代码Q你会发现输出文本Cravengib.amethodQ这g很好的指
明了重写。然而,对于重写Q还有相对于在子cM使用一个方法简单替换另一个方法更多的
东西。还有运行时军_的方法基于引用的cȝcd的问题,q可以通过刉正在被实例化的
cȝ引用cdQ实例初始化语句的左半部分)来说明?br />在上面的例子中,因ؓ名字叫amethod 的方法与cd生了兌Q而不是与特定的类的实
例相兌Q它不在乎什么类型的cL在创建它Q而仅仅在意引用的cd。因此,如果你在?br />用amethod 前改变一下这一行,
Base cg= new Cravengib()
你就会发现当你运行程序时Q你会得到输出:Base.amethod
cg 是一个类Cravengib 在内存中的一个Base cd的实例的引用Q或者指针)。如果一个static
Ҏ被调用了QJVM 不会查什么类型正在指向它Q它只会调用跟Base cȝ兌的方法的
实例?br />与上面的情况相对比:当一个方法被重写ӞJVM 查通过引用正在指向的类的类型,
q调用此cd相关的方法。可以结束这个例子了Q如果你两个版本的amethod Ҏ改变?br />非staticQƈ依然创徏c:
Base cg= new Cravengib()
~译q运行上qC码,你会发现amethod 已经被重写了Qƈ且输出Cravengib.amethod?/p>

刘璐 2006-10-24 11:47 发表评论
]]>
java反射机制http://www.tkk7.com/liulu/archive/2006/09/08/68567.html刘璐刘璐Fri, 08 Sep 2006 09:56:00 GMThttp://www.tkk7.com/liulu/archive/2006/09/08/68567.htmlhttp://www.tkk7.com/liulu/comments/68567.htmlhttp://www.tkk7.com/liulu/archive/2006/09/08/68567.html#Feedback0http://www.tkk7.com/liulu/comments/commentRss/68567.htmlhttp://www.tkk7.com/liulu/services/trackbacks/68567.html
Java 的这一能力在实际应用中也许用得不是很多Q但是在其它的程序设计语a中根本就不存在这一Ҏ。例如,Pascal、C 或?C++ 中就没有办法在程序中获得函数定义相关的信息?br />
JavaBean ?reflection 的实际应用之一Q它能让一些工具可视化的操作Y件组件。这些工具通过 reflection 动态的载入q取?Java lg(c? 的属性?br />


1. 一个简单的例子

考虑下面q个单的例子Q让我们看看 reflection 是如何工作的?br />
import java.lang.reflect.*;
public class DumpMethods {
   public static void main(String args[]) {
       try {
           Class c = Class.forName(args[0]);
           Method m[] = c.getDeclaredMethods();
           for (int i = 0; i < m.length; i++)
               System.out.println(m[i].toString());
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

按如下语句执行:

java DumpMethods java.util.Stack

它的l果输出为:

public java.lang.Object java.util.Stack.push(java.lang.Object)

public synchronized java.lang.Object java.util.Stack.pop()

public synchronized java.lang.Object java.util.Stack.peek()

public boolean java.util.Stack.empty()

public synchronized int java.util.Stack.search(java.lang.Object)

q样列Zjava.util.Stack cȝ各方法名以及它们的限制符和返回类型?br />
q个E序使用 Class.forName 载入指定的类Q然后调?getDeclaredMethods 来获取这个类中定义了的方法列表。java.lang.reflect.Methods 是用来描q某个类中单个方法的一个类?br />
2.开始?Reflection

用于 reflection 的类Q如 MethodQ可以在 java.lang.relfect 包中扑ֈ。用这些类的时候必要遵@三个步骤Q第一步是获得你想操作的类?java.lang.Class 对象。在q行中的 Java E序中,?java.lang.Class cL描述cd接口{?br />
下面是获得一?Class 对象的方法之一Q?br />
Class c = Class.forName("java.lang.String");

q条语句得到一?String cȝcd象。还有另一U方法,如下面的语句Q?br />
Class c = int.class;

或?br />
Class c = Integer.TYPE;

它们可获得基本类型的cM息。其中后一U方法中讉K的是基本cd的封装类 (?Integer) 中预先定义好?TYPE 字段?br />
W二步是调用诸如 getDeclaredMethods 的方法,以取得该cM定义的所有方法的列表?br />
一旦取得这个信息,可以进行第三步了——?reflection API 来操作这些信息,如下面这D代码:

Class c = Class.forName("java.lang.String");

Method m[] = c.getDeclaredMethods();

System.out.println(m[0].toString());

它将以文本方式打印出 String 中定义的W一个方法的原型?br />
在下面的例子中,q三个步骤将Z?reflection 处理Ҏ应用E序提供例证?br />
模拟 instanceof 操作W?br />
得到cM息之后,通常下一个步骤就是解军_?Class 对象的一些基本的问题。例如,Class.isInstance Ҏ可以用于模拟 instanceof 操作W:

class A {
}

public class instance1 {
   public static void main(String args[]) {
       try {
           Class cls = Class.forName("A");
           boolean b1 = cls.isInstance(new Integer(37));
           System.out.println(b1);
           boolean b2 = cls.isInstance(new A());
           System.out.println(b2);
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

在这个例子中创徏了一?A cȝ Class 对象Q然后检查一些对象是否是 A 的实例。Integer(37) 不是Q但 new A() 是?br />
3.扑ևcȝҎ

扑և一个类中定义了些什么方法,q是一个非常有价g非常基础?reflection 用法。下面的代码实Cq一用法Q?br />
import java.lang.reflect.*;

public class method1 {
   private int f1(Object p, int x) throws NullPointerException {
       if (p == null)
           throw new NullPointerException();
       return x;
   }

   public static void main(String args[]) {
       try {
           Class cls = Class.forName("method1");
           Method methlist[] = cls.getDeclaredMethods();
           for (int i = 0; i < methlist.length; i++) {
               Method m = methlist[i];
               System.out.println("name = " + m.getName());
               System.out.println("decl class = " + m.getDeclaringClass());
               Class pvec[] = m.getParameterTypes();
               for (int j = 0; j < pvec.length; j++)
                   System.out.println("param #" + j + " " + pvec[j]);
               Class evec[] = m.getExceptionTypes();
               for (int j = 0; j < evec.length; j++)
                   System.out.println("exc #" + j + " " + evec[j]);
               System.out.println("return type = " + m.getReturnType());
               System.out.println("-----");
           }
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

q个E序首先取得 method1 cȝ描述Q然后调?getDeclaredMethods 来获取一pd?Method 对象Q它们分别描qC定义在类中的每一个方法,包括 public Ҏ、protected Ҏ、package Ҏ?private Ҏ{。如果你在程序中使用 getMethods 来代?getDeclaredMethodsQ你q能获得l承来的各个Ҏ的信息?br />
取得?Method 对象列表之后Q要昄q些Ҏ的参数类型、异常类型和q回值类型等׃难了。这些类型是基本cdq是cȝ型,都可以由描述cȝ对象按顺序给出?br />
输出的结果如下:

name = f1

decl class = class method1

param #0 class java.lang.Object

param #1 int

exc #0 class java.lang.NullPointerException

return type = int

-----

name = main

decl class = class method1

param #0 class [Ljava.lang.String;

return type = void

-----


4.获取构造器信息

获取cL造器的用法与上述获取Ҏ的用法类|如:

import java.lang.reflect.*;

public class constructor1 {
   public constructor1() {
   }

   protected constructor1(int i, double d) {
   }

   public static void main(String args[]) {
       try {
           Class cls = Class.forName("constructor1");
           Constructor ctorlist[] = cls.getDeclaredConstructors();
           for (int i = 0; i < ctorlist.length; i++) {
               Constructor ct = ctorlist[i];
               System.out.println("name = " + ct.getName());
               System.out.println("decl class = " + ct.getDeclaringClass());
               Class pvec[] = ct.getParameterTypes();
               for (int j = 0; j < pvec.length; j++)
                   System.out.println("param #" + j + " " + pvec[j]);
               Class evec[] = ct.getExceptionTypes();
               for (int j = 0; j < evec.length; j++)
                   System.out.println("exc #" + j + " " + evec[j]);
               System.out.println("-----");
           }
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

q个例子中没能获得返回类型的相关信息Q那是因为构造器没有q回cd?br />
q个E序q行的结果是Q?br />
name = constructor1

decl class = class constructor1

-----

name = constructor1

decl class = class constructor1

param #0 int

param #1 double

-----

5.获取cȝ字段(?

扑և一个类中定义了哪些数据字段也是可能的,下面的代码就在干q个事情Q?br />

import java.lang.reflect.*;

public class field1 {
   private double d;
   public static final int i = 37;
   String s = "testing";

   public static void main(String args[]) {
       try {
           Class cls = Class.forName("field1");
           Field fieldlist[] = cls.getDeclaredFields();
           for (int i = 0; i < fieldlist.length; i++) {
               Field fld = fieldlist[i];
               System.out.println("name = " + fld.getName());
               System.out.println("decl class = " + fld.getDeclaringClass());
               System.out.println("type = " + fld.getType());
               int mod = fld.getModifiers();
               System.out.println("modifiers = " + Modifier.toString(mod));
               System.out.println("-----");
           }
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

q个例子和前面那个例子非常相伹{例中用了一个新东西 ModifierQ它也是一?reflection c,用来描述字段成员的修饰语Q如“private int”。这些修饰语自n由整数描qͼ而且使用 Modifier.toString 来返回以“官方”顺序排列的字符串描q?(如“static”在“final”之?。这个程序的输出是:

name = d

decl class = class field1

type = double

modifiers = private

-----

name = i

decl class = class field1

type = int

modifiers = public static final

-----

name = s

decl class = class field1

type = class java.lang.String

modifiers =

-----

和获取方法的情况一下,获取字段的时候也可以只取得在当前cMx了的字段信息 (getDeclaredFields)Q或者也可以取得父类中定义的字段 (getFields) ?br />

6.ҎҎ的名U来执行Ҏ

文本到这里,所丄例子无一例外都与如何获取cȝ信息有关。我们也可以?reflection 来做一些其它的事情Q比如执行一个指定了名称的方法。下面的CZ演示了这一操作Q?br />
import java.lang.reflect.*;
public class method2 {
   public int add(int a, int b) {
       return a + b;
   }
   public static void main(String args[]) {
       try {
           Class cls = Class.forName("method2");
           Class partypes[] = new Class[2];
           partypes[0] = Integer.TYPE;
           partypes[1] = Integer.TYPE;
           Method meth = cls.getMethod("add", partypes);
           method2 methobj = new method2();
           Object arglist[] = new Object[2];
           arglist[0] = new Integer(37);
           arglist[1] = new Integer(47);
           Object retobj = meth.invoke(methobj, arglist);
           Integer retval = (Integer) retobj;
           System.out.println(retval.intValue());
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

假如一个程序在执行的某处的时候才知道需要执行某个方法,q个Ҏ的名U是在程序的q行q程中指定的 (例如QJavaBean 开发环境中׃做这L?Q那么上面的E序演示了如何做到?br />
上例中,getMethod 用于查找一个具有两个整型参C名ؓ add 的方法。找到该Ҏq创Z相应?Method 对象之后Q在正确的对象实例中执行它。执行该Ҏ的时候,需要提供一个参数列表,q在上例中是分别包装了整?37 ?47 的两?Integer 对象。执行方法的q回的同h一?Integer 对象Q它装了返回?84?br />
7.创徏新的对象

对于构造器Q则不能像执行方法那栯行,因ؓ执行一个构造器意味着创徏了一个新的对?(准确的说Q创Z个对象的q程包括分配内存和构造对?。所以,与上例最怼的例子如下:

import java.lang.reflect.*;

public class constructor2 {
   public constructor2() {
   }

   public constructor2(int a, int b) {
       System.out.println("a = " + a + " b = " + b);
   }

   public static void main(String args[]) {
       try {
           Class cls = Class.forName("constructor2");
           Class partypes[] = new Class[2];
           partypes[0] = Integer.TYPE;
           partypes[1] = Integer.TYPE;
           Constructor ct = cls.getConstructor(partypes);
           Object arglist[] = new Object[2];
           arglist[0] = new Integer(37);
           arglist[1] = new Integer(47);
           Object retobj = ct.newInstance(arglist);
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

Ҏ指定的参数类型找到相应的构造函数ƈ执行它,以创Z个新的对象实例。用这U方法可以在E序q行时动态地创徏对象Q而不是在~译的时候创建对象,q一炚w常有价倹{?br />
8.改变字段(?的?br />
reflection 的还有一个用处就是改变对象数据字D늚倹{reflection 可以从正在运行的E序中根据名U找到对象的字段q改变它Q下面的例子可以说明q一点:

import java.lang.reflect.*;

public class field2 {
   public double d;

   public static void main(String args[]) {
       try {
           Class cls = Class.forName("field2");
           Field fld = cls.getField("d");
           field2 f2obj = new field2();
           System.out.println("d = " + f2obj.d);
           fld.setDouble(f2obj, 12.34);
           System.out.println("d = " + f2obj.d);
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

q个例子中,字段 d 的D变ؓ?12.34?br />
9.使用数组

本文介绍?reflection 的最后一U用法是创徏的操作数l。数l在 Java 语言中是一U特D的cȝ型,一个数l的引用可以赋给 Object 引用。观察下面的例子看看数组是怎么工作的:

import java.lang.reflect.*;

public class array1 {
   public static void main(String args[]) {
       try {
           Class cls = Class.forName("java.lang.String");
           Object arr = Array.newInstance(cls, 10);
           Array.set(arr, 5, "this is a test");
           String s = (String) Array.get(arr, 5);
           System.out.println(s);
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

例中创徏?10 个单位长度的 String 数组QؓW?5 个位|的字符串赋了|最后将q个字符串从数组中取得ƈ打印了出来?br />
下面q段代码提供了一个更复杂的例子:

import java.lang.reflect.*;

public class array2 {
   public static void main(String args[]) {
       int dims[] = new int[]{5, 10, 15};
       Object arr = Array.newInstance(Integer.TYPE, dims);
       Object arrobj = Array.get(arr, 3);
       Class cls = arrobj.getClass().getComponentType();
       System.out.println(cls);
       arrobj = Array.get(arrobj, 5);
       Array.setInt(arrobj, 10, 37);
       int arrcast[][][] = (int[][][]) arr;
       System.out.println(arrcast[3][5][10]);
   }
}
例中创徏了一?5 x 10 x 15 的整型数l,qؓ处于 [3][5][10] 的元素赋了gؓ 37。注意,数组实际上就是数l的数组Q例如,W一?Array.get 之后Qarrobj 是一?10 x 15 的数l。进而取得其中的一个元素,即长度ؓ 15 的数l,q?Array.setInt 为它的第 10 个元素赋倹{?br />
注意创徏数组时的cd是动态的Q在~译时ƈ不知道其cd

刘璐 2006-09-08 17:56 发表评论
]]>
什么是POJOhttp://www.tkk7.com/liulu/archive/2006/08/28/66137.html刘璐刘璐Mon, 28 Aug 2006 03:35:00 GMThttp://www.tkk7.com/liulu/archive/2006/08/28/66137.htmlhttp://www.tkk7.com/liulu/comments/66137.htmlhttp://www.tkk7.com/liulu/archive/2006/08/28/66137.html#Feedback0http://www.tkk7.com/liulu/comments/commentRss/66137.htmlhttp://www.tkk7.com/liulu/services/trackbacks/66137.html单的JAVA对象QPlain Old Java ObjectsQ实际就是普通JavaBeans,使用POJO名称是ؓ了和EJBhh, 而且U比较直? 有一些属性及其getter setterҎ的类,有时可以作ؓvalue object或dto来?当然,如果你有一个简单的q算属性也是可以的,但不允许有业务方?不能携带有connection之类?/span>

刘璐 2006-08-28 11:35 发表评论
]]>
վ֩ģ壺 þԭav| ޾Ʒ2021| þerƷѹۿ2| þþþþ޾Ʒ| kk4kkƵëƬ| ޹ƷþþþþԻ| AVһþþƷ| 97޳ҹҹ | 91ѹۿ߹ۿ| һƵ߲| VƬ߹ۿ| Ӱ޴ɫ| Ʒվ| ˶վ| ƷѹۿƵ| Ů18һëƬѹۿ| þ޾ƷAB벥| þþƷ˳| aƬ߹ۿ| պһ߲ѹۿ| ɫˬ1000| ŷAۺһ| þþøձѹۿ| 츾밮v߹ۿ| 鶹Ʒѹۿ| һëƬaŮ˴̼Ƶ| ޳AVƬ߹ۿ| 91Ʒ߹ۿ| ۺƵ| ޾ƷԴ26u| 2021Ƶ| ͵͵APP| ߹ۿҹһ| ϣӰԺѹۿƵ| ëƬ| AVŮһ| ˿ҹëƬ| һ| ޼ƵͼƬ| þþƷƷ| ŷɫƵ߹ۿ|