java中的一些基本应用

分布式计算的第一次课,法师给了几份代码,要求仔细阅读后理解代码,为接下来的进一步学习做准备。代码涉及到的应该都是分布式计算的基础,相信接下来的开发会用到,这里先做一下总结。代码总共涉及到以下五个方面:

  1. java语言的异常捕获和处理机制
  2. 基于socket API开发的基本原理
  3. 多线程机制
  4. java序列化与反序列化机制
  5. java语言的反射机制
java语言的异常捕获和处理机制:

这方面的内容相信写过java代码的人都知道了,Java采用将出错处理和正常代码分开的方法来实现异常处理。每当Java程序运行过程中发生一个可识别的运行错误时,即该错误有一个异常类与之相对应时,系统都会产生一个相应的该异常类的对象,即产生一个异常。一旦一个异常对象产生了,系统中就一定有相应的机制来处理它,确保不会产生死机、死循环或其他对操作系统的损害,从而保证了整个程序运行的安全性。

  1. // 捕获与处理异常例程   
  2. class Account {  
  3.     private double balance = 1000;  
  4.     public void transfer(double amount)throws OutOfMoney {  
  5.         // 在方法中声明抛出异常   
  6.         if (balance < amount)  
  7.         // 直接抛出异常   
  8.             throw new OutOfMoney("[Balance:" + balance + " < Amount:" + amount + "]");  
  9.         balance = balance - amount;  
  10.     }  
  11.     public double getBalance() {  
  12.         return balance;  
  13.     }  
  14. }  
  15. class OutOfMoney extends Exception {  
  16.     public OutOfMoney() {  
  17.         // 给出该异常的一个缺省的字符串描述   
  18.         super("Your account have not enough money!");  
  19.     }  
  20.     public OutOfMoney(String msg) {  
  21.         // 允许使用者自行给出对异常的一个字符串描述   
  22.         super(msg);  
  23.     }  
  24. }  
  25. public class AccountException {  
  26.     public static void main(String[]args) {  
  27.         Account obj = new Account();  
  28.         double amount = 800;  
  29.         for (int count = 0; count < 3; count++) {  
  30.             try {  
  31.                 obj.transfer(amount);  
  32.                 System.out.println("Transfer amount: " + amount + ", and then balance: " + obj.getBalance());  
  33.             } catch (OutOfMoney exc) {  
  34.                 exc.printStackTrace();  
  35.             } finally  {  
  36.                 System.out.println("finally语句块中的语句总是会执行!");  
  37.             }  
  38.             amount = amount - 300;  
  39.         }  
  40.     }  
  41. }  
// 捕获与处理异常例程
class Account {
    private double balance = 1000;
    public void transfer(double amount)throws OutOfMoney {
        // 在方法中声明抛出异常
        if (balance < amount)
        // 直接抛出异常
            throw new OutOfMoney("[Balance:" + balance + " < Amount:" + amount + "]");
        balance = balance - amount;
    }
    public double getBalance() {
        return balance;
    }
}
class OutOfMoney extends Exception {
    public OutOfMoney() {
        // 给出该异常的一个缺省的字符串描述
        super("Your account have not enough money!");
    }
    public OutOfMoney(String msg) {
        // 允许使用者自行给出对异常的一个字符串描述
        super(msg);
    }
}
public class AccountException {
    public static void main(String[]args) {
        Account obj = new Account();
        double amount = 800;
        for (int count = 0; count < 3; count++) {
            try {
                obj.transfer(amount);
                System.out.println("Transfer amount: " + amount + ", and then balance: " + obj.getBalance());
            } catch (OutOfMoney exc) {
                exc.printStackTrace();
            } finally  {
                System.out.println("finally语句块中的语句总是会执行!");
            }
            amount = amount - 300;
        }
    }
}

