java类对象转化为byte数组

lijianli9 2011-08-27 07:12:39
本人有一个类
public class packhead implements Serializable
{
byte[] from = new byte[16];
byte[] to = new byte[16];
int ntype;
int nlength;
}
在socket通讯的时候这么写,但是效果却达不到,
packhead headheart = new packhead();
String strHeadFrom = "javaserver";
headheart.from = strHeadFrom.getBytes();
strHeadFrom = "vcclient";
headheart.to = strHeadFrom.getBytes();
headheart.nlength = 40;
headheart.ntype = 90;



Byte_File_Object objto= new Byte_File_Object();
byte[] bufobject1 = objto.getBytesFromObject(headheart);

System.out.print("\n转换后的数据为" + bufobject1);

packhead headto = (packhead) objto.getObjectFromBytes(bufobject1);

byte[] bufobject2 = objto.getBytesFromObject(headto);
System.out.print("\n反转回来" + bufobject2);
其中使用的转化类
class Byte_File_Object {

public static Object getObjectFromBytes(byte[] objBytes) throws Exception {
if (objBytes == null || objBytes.length == 0) {
return null;
}
ByteArrayInputStream bi = new ByteArrayInputStream(objBytes);
ObjectInputStream oi = new ObjectInputStream(bi);
return oi.readObject();
}

public static byte[] getBytesFromObject(Serializable obj) throws Exception {
if (obj == null) {
return null;
}
ByteArrayOutputStream bo = new ByteArrayOutputStream();
ObjectOutputStream oo = new ObjectOutputStream(bo);
oo.writeObject(obj);
return bo.toByteArray();
}

}
转化后的数据发送到客户端是乱码,而且转换前后数据都不对应了。
...全文
1504 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
TCH790177486 2012-03-12
  • 打赏
  • 举报
回复
楼主,是11楼的方法么?
lijianli9 2012-03-12
  • 打赏
  • 举报
回复
解决了。
可以和我QQ联系277823847,包括心跳,封包head,包体都实现了。
guaiguailaoda 2012-03-10
  • 打赏
  • 举报
回复
LZ问题解决了没?求解答啊
lijianli9 2011-08-27
  • 打赏
  • 举报
回复
我是java 和vc通讯出现问题,
ls的不一样,
xiazdong 2011-08-27
  • 打赏
  • 举报
回复
楼主其实不用这么麻烦。直接用ObjectOutputStream 和ObjectInputStream的readObject和writeObject方法即可。很方便
代码如下:
Client:

import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.io.Serializable;
import java.net.Socket;

public class Client {

public static void main(String[] args) throws Exception {
Socket s = new Socket("localhost", 8189);
OutputStream out = s.getOutputStream();
ObjectOutputStream objectout = new ObjectOutputStream(out);
packhead headheart = new packhead();
String strHeadFrom = "javaserver";
headheart.from = strHeadFrom.getBytes();
strHeadFrom = "vcclient";
headheart.to = strHeadFrom.getBytes();
headheart.nlength = 40;
headheart.ntype = 90;
objectout.writeObject(headheart);
System.out.println("发送完毕");
Thread.sleep(5000);
s.close();
}
}

class packhead implements Serializable {
byte[] from = new byte[16];
byte[] to = new byte[16];
int ntype;
int nlength;
}


Server:

import java.io.InputStream;
import java.io.ObjectInputStream;
import java.io.Serializable;
import java.net.ServerSocket;
import java.net.Socket;


public class Server {

public static void main(String[] args) throws Exception{
ServerSocket server = new ServerSocket(8189);
Socket s = server.accept();
InputStream in = s.getInputStream();
ObjectInputStream objectin = new ObjectInputStream(in);
System.out.println("1");
packhead receive = (packhead)objectin.readObject();
System.out.println("接收完毕");
byte[] from = receive.from;
byte[] to = receive.to;
int ntype = receive.ntype;
int nlength = receive.nlength;
String fromString = new String(from);
String toString = new String(to);
System.out.println(fromString);
System.out.println(toString);
System.out.println(nlength);
System.out.println(ntype);
s.close();
}

}

阳明 to life 2011-08-27
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 lijianli9 的回复:]

VC端已经不能修改了,现在是要在java端做类似的通讯机制。
我觉得socket通讯都是二进制流的形式,通讯应该是不存在问题,只是我刚接触java。
[/Quote]
那你C端是如何处理的 从对象转到Byte[]?
阳明 to life 2011-08-27
  • 打赏
  • 举报
回复
经这两个函数一转一般会出问题,你又不能保证java和c处理object to byte[]一定是一致的
getObjectFromBytes
getBytesFromObject
如果不想组件xml或json,直接按顺序from,to ,ntype,nlength输出过去也行吧
lijianli9 2011-08-27
  • 打赏
  • 举报
回复
VC端已经不能修改了,现在是要在java端做类似的通讯机制。
我觉得socket通讯都是二进制流的形式,通讯应该是不存在问题,只是我刚接触java。
阳明 to life 2011-08-27
  • 打赏
  • 举报
回复
你这个类并不复杂,组建xml或json传输吧,用字节流跨语言总感觉怪怪的
byte[]先转成Base64码
lijianli9 2011-08-27
  • 打赏
  • 举报
回复
使用BufferedInputStream,BufferedOutputStream后还是乱码,我接收VC client发送过来的结构体可以正常解析,但是java再将这个结构体发送出去,vc client端缺无法解析。
阳明 to life 2011-08-27
  • 打赏
  • 举报
回复
DataOutputStream 都是针对java对象的...
byte数组直接使用OutPutStream或者BufferedOutputStream
lijianli9 2011-08-27
  • 打赏
  • 举报
回复
DataInputStream dis = new DataInputStream(socket.getInputStream());
DataOutputStream dos = new DataOutputStream(socket.getOutputStream());

Byte_File_Object objto= new Byte_File_Object();
byte[] bufobject1 = objto.getBytesFromObject(headheart);
dos.write(bufobject1);
dos.flush();
那我转换后将这个字节发送给vc客户端,接收到得和发送的不一样,
淡定的峰哥 2011-08-27
  • 打赏
  • 举报
回复
你的类既然实现了Serializable接口,但是缺少一个
private static final long serialVersionUID = ×××××××××L;
这样的serialVersionUID 的属性
打油的程序员 2011-08-27
  • 打赏
  • 举报
回复
新旧Byte对象的hashcode不一样
打油的程序员 2011-08-27
  • 打赏
  • 举报
回复
完全可以:

import java.io.*;
import java.util.Arrays;

class PackHead implements Serializable {
byte[] from = new byte[16];
byte[] to = new byte[16];
int ntype;
int nlength;
public PackHead(byte[] from, byte[] to, int ntype, int nlength) {
super();
this.from = from;
this.to = to;
this.ntype = ntype;
this.nlength = nlength;
}

public String toString() {
return Arrays.toString(from) + " " + Arrays.toString(to) + " " + ntype + " " + nlength;
}
}

// 在socket通讯的时候这么写,但是效果却达不到,

public class ConvertByte {
public static void main(String[] args) throws Exception {

PackHead headheart = new PackHead("javaserver".getBytes(),"vcclient".getBytes(),40,90);
System.out.print("旧对象是");
System.out.println(headheart);

byte[] bufobject = Byte_File_Object.getBytesFromObject(headheart);


System.out.println("原对象转换后的字节对象为" + bufobject);
System.out.println("原对象转换后的字节数据为" );
for(int i=0 ; i<bufobject.length ; i++) {
System.out.print(bufobject[i] + " ");
}
System.out.println();

PackHead headto = (PackHead) Byte_File_Object
.getObjectFromBytes(bufobject);

System.out.print("新对象是");
System.out.println(headto);

byte[] bufobject2 = Byte_File_Object.getBytesFromObject(headto);

System.out.println("新对象转换后的字节数据为" + bufobject2);//此时是新对象,内存地址当然不同,结果的hashcode也是不同的
System.out.println("新对象转换后的字节数据为" );
for(int i=0 ; i<bufobject2.length ; i++) {
System.out.print(bufobject2[i] + " ");
}
System.out.println();

}
}

class Byte_File_Object {
public static Object getObjectFromBytes(byte[] objBytes) throws Exception {
if (objBytes == null || objBytes.length == 0) {
return null;
}
ByteArrayInputStream bi = new ByteArrayInputStream(objBytes);
ObjectInputStream ois = new ObjectInputStream(bi);
return ois.readObject();
}

public static byte[] getBytesFromObject(Serializable obj) throws Exception {
if (obj == null) {
return null;
}
ByteArrayOutputStream bo = new ByteArrayOutputStream();
ObjectOutputStream oos = new ObjectOutputStream(bo);
oos.writeObject(obj);
return bo.toByteArray();
}

}


/*
旧对象是[106, 97, 118, 97, 115, 101, 114, 118, 101, 114] [118, 99, 99, 108, 105, 101, 110, 116] 40 90
原对象转换后的字节对象为[B@1a679b7
原对象转换后的字节数据为
-84 -19 0 5 115 114 0 8 80 97 99 107 72 101 97 100 -16 69 -4 -30 28 -10 78 -70 2 0 4 73 0 7 110 108 101 110 103 116 104 73 0 5 110 116 121 112 101 91 0 4 102 114 111 109 116 0 2 91 66 91 0 2 116 111 113 0 126 0 1 120 112 0 0 0 90 0 0 0 40 117 114 0 2 91 66 -84 -13 23 -8 6 8 84 -32 2 0 0 120 112 0 0 0 10 106 97 118 97 115 101 114 118 101 114 117 113 0 126 0 3 0 0 0 8 118 99 99 108 105 101 110 116
新对象是[106, 97, 118, 97, 115, 101, 114, 118, 101, 114] [118, 99, 99, 108, 105, 101, 110, 116] 40 90
新对象转换后的字节数据为[B@1e0bc08
新对象转换后的字节数据为
-84 -19 0 5 115 114 0 8 80 97 99 107 72 101 97 100 -16 69 -4 -30 28 -10 78 -70 2 0 4 73 0 7 110 108 101 110 103 116 104 73 0 5 110 116 121 112 101 91 0 4 102 114 111 109 116 0 2 91 66 91 0 2 116 111 113 0 126 0 1 120 112 0 0 0 90 0 0 0 40 117 114 0 2 91 66 -84 -13 23 -8 6 8 84 -32 2 0 0 120 112 0 0 0 10 106 97 118 97 115 101 114 118 101 114 117 113 0 126 0 3 0 0 0 8 118 99 99 108 105 101 110 116



*/




 学习对象对java感兴趣,但没有任何软件编程基础,想先从零基础入手的软件开发爱好者;希望从另外一些简单的其他语言转型从事java开发的求职人员。适合大学生学习计算机入门,通过java语言计算机二级。想从事编程开发的人员、具有计算机基础、面试不过关的待业者、出校门的大学生、以及编程能力提升的从业者、以及世界500强的java工程师。 课程目标:你将对java内容有个全面的掌握,助编程能力的提升,让你理解500强企业要求的难度,通过计算机二级java语言考试 学习计划如果是待业者,明天用8个小时,会在两个月内完成。如果是上班族,每周至少用12-20小时,4-6个月内完成。课后有附加资料和练习来巩固知识并加强编程能力。此课程注重500强企业的编程能力实战要求。Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程 。Java具有简单性、面向对象、分布式、健壮性、安全性、平台独立与可移植性、多线程、动态性等特点  。Java可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序等。Java 具备下列特性。1.简单性Java看起来设计得很像C++,但是为了使语言小和容易熟悉,设计者们把C++语言中许多可用的特征去掉了,这些特征是一般程序员很少使用的。例如,Java不支持go to语句,代之以提供break和continue语句以及异常处理。Java还剔除了C++的操作符过载(overload)和多继承特征,并且不使用主文件,免去了预处理程序。因为Java没有结构,数组和串都是对象,所以不需要指针。Java能够自动处理对象的引用和间接引用,实现自动的无用单元收集,使用户不必为存储管理问题烦恼,能更多的时间和精力花在研发上。2.面向对象Java是一个面向对象的语言。对程序员来说,这意味着要注意应中的数据和操纵数据的方法(method),而不是严格地用过程来思考。在一个面向对象的系统中,类(class)是数据和操作数据的方法的集合。数据和方法一起描述对象(object)的状态和行为。每一对象是其状态和行为的封装。类是按一定体系和层次安排的,使得子类可以从超类继承行为。在这个类层次体系中有一个根类,它是具有一般行为的类。Java程序是用类来组织的。Java还包括一个类的扩展集合,分别组成各种程序包(Package),用户可以在自己的程序中使用。例如,Java提供产生图形用户接口部件的类(java.awt包),这里awt是抽象窗口工具集(abstract windowing toolkit)的缩写,处理输入输出的类(java.io包)和支持网络功能的类(java.net包)。3.分布性Java设计成支持在网络上应用,它是分布式语言。Java既支持各种层次的网络连接,又以Socket类支持可靠的流(stream)网络连接,所以用户可以产生分布式的客户机和服务器。网络变成软件应用的分布运载工具。Java程序只要编写一次,就可到处运行。4.编译和解释性Java编译程序生成字节码(byte-code),而不是通常的机器码。Java字节码提供对体系结构中性的目标文件格式,代码设计成可有效地传送程序到多个平台。Java程序可以在任何实现了Java解释程序和运行系统(run-time system)的系统上运行。在一个解释性的环境中,程序开发的标准“链接”阶段大大消失了。如果说Java还有一个链接阶段,它只是把新类装进环境的过程,它是增量式的、轻量级的过程。因此,Java支持快速原型和容易试验,它将导致快速程序开发。这是一个与传统的、耗时的“编译、链接和测试”形成鲜明对比的精巧的开发过程。5.稳健性Java原来是用作编写消费类家用电子产品软件的语言,所以它是被设计成写高可靠和稳健软件的。Java消除了某些编程错误,使得用它写可靠软件相当容易。Java是一个强类型语言,它允许扩展编译时检查潜在类型不匹配问题的功能。Java要求显式的方法声明,它不支持C风格的隐式声明。这些严格的要求保证编译程序能捕捉调用错误,这就导致更可靠的程序。可靠性方面最重要的增强之一是Java的存储模型。Java不支持指针,它消除重写存储和讹误数据的可能性。类似地,Java自动的“无用单元收集”预防存储漏泄和其它有关动态存储分配和解除分配的有害错误。Java解释程序也执行许多运行时的检查,诸如验证所有数组和串访问是否在界限之内。异常处理是Java中使得程序更稳健的另一个特征。异常是某种类似于错误的异常条件出现的信号。使用try/catch/finally语句,程序员可以找到出错的处理代码,这就简化了出错处理和恢复的任务。6.安全性Java的存储分配模型是它防御恶意代码的主要方法之一。Java没有指针,所以程序员不能得到隐蔽起来的内幕和伪造指针去指向存储器。更重要的是,Java编译程序不处理存储安排决策,所以程序员不能通过查看声明去猜测类的实际存储安排。编译的Java代码中的存储引用在运行时由Java解释程序决定实际存储地址。Java运行系统使用字节码验证过程来保证装载到网络上的代码不违背任何Java语言限制。这个安全机制部分包括类如何从网上装载。例如,装载的类是放在分开的名字空间而不是局部类,预防恶意的小应用程序用它自己的版本来代替标准Java类。7.可移植性Java使得语言声明不依赖于实现的方面。例如,Java显式说明每个基本数据类型的大小和它的运算行为(这些数据类型由Java语法描述)。Java环境本身对新的硬件平台和操作系统是可移植的。Java编译程序也用Java编写,而Java运行系统用ANSIC语言编写。8.高性能Java是一种先编译后解释的语言,所以它不如全编译性语言快。但是有些情况下性能是很要紧的,为了支持这些情况,Java设计者制作了“及时”编译程序,它能在运行时把Java字节码翻译成特定CPU(中央处理器)的机器代码,也就是实现全编译了。Java字节码格式设计时考虑到这些“及时”编译程序的需要,所以生成机器代码的过程相当简单,它能产生相当好的代码。9.多线程性Java是多线程语言,它提供支持多线程的执行(也称为轻便过程),能处理不同任务,使具有线索的程序设计很容易。Java的lang包提供一个Thread类,它支持开始线索、运行线索、停止线索和检查线索状态的方法。Java的线索支持也包括一组同步原语。这些原语是基于监督程序和条件变量风范,由C.A.R.Haore开发的广泛使用的同步化方案。用关键词synchronized,程序员可以说明某些方法在一个类中不能并发地运行。这些方法在监督程序控制之下,确保变量维持在一个一致的状态。10.动态性Java语言设计成适应于变化的环境,它是一个动态的语言。例如,Java中的类是根据需要载入的,甚至有些是通过网络获取的。 尹成老师带你步入Java语言基础的殿堂,讲课生动风趣、深入浅出,全套视频内容充实,整个教程以Java语言为核心,完整精彩的演练了Java语言操作流程以及各种精彩的小项目等,提高竞赛能力,非常适合同学们学习!课程特色特色一:通俗易懂本视频语言简洁,通俗易懂,将难以理解的编程问题用简单清晰的语言描述,让你更容易理解。特色三:内容丰富本视频讲解的java语言知识更加丰富翔实,较之其他视频,本视频讲解的java语言知识更多更深入。特色三:配图详尽本视频在讲解知识点时都配图了表格或图示,在讲解案例时,都配备了流程图或分析图示,让你对所学知识点或案例理解更清晰。特色四:实战性强本视频讲解的每个知识都配备了一个小案例,这样既增加了学生动手能力,又巩固了学生所学知识。特色五:加入尹成老师微信群本视频尹成老师亲自答疑

62,616

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