您的位置:首页 > 其它

bit、byte、位、字节、汉字、字符之间的区别

2016-11-30 13:54 671 查看
bit,byte,位,字节,汉字,字符之间的区别

package com.suypower.chengyu.test;

public class ByteTest {

/**

* byte 8 bits -128 - + 127

* 1 bit = 1 二进制数据

* 1 byte = 8 bit

* ascII编码下1 字母 = 1 byte = 8 bit(位)

* ascII编码下1 汉字 = 2 byte = 16 bit

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

byte b1 = 127;

byte b2 = -128;

byte b3 = ‘a’;

byte b4 = ‘A’; // 一个字母 = 1 byte = 8 bit

// byte b5 =’aa’; 这就错了

// byte b6 =’中’; 这就错了 一个汉字 2个字节 16bit

short s1 = ‘啊’; // 一个汉字 2个字节 16bit short 是 16 bit位的

// short s2 = ‘汉字’; // 2个汉字 4个字节 32 bit int 是32 bit的

// int i1 = ‘汉字’; 但是 int 是数字类型的 , char 是 16 bit的 = 2 byte = 一个汉字

char c1 = ‘汗’;

// byte 转换 string

String string = “中文”;

byte by[] = string.getBytes();

String str = new String(by);

System.out.println(“str=”+str);

}

}

[Java-原创] bit、byte、位、字节、汉字、字符

bit、byte、位、字节、汉字的关系

1 bit     = 1  二进制数据
1 byte  = 8  bit
1 字母 = 1  byte = 8 bit
1 汉字 = 2  byte = 16 bit


bit:位

一个二进制数据0或1,是1bit;

byte:字节

存储空间的基本计量单位,如:MySQL中定义 VARCHAR(45) 即是指 45个字节;

1 byte = 8 bit

一个英文字符占一个字节;

1 字母 = 1 byte = 8 bit

一个汉字占2个字节;

1 汉字 = 2 byte = 16 bit

标点符号

A>. 汉字输入状态下,默认为全角输入方式;

B>. 英文输入状态下,默认为半角输入方式;

C>. 全角输入方式下,标点符号占2字节;

D>. 半角输入方式下,标点符号占1字节;

故:汉字输入状态下的字符,占2个字节 (但不排除,自己更改了默认设置);

英文输入状态下的字符,占1个字节 (但不排除,自己更改了默认设置);

老美在发明电脑时,肯定以自己的英文字母–即他们自认为的字符为最小的存储计量单位,于是也就有了不规范的1字符=1byte, 岂不知还有我们伟大的汉字计量单

位,NND,一个汉字也是一个字符,我们的1汉字字符就等于2byte,后来,他们可能意识到这个尴尬的问题,于是又标榜为:一个字母为一个标准字符,去球吧,谁

整天没事说个字符还“标准字符”,所以啊,个人认为:字符,不能用于标准的计量单位。

不同的字符所占的字节

不同的字符所占的字节是不同的。

  ASCII码:

  一个英文字母(不分大小写)占一个字节的空间,一个中文汉字占两个字节的空间。一个二进制数字序列,在计算机中作为一个数字单元,一般为8位二进制数,换算为十进制。最小值0,最大值255。如一个ASCII码就是一个字节。

  UTF-8编码:

  一个英文字符等于一个字节,一个中文(含繁体)等于三个字节。

  Unicode编码:

  一个英文等于两个字节,一个中文(含繁体)等于两个字节。

  符号:

  英文标点占一个字节,中文标点占两个字节。举例:英文句号“.”占1个字节的大小,中文句号“。”占2个字节的大小。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  bit byte 汉字 字符