基于socket API开发的基本原理:

  1. // 简单的利用流套接字实现通信的服务端程序   
  2. import java.io.*;  
  3. import java.net.*;  
  4.   
  5. public class MyServer {  
  6.     public static void main(String[] args)throws IOException {  
  7.         if (args.length != 1) {  
  8.             System.out.println("用法:EchoServer <端口号>");  
  9.             return ;  
  10.         }  
  11.         // 创建 ServerSocket 实例,建立连接   
  12.         ServerSocket server = new ServerSocket(Integer.parseInt(args[0]));  
  13.         System.out.println("服务程序正在监听端口" + args[0]);  
  14.         // 监听客户程序的连接请求   
  15.         Socket client = server.accept();  
  16.         BufferedReader in = new BufferedReader(new InputStreamReader(client.getInputStream()));  
  17.         PrintWriter out = new PrintWriter(client.getOutputStream());  
  18.         // 从客户端读取数据,并打印在屏幕上,如果接收到”End”,则退出程序。   
  19.         String str;  
  20.         System.out.println("客户端已经建立连接");  
  21.         while ((str = in.readLine()) != null) {  
  22.             System.out.println(str);  
  23.             System.out.println("收到请求:" + str);  
  24.             out.println("服务端已经收到请求:" + str);  
  25.             out.flush();  
  26.             if (str.equals("end")) {  
  27.                 System.out.println("通信已经终止");  
  28.                 break;  
  29.             }  
  30.         }  
  31.         // 关闭连接   
  32.         out.close();  
  33.         in.close();  
  34.         client.close();  
  35.     }  
  36. }  
// 简单的利用流套接字实现通信的服务端程序
import java.io.*;
import java.net.*;

public class MyServer {
    public static void main(String[] args)throws IOException {
        if (args.length != 1) {
            System.out.println("用法:EchoServer <端口号>");
            return ;
        }
        // 创建 ServerSocket 实例,建立连接
        ServerSocket server = new ServerSocket(Integer.parseInt(args[0]));
        System.out.println("服务程序正在监听端口" + args[0]);
        // 监听客户程序的连接请求
        Socket client = server.accept();
        BufferedReader in = new BufferedReader(new InputStreamReader(client.getInputStream()));
        PrintWriter out = new PrintWriter(client.getOutputStream());
        // 从客户端读取数据,并打印在屏幕上,如果接收到”End”,则退出程序。
        String str;
        System.out.println("客户端已经建立连接");
        while ((str = in.readLine()) != null) {
            System.out.println(str);
            System.out.println("收到请求:" + str);
            out.println("服务端已经收到请求:" + str);
            out.flush();
            if (str.equals("end")) {
                System.out.println("通信已经终止");
                break;
            }
        }
        // 关闭连接
        out.close();
        in.close();
        client.close();
    }
}

  1. // 简单的利用流套接字实现通信的客户端程序   
  2. import java.net.*;  
  3. import java.io.*;  
  4.   
  5. public class MyClient {  
  6.     static Socket server;  
  7.   
  8.     public static void main(String[] args)throws Exception {  
  9.         if (args.length != 2) {  
  10.             System.out.println("用法:MyClient <主机名> <端口号>");  
  11.             return ;  
  12.         }  
  13.         // 获取本地ip地址,访问在本地的服务程序,缺省端口是:1234   
  14.         Socket server = new Socket(args[0], Integer.parseInt(args[1]));  
  15.         // 建立连接并打开相关联的输入流和输出流   
  16.         BufferedReader in = new BufferedReader(new InputStreamReader (server.getInputStream()));  
  17.         PrintWriter out = new PrintWriter(server.getOutputStream());  
  18.         BufferedReader wt = new BufferedReader(new InputStreamReader(System.in));  
  19.         // 将控制台输入的字符串发送给服务端,如果接收到"end",则退出程序。   
  20.         while (true) {  
  21.             String str = wt.readLine();  
  22.             out.println(str);  
  23.             out.flush();  
  24.             if (str.equals("end")) {  
  25.                 System.out.println("通信已经终止");  
  26.                 break;  
  27.             }  
  28.             System.out.println(in.readLine());  
  29.         }  
  30.         // 关闭连接   
  31.         wt.close();  
  32.         out.close();  
  33.         in.close();  
  34.         server.close();  
  35.     }  
  36. }  
