/// <summary>
/// 本类提供了对byte数据的常用操作函数
/// </summary>
public class ByteUtil
{
private static char[] HEX_CHARS = {'','','','','','','','','','','A','B','C','D','E','F'};
private static byte[] BITS = {0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80}; /// <summary>
/// 将字节数组转换为HEX形式的字符串, 使用指定的间隔符
/// </summary>
public static string ByteToHex(byte[] buf, string separator)
{
System.Text.StringBuilder sb = new System.Text.StringBuilder();
for(int i = ;i < buf.Length;i++)
{
if (i > )
{
sb.Append(separator);
}
sb.Append(HEX_CHARS[buf[i] >> ]).Append(HEX_CHARS[buf[i] & 0x0F]);
}
return sb.ToString();
} /// <summary>
/// 将字节数组转换为HEX形式的字符串, 使用指定的间隔符
/// </summary>
public static string ByteToHex(byte[] buf, char c)
{
System.Text.StringBuilder sb = new System.Text.StringBuilder();
for(int i = ;i < buf.Length;i++)
{
if (i > )
{
sb.Append(c);
}
sb.Append(HEX_CHARS[buf[i] >> ]).Append(HEX_CHARS[buf[i] & 0x0F]);
}
return sb.ToString();
} /// <summary>
/// 判断字节数组前几位是否符合一定规则
/// </summary>
/// <param name="data">需要判断的字节数组</param>
/// <param name="pattern">匹配规则</param>
/// <returns>如果匹配返回true</returns>
public static bool IsMatch(byte[] data, params byte[] pattern)
{
if (data == null || data.Length < pattern.Length)
return false; for(int i = ;i < pattern.Length;i++)
{
if (data[i] != pattern[i])
return false;
}
return true;
} /// <summary>
/// 判断指定字节是否为列举的某个值
/// </summary>
/// <param name="value">需要判断的值</param>
/// <param name="choice">可能值</param>
/// <returns>如果与任一个可能值相等则返回true</returns>
public static bool IsMatch(byte value, params byte[] choice)
{
if (choice == null || choice.Length == )
return false; foreach(byte item in choice)
{
if (item == value)
return true;
}
return false;
} /// <summary>
/// 将字节数组转换为HEX形式的字符串, 没有间隔符
/// </summary>
public static string ByteToHex(byte[] buf)
{
return ByteToHex(buf, string.Empty);
} /// <summary>
/// 将字节数组转换为HEX形式的字符串
/// 转换后的字符串长度为字节数组长度的两倍
/// 如: 1, 2 转换为 0102
/// </summary>
public static string ByteToHex(byte b)
{
return string.Empty + HEX_CHARS[b >> ] + HEX_CHARS[b & 0x0F];
} /// <summary>
/// 将字节流信息转换为HEX字符串
/// </summary>
public static string DumpBytes(byte[] bytes)
{
return DumpBytes(bytes, , bytes.Length);
} /// <summary>
/// 将字节流信息转换为HEX字符串
/// </summary>
public static string DumpBytes(byte[] bytes, int offset, int len)
{
StringBuilder buf = new StringBuilder();
for(int i = ;i < len;i++)
{
if (i == || i % == )
buf.AppendLine(); buf.Append(ByteToHex(bytes[i + offset]));
buf.Append(' ');
}
buf.AppendLine();
return buf.ToString();
} /// <summary>
/// 计算字节块的模256校验和
/// </summary>
public static byte SumBytes(byte[] bytes, int offset, int len)
{
int sum = ;
for(int i = ;i < len;i++)
{
sum += bytes[i + offset];
if (sum >= )
{
sum = sum % ;
}
}
return (byte)sum;
} /// <summary>
/// 计算字节块的模256双字节校验和(低位在前)
/// </summary>
public static byte[] Sum2Bytes(byte[] bytes, int offset, int len)
{
int sum = ;
for(int i = ;i < len;i++)
sum += bytes[i + offset];
return new byte[] { (byte)(sum % ), (byte)(sum / ) };
} /// <summary>
/// 计算字节块的异或校验和
/// </summary>
public static byte XorSumBytes(byte[] bytes, int offset, int len)
{
byte sum = bytes[ + offset];
for(int i = ;i < len;i++)
{
sum = (byte)(sum ^ bytes[i + offset]);
}
return sum;
} /// <summary>
/// 计算字节块的异或校验和
/// </summary>
public static byte XorSumBytes(byte[] bytes)
{
return XorSumBytes(bytes, , bytes.Length);
} /// <summary>
/// 比较两个字节块是否相等。相等返回true否则false
/// </summary>
public static bool CompareBytes(byte[] bytes1, int offset1, byte[] bytes2, int offset2, int len)
{
for(int i = ;i < len;i++)
{
if (bytes1[i + offset1] != bytes2[i + offset2])
{
return false;
}
}
return true;
} /// <summary>
/// 将两个字符的hex转换为byte
/// </summary>
public static byte HexToByte(char[] hex, int offset)
{
byte result = ;
for(int i = ;i < ;i++)
{
char c = hex[i + offset];
byte b = ;
switch (c)
{
case '':
case '':
case '':
case '':
case '':
case '':
case '':
case '':
case '':
case '':
b = (byte)(c - '');
break;
case 'A':
case 'B':
case 'C':
case 'D':
case 'E':
case 'F':
b = (byte)( + c - 'A');
break;
case 'a':
case 'b':
case 'c':
case 'd':
case 'e':
case 'f':
b = (byte)( + c - 'a');
break;
}
if (i == )
{
b = (byte)(b * );
}
result += b;
} return result;
} /// <summary>
/// 将两个字符的hex转换为byte
/// </summary>
public static byte HexToByte(byte[] hex, int offset)
{
char[] chars = {(char)hex[offset], (char)hex[offset + ]};
return HexToByte(chars, );
} /// <summary>
/// 转换16进制字符串为字节数组
/// <param name="hex">有分隔或无分隔的16进制字符串,如“AB CD EF 12 34...”或“ABCDEF1234...”</param>
/// <param name="dot">任意分隔字符,但不能是16进制字符</param>
/// <returns>字节数组</returns>
/// </summary>
public static byte[] HexToByte(string hex, params char[] dot) {
char[] ca = new char[];
List<byte> list = new List<byte>();
for (int i = , n = ; i < hex.Length; i++) {
if (Array.IndexOf<char>(dot, hex[i]) >= ) {
continue;
} switch (++n) {
case :
ca[] = hex[i];
break; case :
ca[] = hex[i];
list.Add(ByteUtil.HexToByte(ca, ));
n = ;
break;
}
} return list.ToArray();
} /// <summary>
/// 将uint变量分解为四个字节。高位在前。
/// </summary>
public static void UintToBytes(uint i, byte[] bytes, int offset)
{
bytes[offset] = (byte)((i & 0xFF000000) >> );
bytes[offset + ] = (byte)((i & 0x00FF0000) >> );
bytes[offset + ] = (byte)((i & 0x0000FF00) >> );
bytes[offset + ] = (byte)(i & 0x000000FF);
} /// <summary>
/// 将uint变量分解为四个字节。高位在前。
/// </summary>
public static byte[] UintToBytes(uint i)
{
byte[] bytes = new byte[];
bytes[] = (byte)((i & 0xFF000000) >> );
bytes[] = (byte)((i & 0x00FF0000) >> );
bytes[] = (byte)((i & 0x0000FF00) >> );
bytes[] = (byte)(i & 0x000000FF);
return bytes;
} /// <summary>
/// 将int变量分解为四个字节。高位在前。
/// </summary>
public static byte[] IntToBytes(int i)
{
byte[] data = BitConverter.GetBytes(i);
Array.Reverse(data);
return data; //byte[] bytes = new byte[4];
//bytes[0] = (byte)((i & 0xFF000000) >> 24);
//bytes[1] = (byte)((i & 0x00FF0000) >> 16);
//bytes[2] = (byte)((i & 0x0000FF00) >> 8);
//bytes[3] = (byte)(i & 0x000000FF);
//return bytes;
} /// <summary>
/// 将四个字节合成为一个int
/// </summary>
public static uint BytesToUint(byte[] bytes, int offset)
{
uint a = ((uint)bytes[offset]) << ;
uint b = ((uint)bytes[offset + ]) << ;
uint c = ((uint)bytes[offset + ]) << ;
uint d = bytes[offset + ];
return a + b + c + d;
} /// <summary>
/// 将ulong变量分解为八个字节。高位在前。
/// </summary>
public static byte[] UlongToBytes(ulong i)
{
byte[] bytes = new byte[];
bytes[] = (byte)((i & 0xFF00000000000000) >> );
bytes[] = (byte)((i & 0x00FF000000000000) >> );
bytes[] = (byte)((i & 0x0000FF0000000000) >> );
bytes[] = (byte)((i & 0x000000FF00000000) >> );
bytes[] = (byte)((i & 0x00000000FF000000) >> );
bytes[] = (byte)((i & 0x0000000000FF0000) >> );
bytes[] = (byte)((i & 0x000000000000FF00) >> );
bytes[] = (byte)(i & 0x00000000000000FF);
return bytes;
} /// <summary>
/// 将八个字节合成为一个ulong
/// </summary>
public static ulong BytesToUlong(byte[] bytes, int offset)
{
ulong a = ((ulong)bytes[offset]) << ;
ulong b = ((ulong)bytes[offset + ]) << ;
ulong c = ((ulong)bytes[offset + ]) << ;
ulong d = ((ulong)bytes[offset + ]) << ;
ulong e = ((ulong)bytes[offset + ]) << ;
ulong f = ((ulong)bytes[offset + ]) << ;
ulong g = ((ulong)bytes[offset + ]) << ;
ulong h = bytes[offset + ];
return a + b + c + d + e + f + g + h;
} /// <summary>
/// 设置某个字节的指定位
/// </summary>
/// <param name="b">需要设置的字节</param>
/// <param name="pos">1-8, 1表示最低位, 8表示最高位</param>
/// <param name="on">true表示设置1, false表示设置0</param>
public static void ByteSetBit(ref byte b, int pos, bool on)
{
int temp = BITS[pos - ]; if (!on)
{
//取反
temp = temp ^ 0xFF;
} b = (byte)(on?(b | temp):(b & temp));
} /// <summary>
/// 判断某个byte的某个位是否为1
/// </summary>
/// <param name="pos">第几位,大于等于1</param>
public static bool ByteGetBit(byte b, int pos)
{
int temp = BITS[pos - ];
return (b & temp) != ;
} /// <summary>
/// 设置双比特值
/// </summary>
/// <param name="b">需要设置的字节</param>
/// <param name="low">低位, 1-7</param>
/// <param name="val">值,0-3</param>
/// <returns></returns>
public static void ByteSetBitPair(ref byte b, int low, int val)
{
if (low < || low > )
{
throw new ArgumentException(string.Format("无效的low值:{0}", low));
} switch(val)
{
case :
{
ByteUtil.ByteSetBit(ref b, low, false);
ByteUtil.ByteSetBit(ref b, low + , false);
break;
}
case :
{
ByteUtil.ByteSetBit(ref b, low, true);
ByteUtil.ByteSetBit(ref b, low + , false);
break;
}
case :
{
ByteUtil.ByteSetBit(ref b, low, false);
ByteUtil.ByteSetBit(ref b, low + , true);
break;
}
case :
{
ByteUtil.ByteSetBit(ref b, low, true);
ByteUtil.ByteSetBit(ref b, low + , true);
break;
}
default:
{
throw new ArgumentException(string.Format("无效的val值:{0}", val));
}
}
} /// <summary>
/// 读取双比特值
/// </summary>
/// <param name="b">需要读取的字节</param>
/// <param name="low">低位, 0-6</param>
/// <returns>0-3</returns>
public static byte ByteGetBitPair(byte b, int low)
{
if (low < || low > )
{
throw new ArgumentException(string.Format("无效的low值:{0}", low));
} int x = ;
x += ByteUtil.ByteGetBit(b, low)?:;
x += ByteUtil.ByteGetBit(b, low + )?:; return (byte)x;
} /// <summary>
/// 将short转换为两个字节
/// </summary>
/// <param name="s"></param>
/// <returns></returns>
public static byte[] ShortToByte(short s)
{
return UshortToByte((ushort)s);
} /// <summary>
/// 将ushort转换为两个字节
/// </summary>
public static byte[] UshortToByte(ushort u)
{
return new byte[]{
(byte)(u >> ),
(byte)(u & 0x00FF)
};
} /// <summary>
/// 将两个字节转换为一个short
/// </summary>
public static short BytesToShort(byte[] data, int offset)
{
short a = data[offset], b = data[offset + ];
return (short)((a << ) + b);
} /// <summary>
/// 将两个字节转换为一个short
/// </summary>
public static ushort BytesToUshort(byte[] data, int offset)
{
ushort a = data[offset], b = data[offset + ];
return (ushort)((a << ) + b);
} /// <summary>
/// 将四个字节转换为int
/// </summary>
/// <param name="data"></param>
/// <param name="offset"></param>
/// <returns></returns>
public static int BytesToInt(byte[] data, int offset)
{
return (data[offset] << ) + (data[offset + ] << ) + (data[offset + ] << ) + data[offset + ];
} /// <summary>
/// 将guid字符串转换为等价的16维字节数组
/// </summary>
public static byte[] GuidToBytes(string s)
{
byte[] guid = new byte[];
char[] hex = s.Replace("-", string.Empty).Replace(" ", string.Empty).ToCharArray();
for (int i = ; i < ; i += )
{
guid[i / ] = ByteUtil.HexToByte(hex, i);
}
return guid;
} /// <summary>
/// CRC16校验表
/// </summary>
static ushort[] wCRCTalbeAbs = {0x0000, 0xCC01, 0xD801, 0x1400, 0xF001, 0x3C00, 0x2800, 0xE401, 0xA001, 0x6C00, 0x7800, 0xB401, 0x5000, 0x9C01, 0x8801, 0x4400}; /// <summary>
/// 计数字节块的CRC16校验值
/// </summary>
public static int CRC16Bytes(byte[] bytes, int offset, int len)
{
int wCRC = 0xFFFF;
byte chChar; for (int i = offset; i < len; i++)
{
chChar = bytes[i];
wCRC = wCRCTalbeAbs[(chChar ^ wCRC) & ] ^ (wCRC >> );
wCRC = wCRCTalbeAbs[((chChar >> ) ^ wCRC) & ] ^ (wCRC >> );
} return wCRC;
} /// <summary>
/// 字节格式化,将字节转换为字节、KB、MB、GB显示
/// </summary>
/// <param name="bytes">字节数</param>
/// <returns>格式化后的字符串</returns>
public static string ByteFormater(long bytes)
{
const long KB = ;
const long MB = * ;
const long GB = * * ; if (bytes >= GB)
{
double result = bytes * 1.0 / GB;
return result.ToString("#,##0.0") + "GB";
}
if (bytes >= MB)
{
double result = bytes * 1.0 / MB;
return result.ToString("#,##0.0") + "MB";
}
if (bytes >= KB)
{
double result = bytes * 1.0 / KB;
return result.ToString("#,##0.0") + "KB";
}
return bytes.ToString("#,##0") + "字节";
}
}

