- 浏览: 163608 次
- 来自: ...
-
文章分类
- 全部博客 (110)
- 网络 (3)
- window (1)
- eclipse (2)
- mysql (3)
- java (43)
- spring (2)
- memcahe (4)
- kestrel (1)
- linux (19)
- maven (1)
- 总结 (1)
- ActiveMQ (1)
- 线程 (6)
- nio (7)
- java pool (1)
- IO (1)
- 架构 (1)
- Hadoop (1)
- Storm (1)
- zookeeper (3)
- 工作进程 (1)
- epoll (3)
- nginx (4)
- uml (1)
- 分布式 (1)
- RMI (4)
- redis (1)
- shell (4)
- 黄金文档 (1)
- office (2)
- linux_setup (1)
- visio (1)
- BIOS (1)
- 回调 (1)
- jvm (1)
- resin (1)
- ssd (0)
- xmpp (1)
最新评论
-
qxjandyc:
hjjjjjjjjjjjjjjjjjjjjjj
(emoji表情) unicode5与unicode6互换 -
一个人旅行:
写的不错哦
(emoji表情) unicode5与unicode6互换
http://blog.csdn.net/silence1214/article/details/3332667
java中的字节流和字符流的存储区别,用几个常用类型的数据来比较字节流和字符流的区别
int a=5;
boolean b=true;
char c='G';
String d="你好";
使用字符流打印以上类型的数据到文件中:
PrintWriter dos =new PrintWriter(new BufferedWriter(new FileWriter("c://buffertest.txt")));
dos.print(a);
dos.print(b);
dos.print(c);
dos.print(d);
结果如下:
a是5
b是true
c是G
d是你好
字符流完全保证了和我们输入的字符保持一致
再看看字节流
DataOutputStream dos =new DataOutputStream(new FileOutputStream("c://streamtest.txt"));
dos.writeInt(a);
dos.writeBoolean(b);
dos.writeChar(c);
dos.writeUTF(d);
dos.writeChars(d);
dos.writeBytes(d);
结果是二进制文件,我们用十六进制编辑器打开它
a是00 00 00 05,int是四个字节
b是01,布尔型变量是一个字节
c是00 47,char是两个字节
d分别用3个不同的函数打印在文件中
第一个是00 06 E4 BD A0 E5 A5 BD,前面的00 06是writeUTF加上去的,是字节的数目,后面六个字节是"你好"的UTF编码,每个汉字3个字节
第二个是4F 60 59 7D,这是"你好"的big endian的Unicode编码,每个汉字2个字节
第三个是60 7D,这是从4F 60 59 7D中分别取得两个汉字的低字节
进一步说明
用记事本保存不同的编码文件,文件的头部会有一些标记来识别文件的编码类型,用记事本的另存为就可以保存不同编码类型的文件,然后用记事本打开时就可以正确识别编码,如果用十六进制编辑器打开它们就会看到用来识别编码类型的标记被写在文件头部,这些类型说明如下:
EF BB BF UTF-8
FF FE UTF-16/UCS-2, little endian
FE FF UTF-16/UCS-2, big endian
FF FE 00 00 UTF-32/UCS-4, little endian.
00 00 FE FF UTF-32/UCS-4, big-endian.
UTF-8保存一个字符时,长度为1-3个字节,也就是8bit-24bit。
其中code<= 007F的,保存为1个字节
(code >= 0080) && (code <= 0x07FF)的,保存为2个字节
code>0800的,保存为3个字节
"你好"的gb2312编码是C4 E3 BA C3,汉字大于0800,所以每个汉字保存为3个字节
little endian:低地址存放字节低位,x86是这种顺序
big endian:低地址存放字节高位,网络字节序是这种顺序
import java.nio.ByteBuffer; import java.nio.ByteOrder; import java.util.Arrays; /** * * 字节存放秩序. * ByteOrder.BIG_ENDIAN 高位排序 * ByteOrder.LITTLE_ENDIAN 低位排序 * */ public class Endians { public static void main(String[] args) { ByteBuffer bb = ByteBuffer.wrap(new byte[12]); bb.asCharBuffer().put("abcdef"); System.out.println(Arrays.toString(bb.array())); bb.rewind(); bb.order(ByteOrder.BIG_ENDIAN); bb.asCharBuffer().put("abcdef"); System.out.println(Arrays.toString(bb.array())); bb.rewind(); bb.order(ByteOrder.LITTLE_ENDIAN); bb.asCharBuffer().put("abcdef"); System.out.println(Arrays.toString(bb.array())); } /* [0, 97, 0, 98, 0, 99, 0, 100, 0, 101, 0, 102] [0, 97, 0, 98, 0, 99, 0, 100, 0, 101, 0, 102] [97, 0, 98, 0, 99, 0, 100, 0, 101, 0, 102, 0] */
java中的字节流和字符流的存储区别,用几个常用类型的数据来比较字节流和字符流的区别
int a=5;
boolean b=true;
char c='G';
String d="你好";
使用字符流打印以上类型的数据到文件中:
PrintWriter dos =new PrintWriter(new BufferedWriter(new FileWriter("c://buffertest.txt")));
dos.print(a);
dos.print(b);
dos.print(c);
dos.print(d);
结果如下:
a是5
b是true
c是G
d是你好
字符流完全保证了和我们输入的字符保持一致
再看看字节流
DataOutputStream dos =new DataOutputStream(new FileOutputStream("c://streamtest.txt"));
dos.writeInt(a);
dos.writeBoolean(b);
dos.writeChar(c);
dos.writeUTF(d);
dos.writeChars(d);
dos.writeBytes(d);
结果是二进制文件,我们用十六进制编辑器打开它
a是00 00 00 05,int是四个字节
b是01,布尔型变量是一个字节
c是00 47,char是两个字节
d分别用3个不同的函数打印在文件中
第一个是00 06 E4 BD A0 E5 A5 BD,前面的00 06是writeUTF加上去的,是字节的数目,后面六个字节是"你好"的UTF编码,每个汉字3个字节
第二个是4F 60 59 7D,这是"你好"的big endian的Unicode编码,每个汉字2个字节
第三个是60 7D,这是从4F 60 59 7D中分别取得两个汉字的低字节
进一步说明
用记事本保存不同的编码文件,文件的头部会有一些标记来识别文件的编码类型,用记事本的另存为就可以保存不同编码类型的文件,然后用记事本打开时就可以正确识别编码,如果用十六进制编辑器打开它们就会看到用来识别编码类型的标记被写在文件头部,这些类型说明如下:
EF BB BF UTF-8
FF FE UTF-16/UCS-2, little endian
FE FF UTF-16/UCS-2, big endian
FF FE 00 00 UTF-32/UCS-4, little endian.
00 00 FE FF UTF-32/UCS-4, big-endian.
UTF-8保存一个字符时,长度为1-3个字节,也就是8bit-24bit。
其中code<= 007F的,保存为1个字节
(code >= 0080) && (code <= 0x07FF)的,保存为2个字节
code>0800的,保存为3个字节
"你好"的gb2312编码是C4 E3 BA C3,汉字大于0800,所以每个汉字保存为3个字节
little endian:低地址存放字节低位,x86是这种顺序
big endian:低地址存放字节高位,网络字节序是这种顺序
发表评论
-
java final关键字
2012-10-21 21:20 1065Java中的final关键字通常的指的是“这是无法改变的”。它 ... -
Java:List中的toArray()的使用方法
2012-10-16 17:15 1074http://webservices.ctocio.com.c ... -
jvm 参数设置 -D
2012-10-16 14:06 9611、log4j 配置文件 -Dlog4j.configurat ... -
Java核心技术(第8版) – 读书笔记
2012-09-03 15:15 801http://www.coder4.com/archives/ ... -
线程123总结
2012-09-02 22:34 778线程同步的真实意思,其实是“排队”:几个线程之间要排队,一个一 ... -
Arraylist与linkedlist的区别
2012-08-31 16:44 787List: 有顺序的,元素可以重复 遍历:for 迭代 排 ... -
Java RMI之HelloWorld篇
2012-08-29 11:53 594http://www.cnblogs.com/ninahan0 ... -
Comparator和Comparable在排序中 区别
2012-08-21 09:40 756当需要排序的集合或数组不是单纯的数字类型的时候,通常可以使用C ... -
Spring Bean相关的接口、aware接口、FactoryBean
2012-08-02 14:57 37401、 package spring.beansandcon ... -
关系 UML 说明
2012-08-01 22:56 789关联是类之间的一种关系,例如老师教学生,老公和老婆,水壶装水等 ... -
replace和replaceAll 区别
2012-08-01 14:59 820replace和replaceAll是JAVA中常用的替换字符 ... -
JAVA ANNOTATION详解
2012-08-01 14:56 758http://www.cnblogs.com/phoebus0 ... -
Java中的Enum用法介绍
2012-07-27 09:39 991http://blog.sina.com.cn/s/blog_ ... -
获取本地ip
2012-07-26 09:09 908/** * @Title: getLocalIp ... -
动态代理
2012-07-25 10:29 728http://blog.csdn.net/cz_hyf/art ... -
NIO揭秘-1
2012-07-24 11:15 731http://my.oschina.net/zhangya/b ... -
FileChannel类的简单用法
2012-07-23 20:12 899http://blog.163.com/yf_198407/b ... -
JDK5.0 新特性
2012-07-23 17:30 7611.AutoBoxing 原来int是非Object,在JDK ... -
java jdk5 新特性 Annotation(注释)
2012-07-23 17:29 840http://www.iteye.com/topic/1653 ... -
java jdk5 新特性 可变参数
2012-07-23 17:28 703java jdk5 的新特性:可变参数 Java代码 ...
相关推荐
Java 内用 Unicode 编码存储字符,字符流处理类负责将外部的其他编码的字符流和 java 内 Unicode 字符流之间的转换。而类 InputStreamReader 和 OutputStreamWriter 处理字符流和字节流的转换。字符流(一次可以处理...
### Java字符流和字节流详解 #### 一、引言 在Java中,I/O流主要用于处理输入输出操作,包括文件读写等。根据处理数据类型的不同,Java I/O流主要分为字节流和字符流两大类。字节流处理的是8位的字节数据,而字符流...
在Java编程语言中,字节流(Byte Stream)和字符流(Character Stream)是处理输入输出数据的两种基本方式。字节流主要用于处理任何类型的二进制数据,如图片、音频、视频等,而字符流则专为处理基于Unicode编码的...
Java的IO流是按照数据的流向分为输入流和输出流,按照数据类型分为字节流和字符流。字节流处理的是二进制数据,适用于任何类型的文件,包括文本文件和非文本文件(如图片、音频、视频等)。字符流则用于处理字符数据...
Java中的流被分为两类:字节流和字符流。字节流处理的是8位的数据,适用于所有类型的数据,包括图像、音频等非文本数据;字符流处理的是16位的Unicode字符,主要用于处理文本数据。 字节流分为输入流和输出流,Java...
在本文中,我们将详细介绍 Java 中的字节流和字符流的区别,并通过示例代码来演示它们的使用。 字节流和字符流的区别: 字节流和字符流的主要区别在于它们操作时是否使用缓冲区。字节流在操作时不会使用缓冲区,...
Java字节流是一种用于处理字节数据的流处理机制,在Java中,字节流不包含边界数据的连续流,字节流是由字节组成的,Java里字符由两个字节组成。字节流是最基本的,它是按字节来处理二进制数据。 字节流基类有:字节...
Java中字符流与字节流的区别 Java中的流是对字节序列的抽象,可以想象有一...Java中的字节流和字符流都是流的基本概念,它们之间的区别在于它们处理的数据单元不同。正确地理解和使用字节流和字符流是java编程的基础。
总的来说,IO流是Java编程中不可或缺的一部分,理解和熟练运用字节流、字符流和文本流能帮助我们高效地处理数据输入和输出,为各种复杂的应用场景提供支持。在实际开发中,要根据数据类型和需求选择合适的流,并利用...
Java字节流和字符流是Java I/O流处理中非常基础且重要的概念,它们是用于文件读写操作的两大类型。Java字节流主要包括InputStream和OutputStream两个基类及其子类,字符流则包括Reader和Writer两个基类及其子类。 ...
Java IO库还提供了链接流(如PipedReader/PipedWriter,PipedInputStream/PipedOutputStream)和缓冲流(BufferedReader/BufferedWriter,BufferedInputStream/BufferedOutputStream),它们分别用于字符流和字节流...
根据不同的数据类型和操作方式,I/O流分为多个类别,主要包括数据流、对象流、字节流和字符流。 1. **数据流**: 数据流主要指的是InputStream和OutputStream这两类基本流。InputStream是所有读取数据的流的基类,...
在Java中,字符流分为输入流(InputStreamReader、BufferedReader)和输出流(OutputStreamWriter、PrintWriter),它们提供了高效且方便的字符级数据传输。 1. **InputStreamReader与OutputStreamWriter**: 这两个...
这两个流都有它们的顶级抽象类:字节流的`java.io.InputStream`和`java.io.OutputStream`,以及字符流的`java.io.Reader`和`java.io.Writer`。 字节流是最基础的流类型,它可以处理所有类型的数据,因为所有的数据...
在Java编程语言中,字节流、字符流、对象流和序列化是处理数据传输和存储的核心概念。这些概念在程序设计中占据了重要的地位,尤其是在处理输入/输出操作时。让我们逐一深入理解这些主题。 首先,字节流(Byte ...
Java中的字节流和字符流是处理数据输入输出的核心工具,...以上就是关于Java字节流和字符流的基本操作以及相关练习的解析,它们是Java进行数据I/O操作的基础,理解和掌握这些知识对于进行文件操作和网络通信至关重要。
Java中的流API是用于在内存和外部存储之间...综上所述,理解Java中的字节流和字符流的区别对于编写高效的I/O程序至关重要。根据实际需求选择适当的流类型,可以帮助我们更好地处理各种数据并避免可能出现的编码问题。
java 读取字节流的例子,非常好。本例用System.in.read(buffer)从键盘输入一行字符,存储在缓冲区buffer中,再以FileOutStream的write(buffer)方法,将buffer中内容写入文件WriteFile.txt中,程序如下(本例程序放在...
IO流分为字节流(Byte Stream)和字符流(Character Stream),它们构成了Java IO系统的基础。 1. **字节流**: - 字节流主要处理单个字节的数据,包括`InputStream`和`OutputStream`两个抽象基类。例如,`...