前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >IO流简介

IO流简介

作者头像
逝兮诚
发布2019-10-30 12:16:33
2520
发布2019-10-30 12:16:33
举报
文章被收录于专栏:代码人生代码人生代码人生

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/luo4105/article/details/69936268

IO流即输入/input、输出/output流(InputStream、OutputStream),可以实现文件的上传、下载功能。

上传、下载的基本流程

1.获得输入流

InputStream is = new InputSteam(new File(“url地址”));

2.read输入流得到byte[]

byte[] bytes=new bytes[1024];
is.read(bytes);

3.创建输入流OutputStream

OutputStream osm = new OutputStream(new File(“url地址”));

4.写出文件

int i;
While((i = is.read(bytes)) != -1) {
osm.write(bytes, 0, i);
}

is.read(byte[])时,从输入流中读取一定数量的字节,并将其存储在数组 bytes 中。以整数形式返回实际读取的字节数。在输入数据可用、检测到文件末尾或者抛出异常前,此方法一直阻塞线程。如果 bytes 的长度为 0,则不读取任何字节并返回 0;否则,尝试读取至少一个字节。如果因为流位于文件末尾而没有可用的字节,则返回值 -1;否则,至少读取一个字节并将其存储在 bytes 中。将读取的第一个字节存储在元素 bytes[0] 中,下一个存储在 bytes[1] 中,依次类推。读取的字节数最多等于 bytes 的长度。设 k 为实际读取的字节数;这些字节将存储在 bytes[0] 到 bytes[k-1] 的元素中,不影响 bytes[k] 到 bytes[bytes.length-1] 的元素。

IO是线程堵塞的,若要线程不都塞,用NIO。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-04-09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档