【面试笔试】Java常见面试笔试总结

Java 基础

1、有哪些数据类型
Java定义了8种简单类型:byte、short、int、long、char、float、double和boolean。

2、面向对象的语言特征
封装、继承、多态

3、有几种访问机制?
这里写图片描述

4、面向对象的多态性在JAVA中怎么实现的
方法的重写Overriding和重载Overloading是Java多态性的不同表现。重写Overriding是父类与子类之间多态性的一种表现,重载Overloading是一个类中多态性的一种表现。如果在子类中定义某方法与其父类有相同的名称和参数,我们说该方法被重写 (Overriding)。子类的对象使用这个方法时,将调用子类中的定义,对它而言,父类中的定义如同被“屏蔽”了。如果在一个类中定义了多个同名的方法,它们或有不同的参数个数或有不同的参数类型,则称为方法的重载(Overloading)。Overloaded的方法是可以改变返回值

5、Java I/O中字符流和字节流的区别
字节流是传递0~255的整数而Java中有一些(如unicode代码)不能使用字符流,是特殊的字节流,

6、说出ArrayList,Vector, LinkedList的存储性能和特性
ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。

7、HashTable和HashMap的区别
HashTable和HashMap类有三个重要的不同之处,第一个不同主要是历史原因,HashTable是基于陈旧的Dictionary类,而HashMap是Java1.2引进的Map接口的一个实现
HashTable的方法是同步的,而HashMap的方法不是,这就意味着,虽然你可以采用任何的行为就可在一个多线程的应用程序中使用一个HashTable,但你必须同样地为HashMap提供外同步,一个方便的方法就是利用Collection类的静态的SynchronizedMap()方法,它创建了一个线程安全的Map对象,并把它作为一个封装的对象来返回,这个对象的方法可以让你同步访问潜在的hashmap,这么做的结构就是当你不需要同步时,你不能切断HashTable中的同步(比如在一个单线程的应用程序中)而且同步增加了很多处理法费用。
第三不同是,只有HashMap可以让你装空值作为一个表的条目和Key和Value,Hashmap中只有一条记录可以是一个空白的Key,但任意数量的条目可以是空白Value。这就是说,如果一个表中没有发现搜索,或者如果发现了搜索键,但是它是一个空值,那么get()将返回Null,如果有必要,用ContainKey()方法来区别这两种情况。

8、Http协议是长连接还是短链接
Http协议是无状态连接,所以是段连接。

9、java的基本数据类型有哪些,String是不是基本类型
boolean,int,byte,char,short,long,float,double,void,
String不是基本类型。

10、String 和StringBuffer的区别
STRING的长度是不可变的,STRINGBUFFER的长度是可变的。如果你对字符串中的内容经常进行操作,特别是内容要修改时,那么使用StringBuffer,如果最后需要String,那么使用StringBuffer的toString()方法

11、运行时异常与一般异常有何异同?
异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。

12.说出一些常用的类,包,接口,请各举5个
常用的类:
BufferedReader BufferedWriter FileReader FileWirter String Integer
常用的包:java.lang java.awt java.io java.util java.sql
常用的接口:Remote List Map Document NodeList

13、如何避免多个socket的读写堵塞,jdk1.4新增了哪些方法来解决这个问题?
在JDK1.4以前的版本中,要避免堵塞发生,有发以下两种方法:
采用多线程处理不同的socket操作,如果一个线程处理读,一个处理写.
使用第三方程序库,non-JDK方法.
在JDK1.4及以后的版本中引入了NIO,引入了非阻塞socket,可以不用堵塞进行网络操作.

14、servlet的生命周期 
(1)加载 / 实例化:
Servlet容器查找并加载所有的servlet类.当Servlet引擎启动时或者说在客户http请求委托时实例一个Servle或多个Servlet类
(2)初始化
这里在客户请求委托代理之前,使用init()方法进行初始化.
(3)请求处理
当初始化完成之后这时就可以处理客户http请求了.这里使用service()这个方法来完成并把其作参数进行传递,这里的参数包含了httpServletRequest()和httpServletResponse()两个方法分别对应于请求和回应它们也会抛出servletException和IOException然后针对不同的http请求(四个上面说过,get,post,put,head)由doGet(),doPost(),doPut(),doHead(),这四个不同的方法块里的处理单元来处理…
(4)删除Sevlet
有时出于一些原因需要对Sevlet容器中的servlet实例进行删除,这时就可以调用destroy()方法进行, 执行了这个方法之后,这时Sevlet就不能再执行其它客户机的请求了…而这时它也就成了JAVA垃圾回收机的回收对象了!

15、JSP中有哪些重定向方法,它们的区别?

<jsp:forward page=&rdquo;url&rdquo;/>
<jsp:include file=&rdquo;url&rdquo;/>

前者将当前页面重定向到指定的URL的页面,而后者是在当前页面中包含指定的URL的页面。

