【Java】流与文件(端口 & 文件读写对象)
概述:
1、input和output是相对于内存而言的。输入(input)就是写入到内存里,输出(output)就是把内存里的东西写到外面。
2、操作内存里的东西非常便利,要么声明变量,要么new对象,而对于内存外的东西就没那么方便了。
3、写入写出(io流)骨子里一定要清楚的“三步操作”:a、定位。从哪里input(哪个文件、哪个端口)、output到哪里(端口or文件or数据库...)。b、建立管道。c、操作管道。
例如,向端口8000写东西,首先需要知道是往端口8000output,其次需要建立从端口8000到内存的input管道,最后,需要读多少数据呢?以什么形式读呢?叫做操作管道。
4、需要注意的是:1所有离开内存的操作都是有风险的,一定要用try catch保护风险代码。2用指针理解stream的概念,例如,每read一次指针就往沿着文本往下移动,前面的数据就“流走”了。
补充:
1、java byte类型,8位二进制为一个字节,一个英文字母占1byte,一个汉字占2byte。
文件读写的read有多个重载函数,既可以一个字节一个字节的读,无参read();也可以多个字节的读到一个byte型数组中read(new byte[size]);
2、io流的加密偶尔会涉及到“数据的溢出”。
3、使用io流通常需要分段捕获各个类型的异常:filenotfound、ioexception...
4、一定要记住的:
a、最底层的、最基本io流方法是读写字节而不是字符:InputsStream...is.read()、is.read(byte[])
b、为了处理方便有了字符流:Reader....read(char[])
c、为了提高性能,例如一次读一行,就有了BufferReader等高级流,但是BufferReader是建立在基础reader之上的!
d、常常用PrintWriter代替BufferWriter,理由是增强在各个平台的兼容性。
e、再往上走就有专门读写object的流了。
f、不考虑性能的情况下,哪个方便就用哪一个。
g、无法通过socket直接获得字符流(文件可以直接获得),必须通过字节流--InputStreamReader-->字符流---->高级流

参考:
1、java io最详解:http://blog.csdn.net/yczz/article/details/38761237
2、 java 字节流与字符流的区别:http://blog.csdn.net/cynhafa/article/details/6882061
3、为什么一定要关闭流?:http://www.iteye.com/problems/25486 个人认为一个两个iosteam不关闭也没什么问题。。但是量一多就会出问题。。另外如果不调用close,flush()一定是要调用的。。这样才能确保“效果正确”。
4、Socket与ServerSocket:http://www.cnblogs.com/rond/p/3565113.html(有些东西可能不需要了解细节。。但是随手查查心里比较有底。。。)
参考代码:

ObjectOutputStream需要的参数是OutputStream,所以传入的参数只要是OutputStream或者OutputStream的子类都可以。。。


按照需要传入就可以了。
文件io:
package com.xkfx.io;
import com.xkfx.qq.tools.transmit.User;
import java.io.*;
public class FileIOTest {
public static void main(String[] args) {
ObjectOutputStream os = null;
ObjectInputStream is = null;
try {
// 定位与建立管道
os = new ObjectOutputStream(new FileOutputStream("d:/labs/test.txt"));
is = new ObjectInputStream(new FileInputStream("d:/labs/test.txt"));
// 操作管道
os.writeObject(new User("xkfx", "a123456"));
User user = (User)is.readObject();// 读到的是Obj类对象,需要强制转换
System.out.println(user);
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
os.close();
is.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
网络io:
server:
package com.xkfx.qq.server; import com.xkfx.qq.tools.transmit.User; import java.io.IOException;
import java.io.ObjectInputStream;
import java.net.ServerSocket;
import java.net.Socket; public class Server {
public static void main(String[] args) throws IOException{
ServerSocket server = null;
server = new ServerSocket(8000); // 向操作系统注册服务
Socket socket = server.accept(); // 从连接队列中取出一个连接,如果没有则等待
ObjectInputStream is = null;
try {
is = new ObjectInputStream(socket.getInputStream());
User user = (User)is.readObject();
System.out.println(user);
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
} finally {
try {
is.close();
} catch (IOException e) {
e.printStackTrace();
}
try {
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
client:
package com.xkfx.io; import com.xkfx.qq.tools.transmit.User; import java.io.IOException;
import java.io.ObjectOutputStream;
import java.net.Socket; public class SocketTest {
public static void main(String[] args) {
Socket socket = null;
ObjectOutputStream os = null;
try {
socket = new Socket("localhost", 8000); os = new ObjectOutputStream(socket.getOutputStream());
os.writeObject(new User("qjlsd", "a123456"));
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
try {
os.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
【Java】流与文件(端口 & 文件读写对象)的更多相关文章
- JAVA之旅(三十)——打印流PrintWriter,合并流,切割文件并且合并,对象的序列化Serializable,管道流,RandomAccessFile,IO其他类,字符编码
JAVA之旅(三十)--打印流PrintWriter,合并流,切割文件并且合并,对象的序列化Serializable,管道流,RandomAccessFile,IO其他类,字符编码 三十篇了,又是一个 ...
- Java 流(Stream)、文件(File)和IO
Java.io包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io包中的流支持很多种格式,比如:基本类型.对象.本地化字符集等等. 一个流可以理解为一个数据的序 ...
- (转载)java基础:关于java流与文件操作
原文摘自: http://www.blogjava.net/haizhige/archive/2008/08/03/219668.html 1.描述:流是字节数据或字符数据序列. Java采用输入流对 ...
- java I/O框架 (四)文件流
文件读取 FileInputStream FileReader 文件写入 FileOutputStream FileWriter 随机文件读写 RandomAccessFile 一.文件读取 File ...
- Java - 17 Java 流(Stream)、文件(File)和IO
Java 流(Stream).文件(File)和IO Java.io包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io包中的流支持很多种格式,比如:基本类型. ...
- Java编程的逻辑 (60) - 随机读写文件及其应用 - 实现一个简单的KV数据库
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...
- java基础:关于java流与文件操作
1.描述:流是字节数据或字符数据序列.Java采用输入流对象和输出流对象来支持程序对数据的输入和输出.输入流对象提供了数据从源点流向程序的管道,程序可以从输入流对象读取数据:输出流对象提供了数据从程序 ...
- java 流 文件 IO
Java 流(Stream).文件(File)和IO Java.io 包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io 包中的流支持很多种格式,比如:基本类 ...
- Java流和文件
File类:java.io包下与平台无关的文件和目录 java可以使用文件路径字符串来创建File实例,文件路径可以是绝对路径,也可以是相对路径,默认情况下,相对路径是依据用户工作路径,通常就是运行J ...
- Java流(Stream)、文件(File)和IO
Java.io包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io包中的流支持很多格式,比如:基本类型.对象.本地化字符集等等. 一个流可以理解为一个数据的序列 ...
随机推荐
- Deep Networks for Image Super-Resolution with Sparse Prior
深度学习中潜藏的稀疏表达 Deep Networks for Image Super-Resolution with Sparse Prior http://www.ifp.illinois.edu/ ...
- 解决finalflares 安装成功后无法显示问题
按照网上的安装方法:http://blog.sina.com.cn/s/blog_e9370eb80101gias.html 安装插件并破解,安装过程没有任何错误,但是打开max2012始终看不到这个 ...
- IOS学习笔记28—SQLite3第三方库之FMDB
本文转载至 http://blog.csdn.net/happyrabbit456/article/details/11609451 SQLite是一种小型的轻量级的关系型数据库,在移动设备上使用是非 ...
- SpringMVC JSONP JSON支持
1.ajax端 $.ajax({ type: "post", dataType: "jsonp", //传递给请求处理程序,用以获得jsonp回调函数名的参数名 ...
- poj3411
Paid Roads Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6549 Accepted: 2427 Descri ...
- 联想打字必须按FN+数字-fn打字
对于联想G40.14英寸系列的本本,好多时候无意间可能把数字键锁定了. 这时候要做的是:打开运行--输入OSK--打开虚拟屏幕键盘.这时候可以找到 选项---打开数字键盘. 有时候某些电脑上没有NUM ...
- The Thinking of AutomaticTest(有关自动化测试的思考)
考虑因素: 容易维护 简洁易懂 代码重用性好 系统的稳定性强 UI自动化: 数据的获取:装载的数据文件类型.数据的形式.数据的解析方法定义. 1.利用Junit单元测试组织用例,明确输入数据.预期 ...
- 第二课补充01——redis-cli命令行详解、string类型、list类型、hash类型命令操作详解
一. redis-cli命令行参数 1.-x参数:从标准输入读取一个参数: [问题] [解决] 因为echo命令是默认带有回车\n的,不带回车需要echo –n命令: echo -n "ha ...
- Setting IE11 with Group Policy Preferences
一.Setting Home Page with Group Policy Preferences 1.Open the Group Policy Management Console and cre ...
- Giraph执行报错,Error: Exceeded limits on number of counters - Counters=120 Limit=120, exiting...
HamaWhite 原创,转载请注明出处.欢迎大家增加Giraph 技术交流群: 228591158 1. 近日用Giraph跑大数据的SSSP时,遇到例如以下错误: org.apache.hadoo ...