// 简单的利用流套接字实现通信的客户端程序
import java.net.*;
import java.io.*;

public class MyClient {
    static Socket server;

    public static void main(String[] args)throws Exception {
        if (args.length != 2) {
            System.out.println("用法:MyClient <主机名> <端口号>");
            return ;
        }
        // 获取本地ip地址,访问在本地的服务程序,缺省端口是:1234
        Socket server = new Socket(args[0], Integer.parseInt(args[1]));
        // 建立连接并打开相关联的输入流和输出流
        BufferedReader in = new BufferedReader(new InputStreamReader (server.getInputStream()));
        PrintWriter out = new PrintWriter(server.getOutputStream());
        BufferedReader wt = new BufferedReader(new InputStreamReader(System.in));
        // 将控制台输入的字符串发送给服务端,如果接收到"end",则退出程序。
        while (true) {
            String str = wt.readLine();
            out.println(str);
            out.flush();
            if (str.equals("end")) {
                System.out.println("通信已经终止");
                break;
            }
            System.out.println(in.readLine());
        }
        // 关闭连接
        wt.close();
        out.close();
        in.close();
        server.close();
    }
}

多线程机制:

两个小例子,代码很简单,分别是通过实现Runnable接口定义新线程以及通过继承thread类定义新线程。

  1. // 通过实现Runnable接口定义新线程   
  2. class Counter implements Runnable {  
  3.     public void run() {  
  4.         for (int i = 0; i < 100; i++)  
  5.             System.out.println("计数器= " + i);  
  6.     }  
  7. }  
  8. public class RunnableThread {  
  9.     public static void main(String[] args) {  
  10.         Counter counter = new Counter();  
  11.         Thread thread = new Thread(counter);  
  12.         thread.start();  
  13.         System.out.println("主程序结束");  
  14.     }  
  15. }  
// 通过实现Runnable接口定义新线程
class Counter implements Runnable {
    public void run() {
        for (int i = 0; i < 100; i++)
            System.out.println("计数器= " + i);
    }
}
public class RunnableThread {
    public static void main(String[] args) {
        Counter counter = new Counter();
        Thread thread = new Thread(counter);
        thread.start();
        System.out.println("主程序结束");
    }
}

  1. // 通过继承Thread类定义新线程   
  2. public class SubclassThread extends Thread {  
  3.     public void run() {  
  4.         while (true) {  
  5.             // 执行线程自身的任务   
  6.             try {  
  7.                 sleep(5 * 1000);  
  8.                 break;  
  9.             } catch (InterruptedException exc) {  
  10.             // 睡眠被中断   
  11.             }  
  12.         }  
  13.     }  
  14.     public static void main(String[] args) {  
  15.         Thread thread = new SubclassThread();  
  16.         thread.start();  
  17.         System.out.println("主程序结束");  
  18.     }  
  19. }  
// 通过继承Thread类定义新线程
public class SubclassThread extends Thread {
    public void run() {
        while (true) {
            // 执行线程自身的任务
            try {
                sleep(5 * 1000);
                break;
            } catch (InterruptedException exc) {
            // 睡眠被中断
            }
        }
    }
    public static void main(String[] args) {
        Thread thread = new SubclassThread();
        thread.start();
        System.out.println("主程序结束");
    }
}

java序列化与反序列化机制:

