Objective—C的基本框架是framework,里面封装了各种数据类型,在Java中是用包来封装接口和类的。
Objective—C的输入输出用到的framework的NSData(例:NSLog(@”OC输出”) ),Java稍麻烦,用的是java.io包中的各种流(抽象类)来实现的(System.out.print(“Java输出”))。
- Java为什么提出流这个机制呢?
文件就是存储在硬盘上的数据集,一块一块的占用内存。把数据块看作水分子,流机制就是一条管道把水导入程序中。有的流机制(带buffer的)方法,把水装进小桶中,每次小桶装满,再倒入程序。
为什么要设置小桶(流)这个概念呢?因为数据存储都是在硬盘上,读写数据都是在硬盘上进行的,而硬盘的磁盘、磁头这些物件都是有使用次数的,访问的越频繁,使用时间就会越短,因此才会用流来减少它使用,而且一个字节一个字节的读取不仅毁硬盘,能一次读取的分成几十次读、或成千上万读效率也十分低。(2016年11月18日补充)
- 流机制和其他输入输出有什么不同呢?
最明显的输入流和输出流是成对出现的,是用try catch引入,不用时需要关闭管道(.close())。
- java流举例
import java.io.*;
public class TestPrintStream1 {
public static void main(String[] args) {
PrintStream ps = null;
try {
FileOutputStream fos =
new FileOutputStream("d:\\bak\\log.dat");
ps = new PrintStream(fos);
} catch (IOException e) {
e.printStackTrace();
}
if(ps != null){
System.setOut(ps);
}
int ln = 0;
for(char c = 0; c <= 60000; c++){
System.out.print(c+ " ");
if(ln++ >=100){ System.out.println(); ln = 0;}
}
}
}