/Users/lyon/j4p/src/javassist/sample/evolve/demo.html

1    <H2>Class Evolution</H2> 
2     
3    <P>This is a demonstration of the class evolution mechanism 
4    implemented with Javassist.  This mechanism enables a Java program to 
5    reload an existing class file.  Although the reloaded class file is 
6    not applied to exiting objects (the old class file is used for those 
7    objects), it is effective in newly created objects. 
8     
9    <P>Since the reloading is transparently executed, no programming 
10   convention is needed.  However, there are some limitations on possible 
11   changes of the class definition.  For example, the new class definition 
12   must have the same set of methods as the old one.  These limitations are 
13   necessary for keeping the type system consistent. 
14    
15    
16   <H3><a href="java.html">Run WebPage.show()</a></H3> 
17    
18   <P>The web server creates a new <code>WebPage</code> object and 
19   calls <code>show()</code> on that object.  This method works as 
20   if it is a CGI script or a servlet and you will see the html file 
21   produced by this method on your browser. 
22    
23   <H3><a href="update.html">Change WebPage.class</a></H3> 
24    
25   <P>The web server overwrites class file <code>WebPage.class</code> 
26   on the local disk.  Then it signals that <code>WebPage.class</code> 
27   must be reloaded into the JVM.  If you run <code>WebPage.show()</code> 
28   again, you will see a different page on your browser. 
29    
30   <H3>Source files</H3> 
31    
32   <P>Web server: <A HREF="DemoServer.java"><code>DemoServer.java</code></A> 
33    
34   <P>WebPage: <A HREF="WebPage.java"><code>WebPage.java</code></A> 
35    
36   <P>Class loader: <A HREF="DemoLoader.java"><code>DemoLoader.java</code></A>, 
37       <A HREF="Evolution.java"><code>Evolution.java</code></A>, and 
38       <A HREF="VersionManager.java"><code>VersionManager.java</code></A>. 
39