byte数据的常用操作函数[转发]的更多相关文章

  1. R语言Data Frame数据框常用操作

    Data Frame一般被翻译为数据框,感觉就像是R中的表,由行和列组成,与Matrix不同的是,每个列可以是不同的数据类型,而Matrix是必须相同的. Data Frame每一列有列名,每一行也可 ...

  2. 转载:R语言Data Frame数据框常用操作

    Data Frame一般被翻译为数据框,感觉就像是R中的表,由行和列组成,与Matrix不同的是,每个列可以是不同的数据类型,而Matrix是必须相同的. Data Frame每一列有列名,每一行也可 ...

  3. Python--set常用操作函数

    python提供了常用的数据结构,其中之一就是set,python中的set是不支持索引的.值不能重复.无需插入的容器. 简单记录下set常用的操作函数: 1.新建一个set: set("H ...

  4. JavaScript之数组的常用操作函数

    js对数组的操作非常频繁,但是每次用到的时候都会被搞混,都需要去查相关API,感觉这样很浪费时间.为了加深印象,所以整理一下对数组的相关操作. 常用的函数 concat() 连接两个或更多的数组,并返 ...

  5. R语言︱基本函数、统计量、常用操作函数

    先言:R语言常用界面操作 帮助:help(nnet) = ?nnet =??nnet 清除命令框中所有显示内容:Ctrl+L 清除R空间中内存变量:rm(list=ls()).gc() 获取或者设置当 ...

  6. [转]pymongo常用操作函数

    pymongo 是 mongodb 的 python Driver Editor.记录下学习过程中感觉以后会常用多一些部分,以做参考. 1. 连接数据库 要使用pymongo最先应该做的事就是先连上运 ...

  7. pymongo 常用操作函数

    pymongo 是 mongodb 的 python Driver Editor. 记录下学习过程中感觉以后会常用多一些部分,以做参考. 1. 连接数据库 要使用pymongo最先应该做的事就是先连上 ...

  8. 入门大数据---SparkSQL常用聚合函数

    一.简单聚合 1.1 数据准备 // 需要导入 spark sql 内置的函数包 import org.apache.spark.sql.functions._ val spark = SparkSe ...

  9. MYSQL常用操作函数的封装

    1.mysql常用函数封装文件:mysql.func.php <?php /** * 连接MYSQL函数 * @param string $host * @param string $usern ...

随机推荐

  1. C# java MD5加密方不一致问题

    说来惭愧,做开发几年了,一直在吸取,今天也写写自已关于技术的一点点理解,不正之处,请大家多多指点. 由于之前开发的项目使用的是C#,用户信息使用的C#的MD5加密码方式,而现在需要切换到Java平台下 ...

  2. CSS选择器详解

    选择器是CSS的核心,从最初的元素.class/id选择器,演进到伪元素.伪类,以及CSS3中提供的更丰富的选择器,定位页面上的任意元素开始变得愈发的简单. 1.元素选择器 这是最基本的CSS选择器, ...

  3. android:layout_weight的真实含义(转)

    首先声明只有在Linearlayout中,该属性才有效.之所以Android:layout_weight会引起争议,是因为在设置该属性的同时,设置android:layout_width为wrap_c ...

  4. Javascript 数组常用操作方法

    一.数组 Array 1.创建数组 /* 构造函数 */ var arr1 = new Array(); //创建一个空数组 var arr1 = new Array(5); //创建指定长度数组(数 ...

  5. VB.net中Ajaxpro的使用

    1:从网上下载:AjaxPro.2.DLL文件,下载地址: http://files.cnblogs.com/wequst/AjaxPro.2.zip 2:解压之后把DLL放到程序bin目录下进行参照 ...

  6. iOS - Localizable 国际化

    1.国际化 开发的移动应用更希望获取更多用户,走向世界,这就需要应用国际化,国际化其实就是多语言,系统会根据当前设备的语言环境来识别 App 中使用中文还是英文. 2.应用内容国际化 1.新建一个名为 ...

  7. text/plain && text/html

    text/plain和text/html都是Content-Type; text/plain : 页面以文本形式输出 text/html:  页面以html格式输出

  8. 用python爬取QQ空间

    好久没写博文了,最近捣鼓了一下python,好像有点上瘾了,感觉python比js厉害好多,但是接触不久,只看了<[大家网]Python基础教程(第2版)[www.TopSage.com]> ...

  9. loadrunner关联——对服务器返回的数据选择性提交

    在跟进项目的过程中,才体会到自己之前闷头看书再写小小的测试程序验证的学习方式很没有效率,知道动态关联,却也只是会参数化式的动态关联,这种关联是我们预先知道要提交的数据而进行的关联:更高一级的可能就是使 ...

  10. hive外部表的建立与数据匹配

    1.建立hive的外部表匹配hdfs上的数据 出现如下报错: hive (solar)> ; OK Failed with exception java.io.IOException:java. ...