16、Jsp有哪些内置对象?作用分别是什么地?
request:用户端请求,此请求会包含来自GET/POST请求的参数
getParameter() 、setAttribute()、 getAttribute()、reponse():网页传回用户端的回应
encode()、 sendRedirect() 、setContextf()、pageContext: 网页的属性是在这里管理
getServletContext()、 getSessin() 、setAttribute()、session :与请求有关的会话期
getAttribute() 、setAttribute() 、invalidate()、application() :servlet正在执行的内容
setAttribute()、 getAttribute():config servlet的构架部件
getServletContext() 、getServletName() 、getINitParameter():out 用来传送回应的输出(用来向客户端输出数据)
println()\ flush() 、close():page Jsp网页本身
exception针对错误网页,未捕捉的例外(异常)

17、Jsp有哪些动作?作用分别是什么?
jsp共有以下6个动作:
Jsp:include::在网页被请求的时候引入一个文件
Jsp:useBean:寻找或者实例化一个javaBean
Jsp:setProperty :设置某个javaBean的属性
Jsp:getProperty:输出某个javaBean的属性
Jsp:forward:把请求转到一个新的页面。
Jsp:plugin:根据浏览器类型为java插件或生成object或embed标记

18、jsp中动态的include与静态的include的区别?
动态的include用jsp:include动作实现

它总是会检查所含文件的变化,适合用于包含动态页面,并且可以带参数
静态include用include伪码实现定不会检查,所含文件的变化,适用于包含静态页面

19、XML 有哪些解技术?区别是什么?
有DOM,SAX,STAT
DOM处理大型文件时其性能下降非常厉害。这个问题是由DOM的树型结构所造成的,这种结构占用的内存较多,而且DOM必须在解析文件之前把整个文档装入内存,适合XML的随机访问
SAX不同DOM文档驱动型,SAX是事件驱动型XML解析方式。它顺序读取XML文件,不需要一次全部装载整个文件。当遇到像文件开头,文档结束,或者标签开头与标签结束时,它会触发一个事件。用户通过在其回调事件,用户通过在其回调事件写入处理代码来处理XML文件,适合对XML的顺序访问
STAX:StreamingAPI for XMl(STAX)

20、你在项目中用到XML技术的哪些方面?如何实现的?
用到了 数据存贮,信息配置两个方面
在做数据交换平台时,将数据源数据组装XML文件,然后XML文件压缩打包加密后通过网络传送给接收都,接收解密与名解压缩后再对XML文件中还原的相关信息进行处理。
在做软件配置时,利用XML可以很方便,软件和各种配置参数都贮存在XML文件中

21、连接池的解决方案,它有哪些优点?
解决方案:在应用程序启动时建立足够的数据库连接,并将这些连接组成一个连接池,由应用程序动态地对池中的连接进行申请,使用,和释放。对于连接池的并发请求,应在请求队列中排队等待,并应用程序可根据池中连接的使用率,动态地增加或减少池中的连接数。
优点,尽可能多地重用沙消耗内存的资源,大大地节省了内存,提高了服务器的服务效率,能够支持更多的客户服务,通过使用连接池,将大大的提高程序运行效率,同时,我们可以通过其自身的管理机制监视数据库的数量,使用情况等。

22、JDBC的过程 
(1)加载JDBC驱动程序
Class.forName(“com.mysql.jdbc.Driver”);//MySQL加载JDBC驱动程序方法
Class.forName(“org.postgresql.Driver”);//PostgreSQL
Class.forName(“oracle.jdbc.driver.OracleDriver”);//Oracle
Class.forName(“com.ibm.db2.jdbc.net.DB2Driver”);//DB2
Class.forName(“com.sybase.jdbc2.jdbc.SybDriver”);//Sybase
Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDriver”);//SQLServer
(2)建立数据库连接
与MySQL数据库建立连接的方法:
Connectioncon=DriverManager.getConnection(“jdbc:mysql://MyDbComputerNameOrIP:3306/myDBName”,ID,Pwd);
与PostgreSQL数据库建立连接的方法:
Connectioncon=DriverManager.getConnection(“jdbc:postgresql://MyDbComputerNameOrIP:3306/myDBName”,ID,Pwd);
与Oracle数据库建立连接的方法:
Connectioncon=DriverManager.getConnection(“jdbc:oracle:thin:@MyDbComputerNameOrIP:1521:ORCL”,ID,Pwd);
与Sybase数据库建立连接的方法:
Connectioncon=DriverManager.getConnection(“jdbc:sybase:Tds:MyDbComputerNameOrIP:2638”,ID,Pwd);
与SQL Server数据库建立连接的方法:
Connectioncon=DriverManager.getConnection(“jdbc:microsoft:sqlserver://MyDbComputerNameOrIP:1433;databaseName=master”,ID,Pwd);
与DB1数据库建立连接的方法:
Connectioncon=DriverManager.getConnection(“jdbc:db2://MyDbComputerNameOrIP/myDBName”,ID,Pwd);
(3)创建并执行SQL语句
用Connection.createStatement()方法来创建一个Statement对象。Statement对象执行一个查询并从DBMS返回一个包含响应结果的ResultSet对象。
(4)处理从DBMS返回的数据
查询处理后从DBMS收到的查询结果赋给java.sql.ResultSet对象,该对象包含一些用来从结果集中获取数据存到Java变量中的方法,以便进行进一步处理。
(5)关闭数据库连接
使用与数据库有关的对象所消耗的内存是很大的,因此在完成数据库访问后要及时关闭数据库连接,同时还应关闭Connection中返回的内容,包括Statement对象和ResultSet对象。

  • 8
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值