JAVA基础比较容易混淆的知识

基础1.java中常说的缺省值就是默认值的意思默认值

1.1:说出Servlet的生命周期,并说出Servlet和CGI的区别。
Servlet被服务器实例化后,调用init方法时启动,然后会执行一系列的doGet,doPost方法等等,
等到服务器决定将其摧毁时结束.而CGI在Servlet的进程中,与线程一起执行Servlet的方法.
一般一个servlet用于多个请求,所以CGI的效率低于Servlet.

1.2:Collection 和 Collections的区别。
Collection是集合类的上级接口,继承与他的接口主要有Set 和List.
Collections是针对集合类的一个帮助类,他提供一系列静态方法实现对各种集合的搜索、排序,线程安全化等操作。

1.3:HashMap和Hashtable的区别。
HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于Hashtable。HashMap允许将null作为一个entry的key或者value,而Hashtable不允许。

1.4:final, finally, finalize的区别。
final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。
finally是异常处理语句结构的一部分,表示总是执行。
finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等。

1.5:sleep() 和 wait() 有什么区别?
sleep是线程类(Thread)的方法,导致此线程暂停执行指定时间,给执行机会给其他线程,但是监控状态依然保持,到时后会自动恢复。调用sleep不会释放对象锁。
wait是Object类的方法,对此对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态。

1.6:同步和异步有何异同,在什么情况下分别使用他们?
举例说明。如果数据将在线程间共享。例如正在写的数据以后可能被另一个线程读到,或者正在读的数据可能已经被另一个线程写过了,那么这些数据就是共享数据,必须进行同步存取。当应用程序在对象上调用了一个需要花费很长时间来执行的方法,并且不希望让程序等待方法的返回时,就应该使用异步编程,在很多情况下采用异步途径往往更有效率。

1.7:forward 和redirect的区别
    forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器,浏览器根本不知道服务器发送的内容是从哪儿来的,所以它的地址栏中还是原来的地址。
    redirect就是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址,一般来说浏览器会用刚才请求的所有参数重新请求,所以session,request参数都可以获取。

1.8:swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
    switch(expr1)中,expr1是一个整数表达式。因此传递给 switch 和 case 语句的参数应该是 int、 short、 char 或者byte。
    long,string 都不能作用于swtich。在jdk1.7后,整形,枚举类型,boolean,字符串都可以放在switch中.

1.9:使用较广泛的服务器有哪些?
    NGINX(nginx),Apache(apache)

2.0:系统文件以及安装路径保存到C盘.而其他(eg:数据库,java代码编辑器命名空间,maven架包保存空间,jdk等)要保存到指定的目录下(尽量不要放在C盘).

2.1:mybatis中#与$的区别(dbms(数据库管理系统(Database Management System)))
    #{} 表示在预处理中会把参数部分用?占位符,能够防止大量sql语句注入.
    ${} 表示在动态解句注入

2.2:String是最基本的数据类型吗?
不是基本类型。基本数据类型包括byte、int、char、long、float、double、boolean和short。
java.lang.String类是final类型的,因此不可以继承这个类、不能修改这个类。为节省空间,我们应该用StringBuffer类 为提高效率节省空间,我们应该用StringBuffer类

  1. 为什么针对安全保密高的信息,char[]比String更好?
    因为String是不可变的,就是说它一旦创建,就不能更改了,直到垃圾收集器将它回收走。而字符数组中的元素是可以更改的(译者注:这就意味着你就可以在使用完之后将其更改,而不会保留原始的数据)。所以使用字符数组的话,安全保密性高的信息(如密码之类的)将不会存在于系统中被他人看到。

什么是比特(Bit),什么是字节(Byte),什么是字符(Char),它们长度是多少,各有什么区别

答案

Bit最小的二进制单位 ,是计算机的操作部分 取值0或者1
Byte是计算机操作数据的最小单位由8位bit组成 取值(-128-127)
Char是用户的可读写的最小单位,在java里面由16位bit组成 取值(0-65535)

Bit 是最小单位 计算机 只能认识 0或者1

8个字节 是给计算机看的
字符 是看到的东西 一个字符=二个字节

2.什么是流,按照传输的单位,分成哪两种流,并且他们的父类叫什么流是指数据的传输

答案

字节流,字符流
字节流:InputStream OutputStream
字符流:Reader Writer

3.流按照传输的方向可以分为哪两种,分别举例说明

答案

输入输出相对于程序
输入流InputStream
,输出流OutputStream

4.按照实现功能分为哪两种,分别举例说明

答案

节点流,处理流
节点流:OutputStream
处理流: OutputStreamWriter

5.BufferedReader属于哪种流,它主要是用来做什么的,它里面有那些经典的方法

答案

属于处理流中的缓冲流,可以将读取的内容存在内存里面,有readLine()方法

6.什么是节点流,什么是处理流,它们各有什么用处,处理流的创建有什么特征

答案

节点流 直接与数据源相连,用于输入或者输出
处理流:在节点流的基础上对之进行加工,进行一些功能的扩展
处理流的构造器必须要 传入节点流的子类

7.如果我要对字节流进行大量的从硬盘读取,要用那个流,为什么

答案

BufferedInputStream 使用缓冲流能够减少对硬盘的损伤

8.如果我要打印出不同类型的数据到数据源,那么最适合的流是那个流,为什么

答案

Printwriter 可以打印各种数据类型

9.怎么样把我们控制台的输出改成输出到一个文件里面,这个技术叫什么

答案

SetOut(printWriter,printStream)重定向

11.怎么样把输出字节流转换成输出字符流,说出它的步骤

答案

使用 转换处理流OutputStreamWriter 可以将字节流转为字符流
New OutputStreamWriter(new FileOutputStream(File file));

12.把包括基本类型在内的数据和字符串按顺序输出到数据源,或者按照顺序从数据源读入,一般用哪两个流

答案

DataInputStream DataOutputStream

13.把一个对象写入数据源或者从一个数据源读出来,用哪两个流

答案

ObjectInputStream ObjectOutputStream

14.什么叫对象序列化,什么是反序列化,实现对象序列化需要做哪些工作

答案

对象序列化,将对象以二进制的形式保存在硬盘上
反序列化;将二进制的文件转化为对象读取
实现serializable接口

不想让字段放在硬盘上就加transient

15.如果在对象序列化的时候不想给一个字段的数据保存在硬盘上面,采用那个关键字?

答案

transient关键字

16.在实现序列化接口是时候一般要生成一个serialVersionUID字段,它叫做什么,一般有什么用

答案

是版本号,要保持版本号的一致 来进行序列化

为了防止序列化出错

17.InputStream里的read()返回的是什么,read(byte[] data)是什么意思,返回的是什么值

答案

返回的是所读取的字节的int型(范围0-255)
read(byte [ ] data)将读取的字节储存在这个数组
返回的就是传入数组参数个数

Read 字节读取字节 字符读取字符

18.OutputStream里面的write()是什么意思,write(byte b[], int off, int len)这个方法里面的三个参数分别是什么意思

答案

write将指定字节传入数据源
Byte b[ ]是byte数组
b[off]是传入的第一个字符
b[off+len-1]是传入的最后的一个字符
len是实际长度

19.流一般需要不需要关闭,如果关闭的话在用什么方法,一般要在那个代码块里面关闭比较好,处理流是怎么关闭的,如果有多个流互相调用传入是怎么关闭的?

答案

流一旦打开就必须关闭,使用close方法
放入finally语句块中(finally 语句一定会执行)
调用的处理流就关闭处理流
多个流互相调用只关闭最外层的流

20.Java中的所有的流可以分为几大类,它们的名字是什么,各代表什么

答案

分为 字节输入流 InputStream
字节输出流 OutputStream
字符输入流 Reader
字符输出流 Writer
所有流都是这四个流的子类

说下常用的io流

Icon
InputStream,OutputStream,
FileInputStream,FileOutputStream,
BufferedInputStream,BufferedOutputStream
Reader,Writer
BufferedReader,BufferedWriter

21 写一段代码读取一个序列化的对象一般使用哪种Stream?

Icon
A、InputStream B、FileReader C、DataInputStream D、ObjectStream

22 io流怎样读取文件的?

Icon
使用File对象获取文件路径,通过字符流Reader加入文件,使用字符缓存流BufferedReader处理Reader,再定义一个字符串,循环遍历出文件。代码如下:
File file = new File(“d:/spring.txt”);
try {
Reader reader = new FileReader(file);
BufferedReader buffered = new BufferedReader(reader);
String data = null;
while((data = buffered.readLine())!=null){
System.out.println(data);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}

23 说说你对io流的理解

Icon
Io流主要是用来处理输入输出问题,常用的io流有InputStream,OutputStream,Reader,Writer等

24 JAVA的IO流和readLine方法

Icon
Java的io流用来处理输入输出问题,readLine是BufferedReader里的一个方法,用来读取一行。

25 用什么把对象动态的写入磁盘中,写入要实现什么接口。

Icon
ObjectInputStream,需要实现Serializable接口
26 FileInputStream 创建详情,就是怎样的创建不报错,它列出了几种形式!

Icon
FileInputStream是InputStream的子类,通过接口定义,子类实现创建FileInputStream,

28 请问你在什么情况下会在你得java代码中使用可序列化? 如何实现java序列化?
把一个对象写入数据源或者从一个数据源读出来,使用可序列化,需要实现Serializable接口

猜你喜欢

转载自blog.csdn.net/qq_43052309/article/details/82260675