版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_41570658
0 、最大公约数 ,2300年前的欧几里得发明的算法,我还不太清楚
1 、java 中的java.util.* 和 java.awt.* 使用时有什么区别?
2 、Syntax error, insert “Dimensions” to complete ReferenceType Listclass,报错,为啥?
参考解答:java的泛型中的参数是不允许使用原始类型的。都需要用引用类型。如Integer
泛形要求能包容的是对象类型,而基本类型在java里不属于对象
3 、编程小建议
4、 为什么有这个错误呢(Syntax error on token “;”, @ expected)
参考解答 [语句要写在方法体里面]
5 、剩余内容
参考解答:IO输出;反射;枚举类型与泛型;多线程;网络通信;连接数据库
6 、在java输入流中,字节与字符有什么区别?
1) 参考解答
在读写文件,需要对内容按行处理,比如比较特定字符,处理某一行数据的时候一般会选择字符流。只是读写文件,和文件内容无关的,一般选择字节流。
2)参考解答
以下文字解释讲的更详细些
↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
(1)字节流在操作时本身不会用到缓冲区(内存),是文件本身直接操作的,而字符流在操作时使用了缓冲区,通过缓冲区再操作文件 (2)以两个写文件的操作进行比较,在操作时,字节流和字符流的操作完成之后都不关闭输出流。首先使用字节流不关闭执行,在文件中也仍然存在了输出内容,证明字节流是直接操作文件本身的;而使用字符流完成下,发现程序运行后在文件中没有任何内容,这是因为字符流操作时使用了缓冲区,而关闭字符流时会强制性地将缓冲区中的内容进行输出,但是如果程序没有关闭,则缓冲区中的内容时无法输出的。 (3)缓冲区可以理解为一段内存区域。某些情况下,一个程序频繁地操作一个资源,则性能会很低,此时为了提升性能,就可以将一部分数据暂时读入到内存的一块区域之中,以后直接从此区域中读取数据即可;在字符流操作中,所有的字符都是在内存中形成的,在输出前会将所有的内容暂时保存在内存之中,所以使用了缓冲区暂存数据。 (4)如果想在不关闭时也可以将字符流的内容全部输出,则可以使用Writer类中的flush()完成 (5)所有的文件在硬盘或者传输时都是以字节的方式进行的,包括图片都是按照字节的方式存储的,而字符是只有在内存中才会形成,因此开发中,字节流使用较为广泛 (6)InputStream,OutputStream,Reader,Writer都是抽象类,所以不能直接new (7)字节流是最基本的,所有的InputStream和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的, 但实际中很多的数据是文本,又提出了字符流的概念,它是按虚拟机的encode来处理,也就是要进行字符集的转化 这两个之间通过 InputStreamReader, OutputStreamWriter来关联,实际上是通过byte[]和String来关联 在实际开发中出现的汉字问题实际上都是在字符流和字节流之间转化不统一而造成的
7 、关于JAVA.IO中的flush()方法
参考解答 :flush()方法是输出储存在内存中全部的内容(批量输出)。 常用比如FileWriter类中就是一个典型,除了可以使用flush输出,最后调用close方法也会批量输出
8 、Java NIO和IO的主要区别
9 、关于Java的File.separator
在Windows下的路径分隔符(\)和在Linux下的路径分隔符(/)是不一样的,当直接使用绝对路径时,跨平台会报No Such file or diretory异常
File中还有几个与separator类似的静态常量,与系统有关,在编程中应尽量使用。
ps:File file = new File(“G:”+ File.separator +”demo.txt”);
部分自我练习
1、 Java中String类的构造方法
public String (byte[] byte,int index,int length):从字节数组的第index位将字符串的length个字节转化为字符串
要注意它这里其实是将字节数组进行了转码,将字节数组转码成字符
2、 InputStream read()方法详解