Java网络编程-对象编解码方案、优劣对照
实例代码 :http://download.csdn.net/detail/jiangtao_st/7677503
- 用户对象
/**
*
* <p>
*用户实体对象定义
* </p>
*
* @author 卓轩
* @创建时间:2014年6月20日
* @产品: UIC
* @version: V1.0
*/
public class UserDO implements Serializable { private static final long serialVersionUID = 7289036533757178921L; /**
* userid
*/
private int userId; /**
* email
*/
private String email; /**
* uname
*/
private String uname; /**
* unick
*/
private String unick; /**
* sex
*/
private Integer sex; public int getUserId() {
return userId;
} public void setUserId(int userId) {
this.userId = userId;
} public String getEmail() {
return email;
} public void setEmail(String email) {
this.email = email;
} public String getUname() {
return uname;
} public void setUname(String uname) {
this.uname = uname;
} public String getUnick() {
return unick;
} public void setUnick(String unick) {
this.unick = unick;
} public Integer getSex() {
return sex;
} public void setSex(Integer sex) {
this.sex = sex;
} @Override
public String toString() {
return "UserDO ["+this.userId+"],["+this.uname+"],["+this.unick+"],["+this.email+"]";
} public byte [] coder(){ ByteBuffer buffer = ByteBuffer.allocate(1024); byte [] email = this.email.getBytes();
buffer.putInt(email.length);
buffer.put(email); byte [] uname =this.uname.getBytes();
buffer.putInt(uname.length);
buffer.put(uname); byte [] unick = this.unick.getBytes();
buffer.putInt(unick.length);
buffer.put(unick); buffer.putInt(this.sex);
buffer.putInt(this.userId); buffer.flip();
byte[] result = new byte[buffer.remaining()];
buffer.get(result);
return result;
} } - 对例如案
/**
*
* <p>
* 对照对象编解码 优劣
*
* 代码通过从同一个对象,使用jdk序列化 和 二进制编解码 ,从运行时间,产生的字节大小作对照
* </p>
*
* @author 卓轩
* @创建时间:2014年7月8日
* @version: V1.0
*/
public class ObjectCoderCompare { /**
* 对照序列化文件大小
*/
@Test
public void sizeByteCompare(){ try {
UserDO zhuoxuan = new UserDO();
zhuoxuan.setUserId(113445);
zhuoxuan.setSex(1);
zhuoxuan.setUname("卓轩");
zhuoxuan.setUnick("zhuoxuan");
zhuoxuan.setEmail("zhuoxuan@mogujie.com"); System.out.println("byte array 序列化大小:" + zhuoxuan.coder().length); //jdk 序列化对象
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectOutputStream objectOutputStream = new ObjectOutputStream(bos);
objectOutputStream.writeObject(zhuoxuan);
objectOutputStream.flush();
objectOutputStream.close();
byte[] byteArray = bos.toByteArray();
System.out.println("jdk序列化对象大小:" + byteArray.length);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} /**
* 运行时间,性能对照
*/
@Test
public void performCompare(){ try {
UserDO zhuoxuan = new UserDO();
zhuoxuan.setUserId(113445);
zhuoxuan.setSex(1);
zhuoxuan.setUname("卓轩");
zhuoxuan.setUnick("zhuoxuan");
zhuoxuan.setEmail("zhuoxuan@mogujie.com"); long startTime = System.currentTimeMillis();
int count = 1000000;
for (int i = 0; i < count; i++) {
zhuoxuan.coder();
}
long endTime = System.currentTimeMillis();
System.out.println("byte array 运行时间:" + (endTime-startTime) + "ms"); startTime = System.currentTimeMillis();
for (int i = 0; i < count; i++) {
//jdk 序列化对象
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectOutputStream objectOutputStream = new ObjectOutputStream(bos);
objectOutputStream.writeObject(zhuoxuan);
objectOutputStream.flush();
objectOutputStream.close();
byte[] byteArray = bos.toByteArray();
}
endTime = System.currentTimeMillis();
System.out.println("jdk 序列化对象 运行时间:" + (endTime-startTime) + "ms");
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} }
} - 执行结果
byte array 序列化大小:54
jdk序列化对象大小:267
Java网络编程-对象编解码方案、优劣对照的更多相关文章
- 这份书单会告诉你,Java网络编程其实很重要
- Java 网络编程---分布式文件协同编辑器设计与实现
目录: 第一部分:Java网络编程知识 (一)简单的Http请求 一般浏览网页时,使用的时Ip地址,而IP(Internet Protocol,互联网协议)目前主要是IPv4和IPv6. IP地址是一 ...
- Java网络编程和NIO详解9:基于NIO的网络编程框架Netty
Java网络编程和NIO详解9:基于NIO的网络编程框架Netty 转自https://sylvanassun.github.io/2017/11/30/2017-11-30-netty_introd ...
- Java网络编程和NIO详解5:Java 非阻塞 IO 和异步 IO
Java网络编程和NIO详解5:Java 非阻塞 IO 和异步 IO Java 非阻塞 IO 和异步 IO 转自https://www.javadoop.com/post/nio-and-aio 本系 ...
- Java网络编程与NIO详解11:Tomcat中的Connector源码分析(NIO)
本文转载 https://www.javadoop.com 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.c ...
- 20145205 《Java程序设计》实验报告五:Java网络编程及安全
20145205 <Java程序设计>实验报告五:Java网络编程及安全 实验要求 1.掌握Socket程序的编写: 2.掌握密码技术的使用: 3.客户端中输入明文,利用DES算法加密,D ...
- Java 网络编程学习总结
新手一枚,Java学习中,把自己学习网络编程的知识总结一下,梳理下知识,方便日后查阅,高手莫进. 本文的主要内容: [1] 网络编程认识 [2] TCP/IP编程 ...
- 20145212 实验五《Java网络编程》
20145212 实验五<Java网络编程> 一.实验内容 1.运行下载的TCP代码,结对进行,一人服务器,一人客户端: 2.利用加解密代码包,编译运行代码,一人加密,一人解密: 3.集成 ...
- 20145213《Java程序设计》实验五Java网络编程及安全
20145213<Java程序设计>实验五Java网络编程及安全 实验内容 1.掌握Socket程序的编写. 2.掌握密码技术的使用. 3.设计安全传输系统. 实验预期 1.客户端与服务器 ...
随机推荐
- pycURL的内存问题
pycURL的内存问题 最近用pycURL写了一个工具,注册账号用的.写是写好了,但是发现内存占用超大.40个线程运行一天跑到了3.7G的内存. 于是着手调查这个问题. 调查方法就是用python的g ...
- hdu 4861 Couple doubi(数论)
题目链接:hdu 4861 Couple doubi 题目大意:两个人进行游戏,桌上有k个球,第i个球的值为1i+2i+⋯+(p−1)i%p,两个人轮流取,假设DouBiNan的值大的话就输出YES, ...
- PE文件简单介绍
PE(Portable Execute)文件是WIN32下可运行文件遵循的数据格式,也是反汇编调试不可缺少的文件,常见的pe文件有.exe和.dll文件.本文主要介绍pe文件的结构和虚拟内存地址转换到 ...
- C++中实现 time_t, tm 相互转换
time_t -> tm: localtime tm -> time_t: mktime time_t curTime; time(&curTime); dwCurTime = c ...
- 【REDO】删除REDO LOG重做日志组后需要手工删除对应的日志文件(转)
为保证重新创建的日志组成员可以成功创建,我们在删除日志组后需要手工删除对应的日志文件. 1.查看数据库当前REDO LOG日志相关信息1)查看日志组信息sys@ora10g> select * ...
- 基于visual Studio2013解决C语言竞赛题之1030计算函数
题目 解决代码及点评 /********************************************************************** ...
- Buenos Aires和Rio de Janeiro怎么发音?
Buenos Aires和Rio de Janeiro怎么发音?_百度知道 Buenos Aires和Rio de Janeiro怎么发音? 2009-09-25 08:58 zd029 ...
- Win2003 Server磁盘配额揭密之补遗篇
Win2003 Server磁盘配额揭密之补遗篇 [ 作者:茶乡浪子 转贴自:it168.com 点击数:5011 更新时间:2005-1-17 ] 执行查看用户的磁盘配额信息 ...
- 认识axure组件区域
组件区域也叫做部件区域,英文为widgets,还有人称之为控件区域,组件是axure事先准备好的网站项目常用的零件,比如一些基本的页面元素 Axure默认存在2个组件库,分别为线框图和流程图.同时我们 ...
- GreenDAO数据库版本升级
GreenDAO是一款非要流行的android平台上的数据库框架,性能优秀,代码简洁. 初始化数据库模型代码的时候需要使用java项目生成代码,依赖的jar包已经上传到我的资源里了,下载地址如下:ht ...