import java.io.ByteArrayInputStream;

import java.io.ByteArrayOutputStream;

import java.io.IOException;

import java.io.ObjectInputStream;

import java.io.ObjectOutputStream;

import java.io.UnsupportedEncodingException;

import java.nio.ByteBuffer;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

public class ByteUtil

{

private static final Logger LOGGER = LoggerFactory.getLogger(ByteUtil.class);

public static String getString(ByteBuffer byteBuffer)

{

short len = byteBuffer.getShort();

byte[] bb = new byte[len];

byteBuffer.get(bb);

String str = null;

try {

str = new String(bb, "UTF-8");

} catch (UnsupportedEncodingException e) {

LOGGER.error("读取字符串错误.");

}

return str;

}

public static byte[] mergeByteArray(byte[] bb1, byte[] bb2)

{

int len1 = bb1.length;

int len2 = bb2.length;

byte[] bb = new byte[len1 + len2];

System.arraycopy(bb1, 0, bb, 0, len1);

System.arraycopy(bb2, 0, bb, len1, len2);

return bb;

}

public static byte[] booleanToBytes(boolean b)

{

byte[] bb = new byte[1];

bb[0] = (byte)((b) ? 1 : 0);

return bb;

}

public static byte[] byteToBytes(byte b)

{

byte[] bb = new byte[1];

bb[0] = b;

return bb;

}

public static byte[] shortToBytes(short s)

{

ByteBuffer byteBuffer = ByteBuffer.allocate(2);

byteBuffer.putShort(s);

byteBuffer.flip();

byte[] bb = new byte[byteBuffer.limit()];

byteBuffer.get(bb);

return bb;

}

public static byte[] intToBytes(int i)

{

ByteBuffer byteBuffer = ByteBuffer.allocate(4);

byteBuffer.putInt(i);

byteBuffer.flip();

byte[] bb = new byte[byteBuffer.limit()];

byteBuffer.get(bb);

return bb;

}

public static byte[] longToBytes(long l)

{

ByteBuffer byteBuffer = ByteBuffer.allocate(8);

byteBuffer.putLong(l);

byteBuffer.flip();

byte[] bb = new byte[byteBuffer.limit()];

byteBuffer.get(bb);

return bb;

}

public static byte[] stringToBytes(String s)

{

byte[] bb = null;

try {

bb = s.getBytes("UTF-8");

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

return bb;

}

public static <T> T byteArrayToObject(byte[] bb)

{

Object obj = null;

ByteArrayInputStream bais = null;

ObjectInputStream ois = null;

try {

bais = new ByteArrayInputStream(bb);

ois = new ObjectInputStream(bais);

obj = ois.readObject();

} catch (Exception e) {

e.printStackTrace(); } finally {

try {

if (ois != null) ois.close();  } catch (IOException e) {

e.printStackTrace();

}try { if (bais != null) bais.close();  } catch (IOException e) {

e.printStackTrace();

}

}

return obj;

}

public static byte[] objectToByteArray(Object obj)

{

byte[] bb = null;

ByteArrayOutputStream baos = new ByteArrayOutputStream();

ObjectOutputStream oos = null;

try {

oos = new ObjectOutputStream(baos);

oos.writeObject(obj);

bb = baos.toByteArray();

} catch (Exception e) {

e.printStackTrace(); } finally {

try {

if (oos != null) oos.close();  } catch (IOException e) {

e.printStackTrace();

}try { if (baos != null) baos.close();  } catch (IOException e) {

e.printStackTrace();

}

}

return bb;

}

}

ByteUtil的更多相关文章

  1. ByteUtil 工具类

    ByteUtil 工具类 import java.io.FileOutputStream; import java.io.OutputStream; import java.nio.charset.C ...

  2. MyCat源码分析系列之——结果合并

    更多MyCat源码分析,请戳MyCat源码分析系列 结果合并 在SQL下发流程和前后端验证流程中介绍过,通过用户验证的后端连接绑定的NIOHandler是MySQLConnectionHandler实 ...

  3. NPOI、MyXls、Aspose.Cells 导入导出Excel(转)