无论是何种类型的数据,都是以二进制序列的形式在网络上传送,所以需要发送进程将对象转换为字节序列,才能在网络上传送;接收进程则需要把字节序列再恢复为对象。在进程间消息通信过程中,把Java对象转换为字节序列的过程称为对象的序列化。把字节序列恢复为Java对象的过程称为对象的反序列化。因此,对象的序列化主要有两种用途:将对象的字节序列持久化,保存在文件系统中;在网络上传送对象的字节序列。 

  1. // 测试对象的序列化和反序列化   
  2. import java.io.*;  
  3.   
  4. public class AccountSerializable {  
  5.     public static void main(String[] args)throws Exception {  
  6.         // 创建本地文件输入流   
  7.         File f = new File("objectFile.obj");  
  8.         ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(f));  
  9.         // 序列化对象   
  10.         Account Account1 = new Account("Zhang3"1000);  
  11.         Account Account2 = new Account("Li4"2000);  
  12.         out.writeObject(Account1);  
  13.         out.writeObject(Account2);  
  14.         out.close();  
  15.         // 反序列化对象   
  16.         ObjectInputStream in = new ObjectInputStream(new FileInputStream(f));  
  17.         Account obj1 = (Account)in.readObject();  
  18.         System.out.println("Account1=" + obj1);  
  19.         Account obj2 = (Account)in.readObject();  
  20.         System.out.println("Account2=" + obj2);  
  21.         in.close();  
  22.     }  
  23. }  
  24.   
  25. // Account类实现java.io.Serializable接口   
  26. class Account implements Serializable {  
  27.     private String name;  
  28.     private double balance;  
  29.     public Account(String name, double balance) {  
  30.         this.name = name;  
  31.         this.balance = balance;  
  32.     }  
  33.     public String toString() {  
  34.         return "name=" + name + ", balance=" + balance;  
  35.     }  
  36. }  
// 测试对象的序列化和反序列化
import java.io.*;

public class AccountSerializable {
    public static void main(String[] args)throws Exception {
        // 创建本地文件输入流
        File f = new File("objectFile.obj");
        ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(f));
        // 序列化对象
        Account Account1 = new Account("Zhang3", 1000);
        Account Account2 = new Account("Li4", 2000);
        out.writeObject(Account1);
        out.writeObject(Account2);
        out.close();
        // 反序列化对象
        ObjectInputStream in = new ObjectInputStream(new FileInputStream(f));
        Account obj1 = (Account)in.readObject();
        System.out.println("Account1=" + obj1);
        Account obj2 = (Account)in.readObject();
        System.out.println("Account2=" + obj2);
        in.close();
    }
}

// Account类实现java.io.Serializable接口
class Account implements Serializable {
    private String name;
    private double balance;
    public Account(String name, double balance) {
        this.name = name;
        this.balance = balance;
    }
    public String toString() {
        return "name=" + name + ", balance=" + balance;
    }
}


java语言的反射机制:

Java语言的反射(Reflection)机制可以在程序运行时判断任意一个对象所属的类,构造任意一个类的对象,判断任意一个类所具有的成员变量和方法,调用任意一个对象的方法,或者生成动态代理。

  1. // 演示Reflection的基本使用方法   
  2. import java.lang.reflect.*;  
  3. public class AccountReflect {  
  4.     public Object copy(Object object)throws Exception {  
  5.         // 获得对象的类型   
  6.         Class classType = object.getClass();  
  7.         System.out.println("Class:" + classType.getName());  
  8.         // 通过默认构造方法创建一个新的对象   
  9.         Object objectCopy = classType.getConstructor(new Class[]{}).newInstance(new Object[]{});  
  10.         // 获得对象的所有属性   
  11.         Field fields[] = classType.getDeclaredFields();  
  12.         for (int i = 0; i < fields.length; i++) {  
  13.             Field field = fields[i];  
  14.             String fieldName = field.getName();  
  15.             String firstLetter = fieldName.substring(0,1).toUpperCase();  
  16.             // 获得和属性对应的getXXX()方法的名字   
  17.             String getMethodName = "get" + firstLetter + fieldName.substring(1);  
  18.             // 获得和属性对应的setXXX()方法的名字   
  19.             String setMethodName = "set" + firstLetter + fieldName.substring(1);  
  20.             // 获得和属性对应的getXXX()方法   
  21.             Method getMethod = classType.getMethod(getMethodName, new Class[]{});  
  22.             // 获得和属性对应的setXXX()方法   
  23.             Method setMethod = classType.getMethod(setMethodName, new Class[] {field.getType()});  
  24.             // 调用原对象的getXXX()方法   
  25.             Object value = getMethod.invoke(object, new Object[]{});  
  26.             System.out.println(fieldName + ":" + value);  
  27.             // 调用复制对象的setXXX()方法   
  28.             setMethod.invoke(objectCopy, new Object[]{value});  
  29.         }  
  30.         return objectCopy;  
  31.     }  
  32.     public static void main(String[] args)throws Exception {  
  33.         Account Account = new Account("Zhang3"1000);  
  34.         Account AccountCopy = (Account)new AccountReflect().copy(Account);  
  35.         System.out.println("Copy information:" + AccountCopy.getName() + " " + AccountCopy.getBalance());  
  36.     }  
  37. }  
  38.   
  39. // Account类   
  40. class Account {  
  41.     private String name;  
  42.     private int balance;  
  43.     public Account(){}  
  44.     public Account(String name, int balance) {  
  45.         this.name = name;  
  46.         this.balance = balance;  
  47.     }  
  48.     public String getName() {  
  49.         return name;  
  50.     }  
  51.     public void setName(String name) {  
  52.         this.name = name;  
  53.     }  
  54.     public int getBalance() {  
  55.         return balance;  
  56.     }  
  57.     public void setBalance(int balance) {  
  58.         this.balance = balance;  
  59.     }  
  60. }  
