IsLegalMagicSquare
在第一次写的时候在判断已有块的地方没有任何问题,然而在generate处却总是判断不过。在打印出来后发现打印的矩阵没有任何问题,是MagicSquare,在查阅相关方法后将字节流输入改成了字符流输入后在最后补上了Bufferwriter的关闭操作。现在回想起来这个还是个比较困扰的问题,在之后的实践中我发现其实字节流也是可以的,那么字节流与字符流输入到底有什么区别呢?
常用的字节输出流主要有:
- OutputStream
- FileOutputStream
- BufferedOutputStream 【BufferedOutputStream不是OutputStream的直接实现子类,是FilterOutputStream的子类】
OutputStream是字节输出流的基类, OutputStream作为基类,给它的基类定义了几个通用的函数:
-
- write(byte[] b):将b的长度个字节数据写到输出流中。
- write(byte[] b,int off,int len):从b的off位置开始,获取len个字节数据,写到输出流中。
- flush():刷新输出流,把数据马上写到输出流中。
- close():关闭流,释放系统资源。
- FileOutputStream是用于写文件的输出流,它除了可以使用基类定义的函数外,还实现了OutputStream的抽象函数write(int b):
-
- write(int b):将b转成一个字节数据,写到输出流中。
-
- BufferedOutputStream像上面那个BufferedInputStream一样,都可以提高效率。它除了可以使用基类定义的函数外,它还实现了OutputStream的抽象函数write(int b):
-
- write(int b):将b转成一个字节数据,写到输出流中。
-
常见的字符输入流有:
- Reader
- InputStreamReader
- FileReader
- BufferedReader
- Reader是字符输入流的抽象基类 ,它定义了以下几个函数:
-
- read() :读取单个字符,返回结果是一个int,需要转成char;到达流的末尾时,返回-1
- read(char[] buf): 读取buf的长度个字符到buf这种,返回结果是读取的字符数,到达流的末尾时,返回-1
- close() :关闭流,释放占用的系统资源。
-
- InputStreamReader 可以把InputStream中的字节数据流根据字符编码方式转成字符数据流。它除了可以使用基类定义的函数,它自己还实现了以下函数:
- read(char[] buf, int offset, int length) :从offset位置开始,读取length个字符到buf中。返回结果是实际读取的字符数,到达流的末尾时,返回-1
- FileReader 可以把FileInputStream中的字节数据转成根据字符编码方式转成字符数据流。
- BufferedReader可以把字符输入流进行封装,将数据进行缓冲,提高读取效率。它除了可以使用基类定义的函数,它自己还实现了以下函数:
- read(char[] buf, int offset, int length) :从offset位置开始,读取length个字符到buf中。返回结果是实际读取的字符数,到达流的末尾时,返回-1
- readLine() :读取一个文本行,以行结束符作为末尾,返回结果是读取的字符串。如果已到达流末尾,则返回 null
基于上述及查阅资料我们得到如下图所示
字节流在操作时本身不会用到缓冲区(内存),是文件本身直接操作的,而字符流在操作时使用了缓冲区,通过缓冲区再操作文件,而二者的适用范围也不同。如果是音频文件、图片、歌曲,就用字节流好点,而如果是对于文本,尤其是中文而言则使用字符流比较合适。