- 浏览: 1432218 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (363)
- oracle (43)
- 缓存策略 (4)
- 数据库设计 (7)
- IntelliJ IDEA (8)
- freemarker (3)
- JSP (12)
- java基础 (75)
- tomcat (14)
- 服务器 (10)
- maven (3)
- linux (21)
- e-learning (2)
- 手机开发 (1)
- 设计模式 (6)
- 技术之外 (2)
- 工具的使用 (8)
- HTML 5 (5)
- 网站前台 (38)
- 网站后台 (11)
- 项目管理 (12)
- 面试题 (5)
- 幽默 (0)
- 系统架构 (8)
- 创业 (10)
- div-css (5)
- 诗词歌赋 (1)
- 网络课堂组知识库 (4)
- 杂家 (3)
- android (12)
- 框架 (14)
- 读书笔记 (1)
- 孙子兵法 (1)
- mysql (3)
- 小人书 (0)
- Jquery (6)
- eclipse (2)
- 正则表达式 (1)
最新评论
-
a98709474:
写的很详细,看完了,明白了这种概念了
数据库水平切分(拆库拆表)的实现原理解析(转) -
a98709474:
MYSQL分库分表总结 -
CatchU:
7年前的招聘要求,厉害厉害
面试要求 -
luozhixiong:
<table class="bbcode&qu ...
MYSQL分库分表总结 -
沈寅麟:
好用
freemarker格式化
read()与read(byte[] b)这两个方法在抽象类InputStream中前者是作为抽象方法存在的,后者不是,JDK API中是这样描述两者的:
1:read() :
从输入流中读取数据的下一个字节,返回0到255范围内的int字节值。如果因为已经到达流末尾而没有可用的字节,则返回-1。在输入数据可用、检测到流末尾或者抛出异常前,此方法一直阻塞。
2:read(byte[] b) :
从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。以整数形式返回实际读取的字节数。在输入数据可用、检测到文件末尾或者抛出异常前,此方法一直阻塞。如果 b 的长度为 0,则不读取任何字节并返回 0;否则,尝试读取至少一个字节。如果因为流位于文件末尾而没有可用的字节,则返回值 -1;否则,至少读取一个字节并将其存储在 b 中。将读取的第一个字节存储在元素 b[0] 中,下一个存储在 b[1] 中,依次类推。读取的字节数最多等于 b 的长度。设 k 为实际读取的字节数;这些字节将存储在 b[0] 到 b[k-1] 的元素中,不影响 b[k] 到 b[b.length-1] 的元素。
由帮助文档中的解释可知,read()方法每次只能读取一个字节,所以也只能读取由ASCII码范围内的一些字符。这些字符主要用于显示现代英语和其他西欧语言。而对于汉字等unicode中的字符则不能正常读取。只能以乱码的形式显示。
对于read()方法的上述缺点,在read(byte[] b)中则得到了解决,就拿汉字来举例,一个汉字占有两个字节,则可以把参数数组b定义为大小为2的数组即可正常读取汉字了。当然b也可以定义为更大,比如如果b=new byte[4]的话,则每次可以读取两个汉字字符了,但是需要注意的是,如果此处定义b 的大小为3或7等奇数,则对于全是汉字的一篇文档则不能全部正常读写了。
下面用实例来演示一下二者的用法:
实例说明:类InputStreamTest1.java 来演示read()方法的使用。类InputStreamTest2.java来演示read(byte[] b)的使用。两个类的主要任务都是通过文件输入流FileInputStream来读取文本文档xuzhimo.txt中的内容,并且输出到控制台上显示。
先看一下xuzhimo.txt文档的内容
InputStreamTest1.java
执行结果:
如果将while循环中的 (char)去掉,即改成:
则执行结果:
InputStreamTest2.java
执行结果:
遗憾的是,还是有乱码,解决办法可以参见下面教程
http://wentao365.iteye.com/blog/1183951
修改后的代码:
执行结果:
还是遗憾,没有换行。
解决办法,通过 commons-io-*.jar
执行结果:
1:read() :
从输入流中读取数据的下一个字节,返回0到255范围内的int字节值。如果因为已经到达流末尾而没有可用的字节,则返回-1。在输入数据可用、检测到流末尾或者抛出异常前,此方法一直阻塞。
2:read(byte[] b) :
从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。以整数形式返回实际读取的字节数。在输入数据可用、检测到文件末尾或者抛出异常前,此方法一直阻塞。如果 b 的长度为 0,则不读取任何字节并返回 0;否则,尝试读取至少一个字节。如果因为流位于文件末尾而没有可用的字节,则返回值 -1;否则,至少读取一个字节并将其存储在 b 中。将读取的第一个字节存储在元素 b[0] 中,下一个存储在 b[1] 中,依次类推。读取的字节数最多等于 b 的长度。设 k 为实际读取的字节数;这些字节将存储在 b[0] 到 b[k-1] 的元素中,不影响 b[k] 到 b[b.length-1] 的元素。
由帮助文档中的解释可知,read()方法每次只能读取一个字节,所以也只能读取由ASCII码范围内的一些字符。这些字符主要用于显示现代英语和其他西欧语言。而对于汉字等unicode中的字符则不能正常读取。只能以乱码的形式显示。
对于read()方法的上述缺点,在read(byte[] b)中则得到了解决,就拿汉字来举例,一个汉字占有两个字节,则可以把参数数组b定义为大小为2的数组即可正常读取汉字了。当然b也可以定义为更大,比如如果b=new byte[4]的话,则每次可以读取两个汉字字符了,但是需要注意的是,如果此处定义b 的大小为3或7等奇数,则对于全是汉字的一篇文档则不能全部正常读写了。
下面用实例来演示一下二者的用法:
实例说明:类InputStreamTest1.java 来演示read()方法的使用。类InputStreamTest2.java来演示read(byte[] b)的使用。两个类的主要任务都是通过文件输入流FileInputStream来读取文本文档xuzhimo.txt中的内容,并且输出到控制台上显示。
先看一下xuzhimo.txt文档的内容
InputStreamTest1.java
/** * User: liuwentao * Time: 12-1-25 上午10:11 */ public class InputStreamTest1 { public static void main(String[] args){ String path = "D:\\project\\opensouce\\opensouce_demo\\base_java\\classes\\demo\\java\\inputstream\\"; File file = new File(path + "xuzhimo.txt"); InputStream inputStream = null; int i=0; try { inputStream = new FileInputStream(file); while ((i = inputStream.read())!=-1){ System.out.print((char)i + ""); } }catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }
执行结果:
如果将while循环中的 (char)去掉,即改成:
引用
System.out.print(i + "");
则执行结果:
InputStreamTest2.java
/** * User: liuwentao * Time: 12-1-25 上午10:11 */ public class InputStreamTest2 { public static void main(String[] args){ String path = "D:\\project\\opensouce\\opensouce_demo\\base_java\\src\\demo\\java\\inputstream\\"; File file = new File(path + "xuzhimo.txt"); InputStream inputStream = null; int i=0; try { inputStream = new FileInputStream(file); byte[] bytes = new byte[16]; while ((i = inputStream.read(bytes))!=-1){ String str = new String(bytes); System.out.print(str); } }catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }
执行结果:
遗憾的是,还是有乱码,解决办法可以参见下面教程
http://wentao365.iteye.com/blog/1183951
修改后的代码:
/** * User: liuwentao * Time: 12-1-25 上午10:11 */ public class InputStreamTest3 { public static void main(String[] args) { String path = "D:\\project\\opensouce\\opensouce_demo\\base_java\\src\\demo\\java\\inputstream\\"; File file = new File(path + "xuzhimo.txt"); InputStream inputStream = null; String line; StringBuffer stringBuffer = new StringBuffer(); try { //InputStream :1)抽象类,2)面向字节形式的I/O操作(8 位字节流) 。 inputStream = new FileInputStream(file); //Reader :1)抽象类,2)面向字符的 I/O操作(16 位的Unicode字符) 。 Reader reader = new InputStreamReader(inputStream, "UTF-8"); //增加缓冲功能 BufferedReader bufferedReader = new BufferedReader(reader); while ((line = bufferedReader.readLine()) != null) { stringBuffer.append(line); } if (bufferedReader != null) { bufferedReader.close(); } String content = stringBuffer.toString(); System.out.print(content); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }
执行结果:
还是遗憾,没有换行。
解决办法,通过 commons-io-*.jar
/** * User: liuwentao * Time: 12-1-25 上午10:11 */ public class InputStreamTest4 { public static void main(String[] args) { String path = "D:\\project\\opensouce\\opensouce_demo\\base_java\\src\\demo\\java\\inputstream\\"; File file = new File(path + "xuzhimo.txt"); String content = null; try { content = FileUtils.readFileToString(file, "utf-8"); } catch (IOException e) { e.printStackTrace(); } System.out.println("content:" + content); } }
执行结果:
发表评论
-
打印IP 来源
2014-10-16 22:07 946<% String userAgent = reques ... -
java 写文本换行
2014-08-08 18:34 1977import org.apache.commons.io.Fi ... -
DBCP连接池配置示例
2014-06-17 11:44 1247<bean id="dataSourceOra ... -
CGLIB与asm
2014-05-05 14:42 1349“程序运行时,允许改变程序结构或变量类型,这种语言称为动态语言 ... -
201404转成 2014.04
2014-03-31 17:45 999public static void main(Str ... -
取出 字符串中的 网址
2013-10-15 17:47 1269public static void main(Str ... -
java反国际化
2013-09-23 18:10 1019public static String fromEn ... -
AtomicInteger与Volatile修饰
2013-02-05 11:50 6049今天写代码,尝试使用了AtomicInteger这个类,感觉 ... -
ExecutorService线程池
2013-02-05 11:40 1625http://blog.sina.com.cn/s/blog ... -
web.xml中load-on-startup的作用
2012-12-24 10:06 1667如下一段配置,熟悉DWR的再熟悉不过了: <servle ... -
最新版本
2012-09-13 09:28 1013Java SE 7u7 apache-tomcat-7.0. ... -
格式化数字
2012-09-10 20:12 907public static void main(Str ... -
用apache common io包获得文件扩展名
2012-09-09 23:11 1372apache common io包包含了很多非常实用的工具类, ... -
值传递,引用传递
2012-07-28 23:29 1147java 对于 8种基本类型 和 他们的包装类型 , 外 ... -
代码之丑
2012-07-07 22:01 2404原文:http://www.infoq.com/cn/news ... -
Memcache
2012-06-27 09:36 1047Memcache是一个高性能的分布式的内存对象缓存系统,通过在 ... -
ActiveMQ
2012-06-14 15:09 15161ActiveMQ 是Apache出品,最流行的,能力强劲的开源 ... -
proxool配置
2012-06-12 11:43 1186项目结构 所需jar包 proxool.prope ... -
各种文件的注释
2012-04-23 10:44 1012<%-- comment --%> JSP注释,也称为“隐藏注 ... -
List排序
2012-03-27 20:18 1204集合类List存放的数据,默认是按照放入时的顺序存放的,比如依 ...
相关推荐
在实际应用中,`InputStream`的多次读取可能涉及到`BufferedInputStream`的`read()`方法,它每次会读取一定大小的缓冲区。为了合并这些缓冲,我们需要维护一个`List<byte[]>`来存储每次读取的结果,然后在所有数据...
该函数创建了一个`ByteArrayOutputStream`对象,然后逐个读取`InputStream`中的字节并写入`ByteArrayOutputStream`中,最后转换为`byte[]`数组。 2. **byte[]转InputStream** ```java public InputStream ...
本篇文章将详细讲解如何在Spring Boot应用中解决`InputStream`只能读取一次的问题。 首先,了解`InputStream`的工作原理。`InputStream`是Java I/O中的基础类,它定义了读取字节流的基本操作。当我们尝试从`...
- `public int read(byte[] b) throws IOException`: 读取多个字节,存入字节数组`b`中,返回实际读取的字节数。 - `public int read(byte[] b, int off, int len) throws IOException`: 类似于上一个方法,但可以...
当需要一次性读取多个字节并将它们存储到数组中时,则可以选择`read(byte[] b)`或`read(byte[] b, int off, int len)`。 #### 三、案例分析 假设我们要编写一个程序,该程序需要通过键盘接收两个整数,然后找出这...
在Java编程中,`InputStream`是Java I/O流的基础类,用于从各种输入源读取数据。...对于压缩包中的`socketTest`文件,可能是用于测试网络数据传输的Socket编程示例,与`InputStream`在处理网络数据流时的应用紧密相关。
在Java编程语言中,`InputStream`和`OutputStream`是处理数据流的核心类,它们属于Java的I/O(Input/Output)框架。`File`类则用于处理文件操作,如读写、创建、删除等。理解如何在这些对象之间进行转换是Java开发中...
InputStream是所有输入流的抽象超类,它提供了基本的读取方法,如read()、read(byte[] b)等。InputStream有多种实现类,如FileInputStream、PipedInputStream、FilterInputStream等,每种实现类都有其特定的读取方式...
在Java编程中,String对象和Byte...总之,Java中的String与Byte类型的转换是编程中不可或缺的部分,尤其在网络编程中,理解这两种类型之间的转换方式及其在网络数据交换中的作用,对于编写高效、可靠的程序至关重要。
在Java编程中,有时我们可能需要将一个已经写入数据的`OutputStream`转换为`InputStream`,以便重新读取这些数据。这种情况通常出现在临时存储或处理数据时,例如在网络传输或者存储到内存中的场景。本篇文章将深入...
* `read(byte[] b)`:读取多个字节到字节数组中 * `close()`:关闭输入流 InputStream 的限制 InputStream 对象有一个限制:它只能读取一次。也就是说,一旦读取了 InputStream 对象,它就不能再次读取。这是因为 ...
3. `InputStream.read(byte[] b)`与`InputStream.read(byte[] b, int off, int len)`: 这两个方法用于读取多个字节。`read(byte[] b)`尝试读取`b.length`个字节到字节数组`b`中,但不保证一定能读取这么多,可能只...
InputStream中还有其他几个方法,如read(byte b[])、read(byte b[], int off, int len)、skip(long n)、close()、mark(int readlimit)、reset()、markSupported()等。这些方法都是用于读取文件的字节流, skip方法...
在上面的代码中,我们首先打开了一个文件输入流,然后使用 read 方法读取数据,并将其存储在 byte 数组中。最后,我们关闭了输入流,以释放系统资源。 二、FileInputStream 的使用 FileInputStream 是 InputStream...
**JSoup库与Java爬虫基础** JSoup是一款强大的Java库,专为处理HTML文档而设计。它提供了方便的API,使得我们能够解析、提取和修改HTML内容,这对于网络爬虫开发尤其有用。在本教程中,我们将探讨如何利用JSoup结合...
在Java编程中,InputStream、String和File是三个非常基础且重要的类,它们分别代表了数据流、文本字符串和文件对象。在实际开发中,我们经常需要在这三者之间进行转换,以便于处理不同类型的输入输出。以下是关于这...
在Java编程中,数据存储和传输常常涉及到不同类型的数据转换,特别是在数据库操作中,与二进制大数据相关的类型如`byte[]`(字节数组)和`Blob`(Binary Large Object)之间的转换尤为常见。本篇文章将详细讲解如何...
public static byte[] readInputStream(InputStream inputStream) throws IOException { byte[] buffer = new byte[1024]; int len = 0; ByteArrayOutputStream bos = new ByteArrayOutputStream(); while (...
- `public int read(byte[] b) throws IOException`:从流中读取一系列字节到byte数组`b`中。返回实际读取的字节数,如果流已结束则返回-1。 - `public void read(byte[] b, int off, int len) throws IOException...
byte[] cont = new byte[(int) file1.length()]; is.read(cont);// 读取文件 for (int i = 0; i ; i++) { System.out.print((char) cont[i]); } is.close();// 关闭文件 // 保存文件 ...