在TCP网络连接上传递对象

本文通过示例代码展示了如何使用Java实现对象的序列化,并通过网络进行传输。具体包括了定义可序列化的Student类,创建服务器端发送序列化后的对象及客户端接收并解析该对象的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里写图片描述

实现代码:
Student.java文件代码:

import java.io.*;
public class Student implements Serializable{
   int id;
   String name;
   int age;
   String department;
   public Student(int id,String name,int age,String department) {
      // TODO Auto-generated constructor stub
      this.id = id;
      this.name = name;
      this.age = age;
      this.department = department;
   }

}

ObjectServer.java文件代码:

import java.net.*;
import java.io.*;
public class ObjectServer {

   public static void main(String[] args) throws Exception{
      // TODO Auto-generated method stub
      ServerSocket ss = new ServerSocket(8001);
      Socket s = ss.accept();
      OutputStream ops = s.getOutputStream();
      ObjectOutputStream oos = new ObjectOutputStream(ops);
      Student stu = new Student(19, "wangwu", 22, "huaxue");
      oos.writeObject(stu);

      oos.close();
      s.close();
      ss.close();
   }

}

ObjectClient.java文件代码:

import java.io.*;
import java.net.*;
public class ObjectClient {

   public static void main(String[] args) throws Exception{
      // TODO Auto-generated method stub
      Socket s = new Socket("127.0.0.1",8001);
      InputStream ips = s.getInputStream();
      ObjectInputStream ois = new ObjectInputStream(ips);

      Student stu = (Student)ois.readObject();
      System.out.println("id is " + stu.id);
      System.out.println("name is " + stu.name);
      System.out.println("age is " + stu.age);
      System.out.println("deparment is " + stu.department);

      ois.close();
      s.close();
   }

}

先运行ObjectServer程序之后再运行ObjectClient程序,ObjectClient程序会收到ObjectServer程序发来的stu对象。结果如下图:

这里写图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值