事实上,CORBA或Java RMI的实现方式与此类似,只不过远没有这么简单而已。这个程序对于说明分布式对象应用程序的执行机理是很有用的。
程序源代码如下所示:
文件Dog.java
public interface Dog
{
public String getName() throws Exception;
}/* Dog */
文件DogClient.java
public class DogClient
{
public static void main( String[] args ) throws Exception
{
Dog dog = new Dog_Stub();
String strName = dog.getName();
System.out.println( "姓名:" + strName );
}//main()
}/* DogClient */
文件DogServer.java
public class DogServer implements Dog
{
String strName;
int intAge;
public String getName() throws Exception
{
return strName;
}//getName()
public DogServer( String strNameInput )
{
strName = strNameInput;
}//DogServer()
public static void main( String[] args ) throws Exception
{
New Dog_Skeleton( new DogServer( "TOMCAT" ) );
}//main()
}/* DogServer */
文件Dog_Skeleton.java
import java.io.*;
import java.net.*;
public class Dog_Skeleton extends Thread
{
static ServerSocket ss = null;
DogServer ds;
public Dog_Skeleton( DogServer dsInput ) throws Exception
{
ds = dsInput;
if ( ss == null )
ss = new ServerSocket( 8000 );
this.start();
}//Dog_Skeleton()
public synchronized void run()
{
Try
{
while ( ss != null )
{
Socket socket = ss.accept();
ObjectInputStream ois = new ObjectInputStream( socket.getInputStream() );
ObjectOutputStream oos = new ObjectOutputStream( socket.getOutputStream() );
String strMethodName = ( String )ois.readObject();
if ( strMethodName.equals( "getName()" ) )
oos.writeObject( ds.getName() );
oos.flush();
ois.close();
oos.close();
socket.close();
}//while
}//try
catch( Exception e )
{
e.printStackTrace();
}//catch
}//run()
}/* Dog_Skeleton */
文件Dog_Stub.java
import java.io.*;
import java.net.*;
Public class Dog_Stub implements Dog
{
Socket socket;
ObjectOutputStream oos;
ObjectInputStream ois;
public Dog_Stub() throws Exception
{
socket = new Socket( "wudi", 8000 );
Oos = new ObjectOutputStream( socket.getOutputStream() );
Ois = new ObjectInputStream( socket.getInputStream() );
}//Dog_Stub()
public String getName() throws Exception
{
Oos.writeObject( "getName()" );
Oos.flush();
return ( String )ois.readObject();
}//getName()
}/* Dog_Stub */
运行该分布式对象程序时,首先运行DogServer,然后在客户端运行DogClient即可看到结果。