    Excel导入及导出问题产生: 从接触.net到现在一直在维护一个DataTable导s出到Excel的类,时不时还会维护一个导入类.以下是时不时就会出现的问题: 导出问题: 如果是asp.net,你 ...

  4. byte数据的常用操作函数[转发]

    /// <summary> /// 本类提供了对byte数据的常用操作函数 /// </summary> public class ByteUtil { ','A','B',' ...

  5. csharp: Export or Import excel using MyXls,Spire.Xls

    excel 2003 (效果不太理想) using System; using System.Collections.Generic; using System.ComponentModel; usi ...

  6. [转].net 使用NPOI或MyXls把DataTable导出到Excel

    本文转自:http://www.cnblogs.com/yongfa365/archive/2010/05/10/NPOI-MyXls-DataTable-To-Excel-From-Excel.ht ...

  7. Java字节转换类实现

    Java的类库支持完全不如C#,比如时间类,比如数据类型转换类等等,难道是我自己没找到吗? 下面是字节转换类,byte[]与short, int, long, float, double, Strin ...

  8. [转载] java中byte数组与int,long,short间的转换

    文章转载自http://blog.csdn.net/leetcworks/article/details/7390731 package com.util; /** * * <ul> * ...

  9. 【转】java中float与byte[]的互转 -- 不错

    原文网址:http://tjmljw.iteye.com/blog/1767716 起因:想把一个float[]转换成内存数据,查了一下,下面两个方法可以将float转成byte[]. 方法一 imp ...

随机推荐

  1. xtrabackup 使用

    创建具有完全备份所需的最小权限的数据库用户的SQL示例如下 mysql> CREATE USER 'bkpuser'@'%' IDENTIFIED BY 's3cret';mysql> G ...

  2. pandas的行列显示不全的解决方法

    pd.set_option('display.max_rows', 100) # 显示的最大行数(避免只显示部分行数据) pd.set_option('display.max_columns', 10 ...

  3. seaborn---调色板

    一.样式控制 1.set([context,style,palette,font,...]) 一步设定美学参数. 2.axes_style([style,rc]) 返回参数字典,用于绘图的美学风格. ...

  4. mmdetection安装教程

    如果官方教程不行再参考我的吧,我的环境如下: ubuntu cuda10 cudnn7.5 步骤: 1.使用conda创建一个虚拟环境 conda create -n mmdetection pyth ...

  5. jasypt-spring-boot

    运行 运行时配置解密秘钥-Djasypt.encryptor.password=在idea中运行 命令行启动和docker中运行参见https://www.cnblogs.com/zz0412/p/j ...

  6. python操作excel获取内容

    背景:从excel表中获取请求url.请求数据.请求类型.预期结果 因此,需要学会如何使用python从excel获取这些信息 #coding=utf-8 import xlrd #创建对象时,获取对 ...

  7. MySQL中列别名为中文时,Order by 子句中使用别名时不要加引号

    暂时还不清楚原因 1.按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩 SC表: 这里,当做总成绩处理 select sid, sum(score) as '总成绩', avg(score) ...

  8. 如果设置Redis客户端的超时时长?

    客户端的超时时长分连接超时和读写超时,如果是基于hiredis的实现,则读写超时是合在一起的,同一参数控制. 在hiredis中,读写超时调用函数redisSetTimeout设置,可以看到没有区分读 ...

  9. 虔诚的墓主人(BZOJ1227)(洛谷P2154)解题报告

    题目描述 小W是一片新造公墓的管理人.公墓可以看成一块N×M的矩形,矩形的每个格点,要么种着一棵常青树,要么是一块还没有归属的墓地. 当地的居民都是非常虔诚的基督徒,他们愿意提前为自己找一块合适墓地. ...

  10. 如何进行seo优化要点总结

    一.搜索引擎工作原理 当我们在输入框中输入关键词,点击搜索或查询时,然后得到结果.深究其背后的故事,搜索引擎做了很多事情. 在搜索引擎网站,比如百度,在其后台有一个非常庞大的数据库,里面存储了海量的关 ...