`
isiqi
  • 浏览: 16027792 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

关键词Byte相关知识与实用类的深入理解(流操作,加密处理,图像处理等的基础准备)

F# 
阅读更多

关键词Byte相关知识与实用类的深入理解(流操作,加密处理,图像处理等的基础准备)

Byte,long,int,short,char,

( 1 )Byte的解说:

byte 关键字代表一种整型,该类型按下表所示存储值:

类型 范围 大小 .NET Framework 类型

byte

0 255

无符号 8 位整数

System.Byte

标识符

可如下例所示声明并初始化 byte 类型的变量:

byte myByte = 255;

在以上声明中,整数 255 int 隐式转换为 byte。如果整数超出了 byte 的范围,将产生编译错误。

转换

存在从 byte shortushortintuintlongulongfloatdouble decimal 的预定义隐式转换。

不能将更大存储大小的非文本数值类型隐式转换为 byte有关整型的存储大小的更多信息,请参见整型表(C# 参考)。例如,请看以下两个 byte 变量 x y

byte x = 10, y = 20; (会出错,因为该非文本数值类型存储大小大于byte)

以下赋值语句将产生一个编译错误,原因是赋值运算符右侧的算术表达式在默认情况下的计算结果为 int 类型。

// Error: conversion from int to byte:

byte z = x + y;

若要解决此问题,请使用强制转换:

// OK: explicit conversion:

byte z = (byte)(x + y);

但是,在目标变量具有相同或更大的存储大小时,使用下列语句是可能的:

int x = 10, y = 20;

int m = x + y; (正确,因为int类型存储大小大于int)

long n = x + y; (正确,因为long类型存储大小大于int)

同样,不存在从浮点型到 byte 类型的隐式转换。例如,除非使用显式强制转换,否则以下语句将生成一个编译器错误:

// Error: no implicit conversion from double:

byte x = 3.0;

// OK: explicit conversion:

byte y = (byte)3.0;

调用重载方法时,必须使用显式转换。以下面使用 byte int 参数的重载方法为例:

public static void SampleMethod(int i) {}

public static void SampleMethod(byte b) {}

使用 byte 强制转换可保证调用正确的类型,例如:

// Calling the method with the int parameter:

SampleMethod(5);

// Calling the method with the byte parameter:

SampleMethod((byte)5);

( 2 )byte的实例

1.

char类型转换成两个byte,第一个比特存unicode的第一个字节,第二个存unicode的第二个字节:

char a='a12335';
string s=Convert.ToString(a);
byte[] b=System.Text.Encoding.Unicode.GetBytes(s);//转为byte数组

2.

怎样把byte转换为char*类型的:

CString tt;
BYTE buf[100];
tt.Format(_T("%s"),buf);
char * kk=tt.GetBuffer(tt.GetLength());
上面是可以的
或者你也可以用strcpy.

3.

byte相关的处理类

一个处理BYTE和其它类型转换的类:

public class Tools{
//16进制
private static String HexCode[] = {
"0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
"a", "b", "c", "d", "e", "f"
};

private Tools(){
}

//byte类型转换为16进制字符串
public static String byteToHexString(byte b){
int n = b;
if(n < 0)
n = 256 + n;
int d1 = n / 16;
int d2 = n % 16;
return HexCode[d1]+HexCode[d2];
}

//byte数组转换为16进制字符串
public static String byteArrayToHexString(byte b[]){
String result = "";
for(int i = 0; i < b.length; i++)
result = result+byteToHexString(b[i]); ( 字符串并,注:不同于算术加 )
return result;
}


//byte数组第offset个元素起的4个字节转换为int
public static int byte2int(byte b[], int offset)
{
return b[offset + 3] & 0xff | (b[offset + 2] & 0xff) << 8 | (b[offset + 1] & 0xff) << 16 | (b[offset] & 0xff) << 24;
}
//byte数组转换为int
public static int byte2int(byte b[])
{
return b[3] & 0xff | (b[2] & 0xff) << 8 | (b[1] & 0xff) << 16 | (b[0] & 0xff) << 24; ( << 位左移;假如传入1234式中可以看出 b[0] 1, b[1] 2, b[2] 3, b[3] 4, 返回的目标结果为:1234 ;从类byte2intbyte2long可以看出int4byte的长度, long8byte的长度, short2byte的长度)
}

//byte数组转为long
public static long byte2long(byte b[])
{
return (long)b[7] & (long)255 | ((long)b[6] & (long)255) << 8 | ((long)b[5] & (long)255) << 16 | ((long)b[4] & (long)255) << 24 | ((long)b[3] & (long)255) << 32 | ((long)b[2] & (long)255) << 40 | ((long)b[1] & (long)255) << 48 | (long)b[0] << 56;
}

//byte数组第offset个元素起的8个字节转为long
public static long byte2long(byte b[], int offset)
{
return (long)b[offset + 7] & (long)255 | ((long)b[offset + 6] & (long)255) << 8 | ((long)b[offset + 5] & (long)255) << 16 | ((long)b[offset + 4] & (long)255) << 24 | ((long)b[offset + 3] & (long)255) << 32 | ((long)b[offset + 2] & (long)255) << 40 | ((long)b[offset + 1] & (long)255) << 48 | (long)b[offset] << 56;
}

//int类型转为byte数组
public static byte[] int2byte(int n)
{
byte b[] = new byte[4];
b[0] = (byte)(n >> 24);
b[1] = (byte)(n >> 16);
b[2] = (byte)(n >> 8);
b[3] = (byte)n;
return b;
}

/**
*n 为待转数据,buf[]为转换后的数据,offsetbuf[]中转换的起始点
* 转换后数据从低到高位
*/
public static void int2byte(int n, byte buf[], int offset)
{
buf[offset] = (byte)(n >> 24);
buf[offset + 1] = (byte)(n >> 16);
buf[offset + 2] = (byte)(n >> 8);
buf[offset + 3] = (byte)n;
}

public static byte[] short2byte(int n)
{
byte b[] = new byte[2];
b[0] = (byte)(n >> 8);
b[1] = (byte)n;
return b;
}

public static void short2byte(int n, byte buf[], int offset)
{
buf[offset] = (byte)(n >> 8);
buf[offset + 1] = (byte)n;
}

public static byte[] long2byte(long n)
{
byte b[] = new byte[8];
b[0] = (byte)(int)(n >> 56);
b[1] = (byte)(int)(n >> 48);
b[2] = (byte)(int)(n >> 40);
b[3] = (byte)(int)(n >> 32);
b[4] = (byte)(int)(n >> 24);
b[5] = (byte)(int)(n >> 16);
b[6] = (byte)(int)(n >> 8);
b[7] = (byte)(int)n;
return b;
}

public static void long2byte(long n, byte buf[], int offset)
{
buf[offset] = (byte)(int)(n >> 56);
buf[offset + 1] = (byte)(int)(n >> 48);
buf[offset + 2] = (byte)(int)(n >> 40);
buf[offset + 3] = (byte)(int)(n >> 32);
buf[offset + 4] = (byte)(int)(n >> 24);
buf[offset + 5] = (byte)(int)(n >> 16);
buf[offset + 6] = (byte)(int)(n >> 8);
buf[offset + 7] = (byte)(int)n;
}

}

*************************************************************************************

byte[] b = {00,00,00,00};
int i = ((b[0] << 24) + (b[1] << 16) + (b[2] << 8) + (b[3] << 0));
System.out.println(i);

System.out.println(Integer.parseInt(new String(b,0,4)));

结果:
都是由BYTE[]转换为INT,但
第一条打印语句得到结果:0
第二条出错,因为new String(b,0,4)" "

原因如下:

1)每四个byte可转换成一个int,因为int=4 byte

取出4byte
int i = (int)b[0] | ((int)b[1] << 8) | ((int)b[2] << 16) | ((int)b[3] << 24);

上面用的是+
20转换为字符串是\0,把二进制零转不成字符串的,因为\0是不可见的

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics