﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-流浪~-随笔分类-web</title><link>http://www.blogjava.net/ysqwertys/category/42690.html</link><description /><language>zh-cn</language><lastBuildDate>Tue, 09 Mar 2010 10:04:52 GMT</lastBuildDate><pubDate>Tue, 09 Mar 2010 10:04:52 GMT</pubDate><ttl>60</ttl><item><title>hibernate常问问题</title><link>http://www.blogjava.net/ysqwertys/archive/2010/03/08/314839.html</link><dc:creator>lucas_y</dc:creator><author>lucas_y</author><pubDate>Mon, 08 Mar 2010 08:14:00 GMT</pubDate><guid>http://www.blogjava.net/ysqwertys/archive/2010/03/08/314839.html</guid><wfw:comment>http://www.blogjava.net/ysqwertys/comments/314839.html</wfw:comment><comments>http://www.blogjava.net/ysqwertys/archive/2010/03/08/314839.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/ysqwertys/comments/commentRss/314839.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/ysqwertys/services/trackbacks/314839.html</trackback:ping><description><![CDATA[hibenate的面试总结. <br />
可能现在大家常常还会遇到一个些面试的时候问一些关于hibernate的问题，我个人觉得，这些东西一般做过开发的人在使用上没有任何的问题的，但是如果是要你来说就不一定能够说好的，下面是从goole上找的一些常见的面试。 <br />
1.Hibernate session接口的get和load方法有何异同？ <br />
答：&nbsp;get不到实体对象时会返回null，load会抛出异常<br />
&nbsp; - get会立即加载实体对象，load默认是延迟加载<br />
&nbsp; - get会忽略二级缓存(这个没有试验过)，load则是一级和二级缓存都使用 <br />
<br />
2.在持久化层，对象分为哪些状态？分别列出来. <br />
答:瞬时态(Transient)、持久态(Persistent)、脱管态(Detached)。 <br />
瞬时态(Transient) <br />
是对象是创建时，瞬时对象在内存孤立存在，它是携带信息的载体，不和数据库的数据有任何关联关系，在Hibernate中，可通过session的save()或 saveOrUpdate()方法将瞬时对象与数据库相关联，并将数据对应的插入数据库中，此时该瞬时对象转变成持久化对象。 <br />
持久态(Persistent) <br />
是该对象在数据库中已有对应的记录，并拥有一个持久化标识，如果是用hibernate的delete()方法，对应的持久对象就变成瞬时对象，因数据库中的对应数据已被删除，该对象不再与数据库的记录关联。 <br />
&nbsp;&nbsp;&nbsp; 当一个session执行close()或clear()、evict()之后，持久对象变成脱管对象，此时持久对象会变成脱管对象，此时该对象虽然具有数据库识别值，但它已不在hibernate持久层的管理之下。 <br />
&nbsp; 持久对象具有如下特点： <br />
&nbsp;&nbsp;&nbsp;&nbsp; 1. 和session实例关联； <br />
&nbsp;&nbsp;&nbsp;&nbsp; 2. 在数据库中有与之关联的记录。 <br />
脱管态(Detached) <br />
当与某持久对象关联的session被关闭后，该持久对象转变为脱管对象。当脱管对象被重新关联到session上时，并再次转变成持久对象。 <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 脱管对象拥有数据库的识别值，可通过update()、saveOrUpdate()等方法，转变成持久对象。 <br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 脱管对象具有如下特点： <br />
&nbsp; 1.本质上与瞬时对象相同，在没有任何变量引用它时，JVM会在适当的时候将它回收； <br />
2. 比瞬时对象多了一个数据库记录标识值。 <br />
<br />
3.lock和update区别 <br />
答: update是把一个已经更改过的脱管状态的对象变成持久状态 <br />
lock是把一个没有更改过的脱管状态的对象变成持久状态(针对的是因Session的关闭 而处于脱管状态的po对象(2)，不能针对因delete而处于脱管状态的po对象) <br />
对应更改一个记录的内容，两个的操作不同： <br />
update的操作步骤是： <br />
(1)属性改动后的脱管的对象的修改-&gt;调用update <br />
lock的操作步骤是： <br />
(2)调用lock把未修改的对象从脱管状态变成持久状态--&gt;更改持久状态的对象的内容--&gt;等待flush或者手动flush <br />
<br />
4.save 和update区别 <br />
答： save是把一个对象做为一个新的数据保存, update则是把一个脱管状态的对象或自由态对象（一定要和一个记录对应）更新到数据库，其实一个是保存一个是更新，一看都知道是有什么区别了。 <br />
<br />
5.update 和saveOrUpdate区别 <br />
答：这个是比较好理解的，顾名思义，saveOrUpdate基本上就是合成了save和update,而update只是update;引用hibernate reference中的一段话来解释他们的使用场合和区别 <br />
通常下面的场景会使用update()或saveOrUpdate()： <br />
程序在第一个session中加载对象,接着把session关闭 <br />
该对象被传递到表现层 <br />
对象发生了一些改动 <br />
该对象被返回到业务逻辑层最终到持久层 <br />
程序创建第二session调用第二个session的update()方法持久这些改动 <br />
saveOrUpdate(po)做下面的事: <br />
如果该po对象已经在本session中持久化了，在本session中执行saveOrUpdate不做任何事 <br />
如果savaOrUpdate(新po)与另一个与本session关联的po对象拥有相同的持久化标识(identifier)，抛出一个异常 <br />
org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session: [org.itfuture.www.po.Xtyhb#5] <br />
saveOrUpdate如果对象没有持久化标识(identifier)属性，对其调用save() ，否则update() 这个对象&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />
<br />
6.flush和update区别 <br />
答：这两个的区别好理解update操作的是在自由态或脱管状态(因session的关闭而处于脱管状态)的对象//updateSQL <br />
而flush是操作的在持久状态的对象。 <br />
默认情况下，一个持久状态的对象的改动（包含set容器）是不需要update的，只要你更改了对象的值，等待hibernate flush就自动更新或保存到数据库了。hibernate flush发生在以下几种情况中： <br />
1， 调用某些查询的和手动flush(),session的关闭、SessionFactory关闭结合 <br />
get()一个对象，把对象的属性进行改变,把资源关闭。 <br />
2，transaction commit的时候（包含了flush） <br />
<img src ="http://www.blogjava.net/ysqwertys/aggbug/314839.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/ysqwertys/" target="_blank">lucas_y</a> 2010-03-08 16:14 <a href="http://www.blogjava.net/ysqwertys/archive/2010/03/08/314839.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>proxy</title><link>http://www.blogjava.net/ysqwertys/archive/2010/02/04/312012.html</link><dc:creator>lucas_y</dc:creator><author>lucas_y</author><pubDate>Thu, 04 Feb 2010 09:52:00 GMT</pubDate><guid>http://www.blogjava.net/ysqwertys/archive/2010/02/04/312012.html</guid><wfw:comment>http://www.blogjava.net/ysqwertys/comments/312012.html</wfw:comment><comments>http://www.blogjava.net/ysqwertys/archive/2010/02/04/312012.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/ysqwertys/comments/commentRss/312012.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/ysqwertys/services/trackbacks/312012.html</trackback:ping><description><![CDATA[<p>&nbsp;代理模式</p>
<p><br />
代理模式的作用是：</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 为其他对象提供一种代理以控制对这个对象的访问。在某些情况下，一个客户不想或者不能直接引用另一个对象，而代理对象可以在客户端和目标对象之间起到中介的作用。</p>
<p><br />
代理模式一般涉及到的角色有： </p>
<p><br />
抽象角色：声明真实对象和代理对象的共同接口；</p>
<p>代理角色：代理对象角色内部含有对真实对象的引用，从而可以操作真实对象，同时代理对象提供与真实对象相同的接口以便在任何时刻都能代替真实对象。同时，代理对象可以在执行真实对象操作时，附加其他的操作，相当于对真实对象进行封装。</p>
<p>真实角色：代理角色所代表的真实对象，是我们最终要引用的对象。</p>
<p>以下以《Java与模式》中的示例为例：</p>
<p>代码： //抽象角色：<br />
abstract public class Subject{ <br />
abstract public void request();<br />
}</p>
<p>//真实角色：实现了Subject的request()方法。<br />
public class RealSubject extends Subject{<br />
public RealSubject(){ <br />
}<br />
public void request(){<br />
System.out.println("From real subject.");<br />
}<br />
} </p>
<p>//代理角色：<br />
public class ProxySubject extends Subject{<br />
private RealSubject realSubject; //以真实角色作为代理角色的属性 <br />
public ProxySubject(){<br />
} <br />
public void request(){ //该方法封装了真实对象的request方法 <br />
preRequest(); <br />
if( realSubject == null ){<br />
realSubject = new RealSubject();<br />
}<br />
realSubject.request(); //此处执行真实对象的request方法 <br />
postRequest(); <br />
}<br />
private void preRequest(){ <br />
//something you want to do before requesting <br />
}<br />
private void postRequest(){ <br />
//something you want to do after requesting <br />
}<br />
}</p>
<p>//客户端调用：<br />
Subject sub=new ProxySubject();<br />
Sub.request(); </p>
<p><br />
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 由以上代码可以看出，客户实际需要调用的是RealSubject类的request()方法，现在用ProxySubject来代理RealSubject类，同样达到目的，同时还封装了其他方法(preRequest(),postRequest())，可以处理一些其他问题。 </p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 另外，如果要按照上述的方法使用代理模式，那么真实角色必须是事先已经存在的，并将其作为代理对象的内部属性。但是实际使用时，一个真实角色必须对应一个代理角色，如果大量使用会导致类的急剧膨胀；此外，如果事先并不知道真实角色，该如何使用代理呢？这个问题可以通过Java的动态代理类来解决。</p>
<p>2.动态代理</p>
<p>Java动态代理类位于Java.lang.reflect包下，一般主要涉及到以下两个类：</p>
<p>(1). Interface InvocationHandler：该接口中仅定义了一个方法Object：invoke(Object obj,Method method, Object[] args)。在实际使用时，第一个参数obj一般是指代理类，method是被代理的方法，如上例中的request()，args为该方法的参数数组。这个抽象方法在代理类中动态实现。</p>
<p>(2).Proxy：该类即为动态代理类，作用类似于上例中的ProxySubject，其中主要包含以下内容：<br />
Protected Proxy(InvocationHandler h)：构造函数，估计用于给内部的h赋值。</p>
<p>Static Class getProxyClass (ClassLoader loader, Class[] interfaces)：获得一个代理类，其中loader是类装载器，interfaces是真实类所拥有的全部接口的数组。</p>
<p>Static Object newProxyInstance(ClassLoader loader, Class[] interfaces, InvocationHandler h)：返回代理类的一个实例，返回后的代理类可以当作被代理类使用(可使用被代理类的在Subject接口中声明过的方法)。</p>
<p>所谓Dynamic Proxy是这样一种class：它是在运行时生成的class，在生成它时你必须提供一组interface给它，然后该class就宣称它实现了这些interface。你当然可以把该class的实例当作这些interface中的任何一个来用。当然啦，这个Dynamic Proxy其实就是一个Proxy，它不会替你作实质性的工作，在生成它的实例时你必须提供一个handler，由它接管实际的工作。(参见文献3)</p>
<p>在使用动态代理类时，我们必须实现InvocationHandler接口，以第一节中的示例为例： </p>
<p>代码： //抽象角色(之前是抽象类，此处应改为接口)：</p>
<p>public interface Subject{<br />
public void request();<br />
} </p>
<p>//具体角色RealSubject：实现了Subject接口的request()方法。<br />
public class RealSubject implements Subject{ <br />
public RealSubject(){</p>
<p>}<br />
public void request(){ <br />
System.out.println("From real subject."); <br />
} <br />
}</p>
<p>//代理角色：<br />
import java.lang.reflect.Method;<br />
import java.lang.reflect.InvocationHandler;<br />
public class DynamicSubject implements InvocationHandler{<br />
private Object sub; <br />
public DynamicSubject(Object sub){ <br />
this.sub = sub;<br />
}<br />
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {<br />
System.out.println("before calling " + method); <br />
method.invoke(sub,args); <br />
System.out.println("after calling " + method); <br />
return null; <br />
}<br />
}</p>
<p>该代理类的内部属性为Object类，实际使用时通过该类的构造函数DynamicSubject(Object sub)对其赋值；此外，在该类还实现了invoke方法，该方法中的"method.invoke(sub,args)" 其实就是调用被代理对象的将要被执行的方法，方法参数sub是实际的被代理对象，args为执行被代理对象相应操作所需的参数。通过动态代理类，我们可以在调用之前或之后执行一些相关操作。 </p>
<p>客户端：<br />
代码： import java.lang.reflect.InvocationHandler;<br />
import java.lang.reflect.Proxy;<br />
import java.lang.reflect.Constructor;<br />
import java.lang.reflect.Method;<br />
public class Client{ <br />
static public void main(String[] args) throws Throwable{<br />
RealSubject rs = new RealSubject(); //在这里指定被代理类<br />
InvocationHandler ds = new DynamicSubject(rs); //初始化代理类<br />
Class cls = rs.getClass();<br />
//以下是分解步骤<br />
/*<br />
Class c = Proxy.getProxyClass(cls.getClassLoader(),cls.getInterfaces());<br />
Constructor ct=c.getConstructor(new Class[]{InvocationHandler.class});<br />
Subject subject =(Subject) ct.newInstance(new Object[]{ds});<br />
*/</p>
<p>//以下是一次性生成</p>
<p>Subject subject = (Subject) Proxy.newProxyInstance(cls.getClassLoader(),cls.getInterfaces(),ds);<br />
subject.request();<br />
}</p>
<p>通过这种方式，被代理的对象(RealSubject)可以在运行时动态改变，需要控制的接口(Subject接口)可以在运行时改变，控制的方式(DynamicSubject类)也可以动态改变，从而实现了非常灵活的动态代理关系。 </p>
<p>3.代理模式使用原因和应用方面</p>
<p>（1）授权机制 不同级别的用户对同一对象拥有不同的访问权利,如Jive论坛系统中,就使用Proxy进行授权机制控制,访问论坛有两种人:注册用户和游客(未注册用户),Jive中就通过类似ForumProxy这样的代理来控制这两种用户对论坛的访问权限.</p>
<p>（2）某个客户端不能直接操作到某个对象,但又必须和那个对象有所互动.<br />
举例两个具体情况: <br />
如果那个对象是一个是很大的图片,需要花费很长时间才能显示出来,那么当这个图片包含在文档中时,使用编辑器或浏览器打开这个文档,打开文档必须很迅速,不能等待大图片处理完成,这时需要做个图片Proxy来代替真正的图片.</p>
<p>如果那个对象在Internet的某个远端服务器上,直接操作这个对象因为网络速度原因可能比较慢,那我们可以先用Proxy来代替那个对象.</p>
<p>总之原则是,对于开销很大的对象,只有在使用它时才创建,这个原则可以为我们节省很多宝贵的Java内存. 所以,有些人认为Java耗费资源内存,我以为这和程序编制思路也有一定的关系.</p>
<p>（3）现实中，Proxy应用范围很广,现在流行的分布计算方式RMI和Corba等都是Proxy模式的应用</p>
<p>&nbsp;</p>
<p>本文来自CSDN博客，转载请标明出处：http://blog.csdn.net/goodHabit/archive/2009/11/08/4784461.aspx</p>
<img src ="http://www.blogjava.net/ysqwertys/aggbug/312012.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/ysqwertys/" target="_blank">lucas_y</a> 2010-02-04 17:52 <a href="http://www.blogjava.net/ysqwertys/archive/2010/02/04/312012.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>reflect</title><link>http://www.blogjava.net/ysqwertys/archive/2010/02/04/312007.html</link><dc:creator>lucas_y</dc:creator><author>lucas_y</author><pubDate>Thu, 04 Feb 2010 09:00:00 GMT</pubDate><guid>http://www.blogjava.net/ysqwertys/archive/2010/02/04/312007.html</guid><wfw:comment>http://www.blogjava.net/ysqwertys/comments/312007.html</wfw:comment><comments>http://www.blogjava.net/ysqwertys/archive/2010/02/04/312007.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/ysqwertys/comments/commentRss/312007.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/ysqwertys/services/trackbacks/312007.html</trackback:ping><description><![CDATA[JAVA反射机制<br />
&nbsp;&nbsp;&nbsp;&nbsp;JAVA反射机制是在运行状态中，对于任意一个类，都能够知道这个类的所有属性和方法；对于任意一个对象，都能够调用它的任意一个方法；这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。<br />
Java反射机制主要提供了以下功能：&nbsp;在运行时判断任意一个对象所属的类；在运行时构造任意一个类的对象；在运行时判断任意一个类所具有的成员变量和方法；在运行时调用任意一个对象的方法；生成动态代理。<br />
1.&nbsp;得到某个对象的属性<br />
<br />
1&nbsp;public&nbsp;Object&nbsp;getProperty(Object&nbsp;owner,&nbsp;String&nbsp;fieldName)&nbsp;throws&nbsp;Exception&nbsp;{<br />
2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Class&nbsp;ownerClass&nbsp;=&nbsp;owner.getClass();<br />
3&nbsp;<br />
4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Field&nbsp;field&nbsp;=&nbsp;ownerClass.getField(fieldName);<br />
5&nbsp;<br />
6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Object&nbsp;property&nbsp;=&nbsp;field.get(owner);<br />
7&nbsp;<br />
8&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;property;<br />
9&nbsp;}<br />
Class&nbsp;ownerClass&nbsp;=&nbsp;owner.getClass()：得到该对象的Class。<br />
<br />
Field&nbsp;field&nbsp;=&nbsp;ownerClass.getField(fieldName)：通过Class得到类声明的属性。<br />
<br />
Object&nbsp;property&nbsp;=&nbsp;field.get(owner)：通过对象得到该属性的实例，如果这个属性是非公有的，这里会报IllegalAccessException。<br />
<br />
2.&nbsp;得到某个类的静态属性<br />
<br />
&nbsp;1&nbsp;public&nbsp;Object&nbsp;getStaticProperty(String&nbsp;className,&nbsp;String&nbsp;fieldName)<br />
&nbsp;2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;throws&nbsp;Exception&nbsp;{<br />
&nbsp;3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Class&nbsp;ownerClass&nbsp;=&nbsp;Class.forName(className);<br />
&nbsp;4&nbsp;<br />
&nbsp;5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Field&nbsp;field&nbsp;=&nbsp;ownerClass.getField(fieldName);<br />
&nbsp;6&nbsp;<br />
&nbsp;7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Object&nbsp;property&nbsp;=&nbsp;field.get(ownerClass);<br />
&nbsp;8&nbsp;<br />
&nbsp;9&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;property;<br />
10&nbsp;}<br />
<br />
Class&nbsp;ownerClass&nbsp;=&nbsp;Class.forName(className)&nbsp;：首先得到这个类的Class。<br />
<br />
Field&nbsp;field&nbsp;=&nbsp;ownerClass.getField(fieldName)：和上面一样，通过Class得到类声明的属性。<br />
<br />
Object&nbsp;property&nbsp;=&nbsp;field.get(ownerClass)&nbsp;：这里和上面有些不同，因为该属性是静态的，所以直接从类的Class里取。<br />
<br />
3.&nbsp;执行某对象的方法<br />
<br />
&nbsp;1&nbsp;public&nbsp;Object&nbsp;invokeMethod(Object&nbsp;owner,&nbsp;String&nbsp;methodName,&nbsp;Object[]&nbsp;args)&nbsp;throws&nbsp;Exception&nbsp;{<br />
&nbsp;2&nbsp;<br />
&nbsp;3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Class&nbsp;ownerClass&nbsp;=&nbsp;owner.getClass();<br />
&nbsp;4&nbsp;<br />
&nbsp;5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Class[]&nbsp;argsClass&nbsp;=&nbsp;new&nbsp;Class[args.length];<br />
&nbsp;6&nbsp;<br />
&nbsp;7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0,&nbsp;j&nbsp;=&nbsp;args.length;&nbsp;i&nbsp;&lt;&nbsp;j;&nbsp;i++)&nbsp;{<br />
&nbsp;8&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;argsClass[i]&nbsp;=&nbsp;args[i].getClass();<br />
&nbsp;9&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br />
10&nbsp;<br />
11&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Method&nbsp;method&nbsp;=&nbsp;ownerClass.getMethod(methodName,&nbsp;argsClass);<br />
12&nbsp;<br />
13&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;method.invoke(owner,&nbsp;args);<br />
14&nbsp;}<br />
Class&nbsp;owner_class&nbsp;=&nbsp;owner.getClass()&nbsp;：首先还是必须得到这个对象的Class。<br />
<br />
5～9行：配置参数的Class数组，作为寻找Method的条件。<br />
<br />
Method&nbsp;method&nbsp;=&nbsp;ownerClass.getMethod(methodName,&nbsp;argsClass)：通过Method名和参数的Class数组得到要执行的Method。<br />
<br />
method.invoke(owner,&nbsp;args)：执行该Method，invoke方法的参数是执行这个方法的对象，和参数数组。返回值是Object，也既是该方法的返回值。<br />
<br />
4.&nbsp;执行某个类的静态方法<br />
<br />
&nbsp;1&nbsp;public&nbsp;Object&nbsp;invokeStaticMethod(String&nbsp;className,&nbsp;String&nbsp;methodName,<br />
&nbsp;2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Object[]&nbsp;args)&nbsp;throws&nbsp;Exception&nbsp;{<br />
&nbsp;3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Class&nbsp;ownerClass&nbsp;=&nbsp;Class.forName(className);<br />
&nbsp;4&nbsp;<br />
&nbsp;5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Class[]&nbsp;argsClass&nbsp;=&nbsp;new&nbsp;Class[args.length];<br />
&nbsp;6&nbsp;<br />
&nbsp;7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0,&nbsp;j&nbsp;=&nbsp;args.length;&nbsp;i&nbsp;&lt;&nbsp;j;&nbsp;i++)&nbsp;{<br />
&nbsp;8&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;argsClass[i]&nbsp;=&nbsp;args[i].getClass();<br />
&nbsp;9&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br />
10&nbsp;<br />
11&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Method&nbsp;method&nbsp;=&nbsp;ownerClass.getMethod(methodName,&nbsp;argsClass);<br />
12&nbsp;<br />
13&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;method.invoke(null,&nbsp;args);<br />
14&nbsp;}<br />
<br />
基本的原理和实例3相同，不同点是最后一行，invoke的一个参数是null，因为这是静态方法，不需要借助实例运行。<br />
<br />
5.&nbsp;新建实例<br />
&nbsp;1&nbsp;<br />
&nbsp;2&nbsp;public&nbsp;Object&nbsp;newInstance(String&nbsp;className,&nbsp;Object[]&nbsp;args)&nbsp;throws&nbsp;Exception&nbsp;{<br />
&nbsp;3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Class&nbsp;newoneClass&nbsp;=&nbsp;Class.forName(className);<br />
&nbsp;4&nbsp;<br />
&nbsp;5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Class[]&nbsp;argsClass&nbsp;=&nbsp;new&nbsp;Class[args.length];<br />
&nbsp;6&nbsp;<br />
&nbsp;7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0,&nbsp;j&nbsp;=&nbsp;args.length;&nbsp;i&nbsp;&lt;&nbsp;j;&nbsp;i++)&nbsp;{<br />
&nbsp;8&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;argsClass[i]&nbsp;=&nbsp;args[i].getClass();<br />
&nbsp;9&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br />
10&nbsp;<br />
11&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Constructor&nbsp;cons&nbsp;=&nbsp;newoneClass.getConstructor(argsClass);<br />
12&nbsp;<br />
13&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;cons.newInstance(args);<br />
14&nbsp;<br />
15&nbsp;}<br />
<br />
这里说的方法是执行带参数的构造函数来新建实例的方法。如果不需要参数，可以直接使用newoneClass.newInstance()来实现。<br />
<br />
Class&nbsp;newoneClass&nbsp;=&nbsp;Class.forName(className)：第一步，得到要构造的实例的Class。<br />
<br />
第5～第9行：得到参数的Class数组。<br />
<br />
Constructor&nbsp;cons&nbsp;=&nbsp;newoneClass.getConstructor(argsClass)：得到构造子。<br />
<br />
cons.newInstance(args)：新建实例。<br />
<br />
6.&nbsp;判断是否为某个类的实例<br />
<br />
1&nbsp;public&nbsp;boolean&nbsp;isInstance(Object&nbsp;obj,&nbsp;Class&nbsp;cls)&nbsp;{<br />
2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;cls.isInstance(obj);<br />
3&nbsp;}<br />
<br />
7.&nbsp;得到数组中的某个元素<br />
1&nbsp;public&nbsp;Object&nbsp;getByArray(Object&nbsp;array,&nbsp;int&nbsp;index)&nbsp;{<br />
2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;Array.get(array,index);<br />
3&nbsp;}
<img src ="http://www.blogjava.net/ysqwertys/aggbug/312007.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/ysqwertys/" target="_blank">lucas_y</a> 2010-02-04 17:00 <a href="http://www.blogjava.net/ysqwertys/archive/2010/02/04/312007.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Spring Security3.0.1</title><link>http://www.blogjava.net/ysqwertys/archive/2010/01/19/310102.html</link><dc:creator>lucas_y</dc:creator><author>lucas_y</author><pubDate>Tue, 19 Jan 2010 08:48:00 GMT</pubDate><guid>http://www.blogjava.net/ysqwertys/archive/2010/01/19/310102.html</guid><wfw:comment>http://www.blogjava.net/ysqwertys/comments/310102.html</wfw:comment><comments>http://www.blogjava.net/ysqwertys/archive/2010/01/19/310102.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/ysqwertys/comments/commentRss/310102.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/ysqwertys/services/trackbacks/310102.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: Spring Security-3.0.1中文官方文档（翻译版） 这次发布的Spring Security-3.0.1是一个bug fix版，主要是对3.0中存在的一些问题进行修正。文档中没有添加新功能的介绍，但是将之前拼写错误的一些类名进行了修正，建议开发者以这一版本的文档为参考。另：Spring Security从2010-01-01以后，版本控制从SVN换成了GIT，我们在翻译文...&nbsp;&nbsp;<a href='http://www.blogjava.net/ysqwertys/archive/2010/01/19/310102.html'>阅读全文</a><img src ="http://www.blogjava.net/ysqwertys/aggbug/310102.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/ysqwertys/" target="_blank">lucas_y</a> 2010-01-19 16:48 <a href="http://www.blogjava.net/ysqwertys/archive/2010/01/19/310102.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>&lt;meta http-equiv=...&gt; 的功能</title><link>http://www.blogjava.net/ysqwertys/archive/2010/01/19/310099.html</link><dc:creator>lucas_y</dc:creator><author>lucas_y</author><pubDate>Tue, 19 Jan 2010 08:43:00 GMT</pubDate><guid>http://www.blogjava.net/ysqwertys/archive/2010/01/19/310099.html</guid><wfw:comment>http://www.blogjava.net/ysqwertys/comments/310099.html</wfw:comment><comments>http://www.blogjava.net/ysqwertys/archive/2010/01/19/310099.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/ysqwertys/comments/commentRss/310099.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/ysqwertys/services/trackbacks/310099.html</trackback:ping><description><![CDATA[<h3><a href="http://rubys.javaeye.com/blog/339033">&lt;meta http-equiv=...&gt; 的功能</a></h3>
<div class="blog_content">1.定义语言 &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　格式： &nbsp; &nbsp; <br />
&nbsp; 　　〈meta http－equiv=&#8243;Content－Type&#8243; content=&#8243;text/html; charset=gb2312&#8243;〉 &nbsp; &nbsp; &nbsp; <br />
<p>&nbsp; 　　这是META最常见的用法,在制作网页时,在纯HTML代码下都会看到它,它起的作用是定义你网页的语言,当访客浏览你的网页时,浏览器会自动识别并设置网页&nbsp;&nbsp;&nbsp; 中的语言,如果你网页设置的是GB码,而访客没有安装GB码,这时网页只会呈现访客人所设置的浏览器默认语言。同样的,如果该网页是英语,那么 charset=en。 &nbsp; </p>
&nbsp; &nbsp; <br />
2.描述网页 &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　格式: &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　〈meta name=&#8243;Keywords&#8243; CONTENT=&#8243;china,enterprise,business,net&#8243;〉 &nbsp; &nbsp; <br />
&nbsp; 　　META也常用来描述网页,以供某些搜索站台机器人的使用。大家知道,搜索站台分为两大类,一类为完全人工登录,比如Yahoo；另一类为机器人搜 索,以机器人搜索的搜索站台会包含更多的内容。机器人会搜索网页META标签中所设置的描述关键字,把它们加入到搜索数据库中,用来索引你的网页。而这个 标签很少有人注意到。在格式中,Content列出了你所设置的关键字,这其中的内容可以自行设置,其间用逗号相隔。这里有个技巧,你可以重复某一个单 词,这样可以提高自己网站的排行位置,如：&nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　〈meta name=&#8243;Keywords&#8243; CONTENT=&#8243;china,china,china,china〉 &nbsp; <br />
&nbsp; &nbsp; <br />
3.自动刷新页面 &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　格式: &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　〈meta HTTP－EQUIV=&#8243;refresh&#8243; CONTENT=&#8243;8;URL=网址或者是 action|servlet&#8243;〉 &nbsp; <br />
&nbsp; 　　大家在浏览某一个网页时,会发现有些页在数秒后自动转到另外一页,这就是META的刷新作用,在CONTENT中,8代表设置的秒数,而URL就是过8秒后自动连接的网页地址。 &nbsp; <br />
&nbsp; &nbsp; <br />
4.网页定级评价 &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　格式: &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　〈META &nbsp; http－equiv=&#8243;PICS－Label&#8243; content=&#8242;(PICS－1.1 &nbsp; &#8243;http://www.163.coml&#8243; &nbsp; l &nbsp; gen &nbsp; true &nbsp; comment &nbsp; &#8243;RSACi &nbsp; North &nbsp; America &nbsp; Server&#8243; &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　 &nbsp; for &nbsp; &#8243;http://www.163.com&#8243; &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　 &nbsp; on &nbsp; &#8243;1996.04.16T08:15－0500&#8243;<br />
&nbsp; 　　 &nbsp; r &nbsp; (n &nbsp; 0 &nbsp; s &nbsp; 0 &nbsp; v &nbsp; 0 &nbsp; l &nbsp; 0))&#8242;〉 <br />
&nbsp; 　　在Internet &nbsp; Explorer &nbsp; 4.0浏览器Internet选项中有一个内容设置,它可以防止浏览一些受限制的网站,而之所以浏览器会自动识别某些网站是否受限制,就是因为在网站 META标签中已经设置好了该网站的级别,而该级别的评定是由美国RSAC,即娱乐委员会的评级机构评定的,如果你需要评价自己的网站,可以连接到网站 http://www.163.com/,按要求提交表格,那么RSAC会提供一段META代码给你,复制到自己网页里就可以了。 &nbsp; <br />
&nbsp; &nbsp; <br />
5.控制页面缓冲 &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　格式: &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　〈meta &nbsp; HTTP－EQUIV=&#8243;expires&#8243; &nbsp; CONTENT=&#8243;TUE,11.NOV &nbsp; 1998 &nbsp; 00:00 &nbsp; GMT&#8243;〉 &nbsp; &nbsp; &nbsp; <br />
<p>&nbsp; 　　META可以设置网页到期的时间,也就是说,当你在Internet &nbsp; Explorer &nbsp; 4.0浏览器中设置浏览网页时首先查看本地缓冲里的页面,那么当浏览某一网页,而本地缓冲又有时,那么浏览器会自动浏览缓冲区里的页面,直到META中设 置的时间到期,这时候,浏览器才会去取得新页面。 &nbsp; </p>
&nbsp; &nbsp; <br />
6.META的属性 &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　HTTP－EQUIV=&#8243;....&#8243; &nbsp; HTTP响应的标题头； &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　name=&#8243;.....&#8243; &nbsp; META信息的名称； &nbsp; &nbsp; &nbsp; <br />
&nbsp; 　　content=&#8243;....&#8243; &nbsp; META信息的具体内容；&nbsp; &nbsp; <br />
<p>&nbsp; 　　scheme=&#8243;...&#8243; &nbsp; META信息的图解。 </p>
<p>&nbsp;&nbsp;</p>
</div>
<img src ="http://www.blogjava.net/ysqwertys/aggbug/310099.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/ysqwertys/" target="_blank">lucas_y</a> 2010-01-19 16:43 <a href="http://www.blogjava.net/ysqwertys/archive/2010/01/19/310099.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>