// 演示Reflection的基本使用方法
import java.lang.reflect.*;
public class AccountReflect {
    public Object copy(Object object)throws Exception {
        // 获得对象的类型
        Class classType = object.getClass();
        System.out.println("Class:" + classType.getName());
        // 通过默认构造方法创建一个新的对象
        Object objectCopy = classType.getConstructor(new Class[]{}).newInstance(new Object[]{});
        // 获得对象的所有属性
        Field fields[] = classType.getDeclaredFields();
        for (int i = 0; i < fields.length; i++) {
            Field field = fields[i];
            String fieldName = field.getName();
            String firstLetter = fieldName.substring(0,1).toUpperCase();
            // 获得和属性对应的getXXX()方法的名字
            String getMethodName = "get" + firstLetter + fieldName.substring(1);
            // 获得和属性对应的setXXX()方法的名字
            String setMethodName = "set" + firstLetter + fieldName.substring(1);
            // 获得和属性对应的getXXX()方法
            Method getMethod = classType.getMethod(getMethodName, new Class[]{});
            // 获得和属性对应的setXXX()方法
            Method setMethod = classType.getMethod(setMethodName, new Class[] {field.getType()});
            // 调用原对象的getXXX()方法
            Object value = getMethod.invoke(object, new Object[]{});
            System.out.println(fieldName + ":" + value);
            // 调用复制对象的setXXX()方法
            setMethod.invoke(objectCopy, new Object[]{value});
        }
        return objectCopy;
    }
    public static void main(String[] args)throws Exception {
        Account Account = new Account("Zhang3", 1000);
        Account AccountCopy = (Account)new AccountReflect().copy(Account);
        System.out.println("Copy information:" + AccountCopy.getName() + " " + AccountCopy.getBalance());
    }
}

// Account类
class Account {
    private String name;
    private int balance;
    public Account(){}
    public Account(String name, int balance) {
        this.name = name;
        this.balance = balance;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getBalance() {
        return balance;
    }
    public void setBalance(int balance) {
        this.balance = balance;
    }
}

总结以上内容,通过反射机制,客户端可以将向服务端发出的请求对象进行封装,客户端只需要知道远程对象名及其提供服务的方法名,就可以与服务端实现通信。示例代码如下:

  1. //远程对象接口   
  2. public interface AccountService {  
  3.     public String getAccount(String Name);  
  4. }  
//远程对象接口
public interface AccountService {
    public String getAccount(String Name);
}

  1. //远程对象接口的实现类   
  2. public class AccountServiceImpl implements AccountService {  
  3.     public String getAccount(String Name) {  
  4.         return "Account id: " + Name;  
  5.     }  
  6. }  
//远程对象接口的实现类
public class AccountServiceImpl implements AccountService {
    public String getAccount(String Name) {
        return "Account id: " + Name;
    }
}

  1. //远程调用对象   
  2. import java.io.*;  
  3. public class RemoteCall implements Serializable {  
  4.     private String className; //表示类名或接口名   
  5.     private String methodName; //表示方法名   
  6.     private Class[] paramTypes; //表示方法参数类型   
  7.     private Object[] params; //表示方法参数值   
  8.   
  9.     //表示方法的执行结果   
  10.     //如果方法正常执行,则result为方法返回值,如果方法抛出异常,那么result为该异常。   
  11.     private Object result;  
  12.     public RemoteCall(){}  
  13.     public RemoteCall(String className, String methodName, Class[] paramTypes,  
  14.         Object[] params) {  
  15.         this.className = className;  
  16.         this.methodName = methodName;  
  17.         this.paramTypes = paramTypes;  
  18.         this.params = params;  
  19.     }  
  20.   
  21.     public String getClassName() {  
  22.         return className;  
  23.     }  
  24.     public void setClassName(String className) {  
  25.         this.className = className;  
  26.     }  
  27.   
  28.     public String getMethodName() {  
  29.         return methodName;  
  30.     }  
  31.     public void setMethodName(String methodName) {  
  32.         this.methodName = methodName;  
  33.     }  
  34.   
  35.     public Class[] getParamTypes() {  
  36.         return paramTypes;  
  37.     }  
  38.     public void setParamTypes(Class[] paramTypes) {  
  39.         this.paramTypes = paramTypes;  
  40.     }  
  41.   
  42.     public Object[] getParams() {  
  43.         return params;  
  44.     }  
  45.     public void setParams(Object[] params) {  
  46.         this.params = params;  
  47.     }  
  48.   
  49.     public Object getResult() {  
  50.         return result;  
  51.     }  
  52.     public void setResult(Object result) {  
  53.         this.result = result;  
  54.     }  
  55.   
  56.     public String toString() {  
  57.         return "className=" + className + " methodName=" + methodName;  
  58.     }  
  59. }  
//远程调用对象
import java.io.*;
public class RemoteCall implements Serializable {
    private String className; //表示类名或接口名
    private String methodName; //表示方法名
    private Class[] paramTypes; //表示方法参数类型
    private Object[] params; //表示方法参数值

    //表示方法的执行结果
    //如果方法正常执行,则result为方法返回值,如果方法抛出异常,那么result为该异常。
    private Object result;
    public RemoteCall(){}
    public RemoteCall(String className, String methodName, Class[] paramTypes,
        Object[] params) {
        this.className = className;
        this.methodName = methodName;
        this.paramTypes = paramTypes;
        this.params = params;
    }

    public String getClassName() {
        return className;
    }
    public void setClassName(String className) {
        this.className = className;
    }

    public String getMethodName() {
        return methodName;
    }
    public void setMethodName(String methodName) {
        this.methodName = methodName;
    }

    public Class[] getParamTypes() {
        return paramTypes;
    }
    public void setParamTypes(Class[] paramTypes) {
        this.paramTypes = paramTypes;
    }

    public Object[] getParams() {
        return params;
    }
    public void setParams(Object[] params) {
        this.params = params;
    }

    public Object getResult() {
        return result;
    }
    public void setResult(Object result) {
        this.result = result;
    }

    public String toString() {
        return "className=" + className + " methodName=" + methodName;
    }
}

  1. // 客户端程序   
  2. import java.io.*;  
  3. import java.net.*;  
  4. import java.util.*;  
  5.   
  6. public class RemoteClient {  
  7.     public void invoke()throws Exception {  
  8.         Socket socket = new Socket("localhost"8000);  
  9.         OutputStream out = socket.getOutputStream();  
  10.         ObjectOutputStream oos = new ObjectOutputStream(out);  
  11.         InputStream in = socket.getInputStream();  
  12.         ObjectInputStream ois = new ObjectInputStream(in);  
  13.         RemoteCall call = new RemoteCall("AccountService""getAccount"new Class[] { String.class }, new Object[] {"Zhang3"});  
  14.           
  15.         // 向服务器发送Call 对象   
  16.         oos.writeObject(call);  
  17.         // 接收包含了方法执行结果的Call 对象   
  18.         call = (RemoteCall)ois.readObject();  
  19.         System.out.println(call.getResult());  
  20.         ois.close();  
  21.         oos.close();  
  22.         socket.close();  
  23.     }  
  24.   
  25.     public static void main(String args[])throws Exception {  
  26.         new RemoteClient().invoke();  
  27.     }  
  28. }  
// 客户端程序
import java.io.*;
import java.net.*;
import java.util.*;

public class RemoteClient {
    public void invoke()throws Exception {
        Socket socket = new Socket("localhost", 8000);
        OutputStream out = socket.getOutputStream();
        ObjectOutputStream oos = new ObjectOutputStream(out);
        InputStream in = socket.getInputStream();
        ObjectInputStream ois = new ObjectInputStream(in);
        RemoteCall call = new RemoteCall("AccountService", "getAccount", new Class[] { String.class }, new Object[] {"Zhang3"});
        
        // 向服务器发送Call 对象
        oos.writeObject(call);
        // 接收包含了方法执行结果的Call 对象
        call = (RemoteCall)ois.readObject();
        System.out.println(call.getResult());
        ois.close();
        oos.close();
        socket.close();
    }

    public static void main(String args[])throws Exception {
        new RemoteClient().invoke();
    }
}

  1. //服务端程序   
  2. import java.io.*;  
  3. import java.net.*;  
  4. import java.util.*;  
  5. import java.lang.reflect.*;  
  6.   
  7. public class Server {  
  8.     // 存放远程对象的缓存   
  9.     private Map remoteObjects = new HashMap();  
  10.     // 把一个远程对象放到缓存中   
  11.     public void register(String className, Object remoteObject) {  
  12.         remoteObjects.put(className, remoteObject);  
  13.     }  
  14.     public void service()throws Exception {  
  15.         // 创建基于流的Socket,并在8000端口监听   
  16.         ServerSocket serverSocket = new ServerSocket(8000);  
  17.         System.out.println("服务器启动......");  
  18.         while (true) {  
  19.             Socket socket = serverSocket.accept();  
  20.             InputStream in = socket.getInputStream();  
  21.             ObjectInputStream ois = new ObjectInputStream(in);  
  22.             OutputStream out = socket.getOutputStream();  
  23.             ObjectOutputStream oos = new ObjectOutputStream(out);  
  24.             RemoteCall remotecallobj = (RemoteCall)ois.readObject();   
  25.                 //接收客户发送的Call对象   
  26.             System.out.println(remotecallobj);  
  27.             remotecallobj = invoke(remotecallobj); //调用相关对象的方法   
  28.             oos.writeObject(remotecallobj);   
  29.                 //向客户发送包含了执行结果的remotecallobj对象   
  30.             ois.close();  
  31.             oos.close();  
  32.             socket.close();  
  33.         }  
  34.     }  
  35.   
  36.     public RemoteCall invoke(RemoteCall call) {  
  37.         Object result = null;  
  38.         try {  
  39.             String className = call.getClassName();  
  40.             String methodName = call.getMethodName();  
  41.             Object[] params = call.getParams();  
  42.             Class classType = Class.forName(className);  
  43.             Class[] paramTypes = call.getParamTypes();  
  44.             Method method = classType.getMethod(methodName, paramTypes);  
  45.             Object remoteObject = remoteObjects.get(className);   
  46.                 //从缓存中取出相关的远程对象   
  47.             if (remoteObject == null) {  
  48.                 throw new Exception(className + "的远程对象不存在");  
  49.             } else {  
  50.                 result = method.invoke(remoteObject, params);  
  51.             }  
  52.         } catch (Exception e) {  
  53.             result = e;  
  54.         }  
  55.         call.setResult(result); //设置方法执行结果   
  56.         return call;  
  57.     }  
  58.   
  59.     public static void main(String args[])throws Exception {  
  60.         Server server = new Server();  
  61.         //把事先创建的RemoteServiceImpl 对象加入到服务器的缓存中   
  62.         server.register("AccountService"new AccountServiceImpl());  
  63.         server.service();  
  64.     }  
  65. }  
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值