java面试题

面向对象的特征有哪些方面

1.抽象:抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。

2.继承:继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或增加新的方法使之更适合特殊的需要。

3.封装:封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受保护的接口访问其他对象。

4. 多态性:多态性是指允许不同类的对象对同一消息作出响应。多态性包括参数化多态性和包含多态性。多态性语言具有灵活、抽象、行为共享、代码共享的优势,很好的解决了应用程序函数同名问题。

 

垃圾回收的优点和原理

Java语言中一个显著的特点就是引入了垃圾回收机制,使c++程序员最头疼的内存管理的问题迎刃而解,它使得Java程序员在编写程序的时候不再需要考虑内存管理。由于有个垃圾回收机制,Java中的对象不再有“作用域”的概念,只有对象的引用才有“作用域”。垃圾回收可以有效的防止内存泄露,有效的使用可以使用的内存。垃圾回收器通常是作为一个单独的低级别的线程运行,不可预知的情况下对内存堆中已经死亡的或者长时间没有使用的对象进行清楚和回收,程序员不能实时的调用垃圾回收器对某个对象或所有对象进行垃圾回收。回收机制有分代复制垃圾回收和标记垃圾回收,增量垃圾回收。

 

Request对象的主要方法:

setAttribute(String name,Object):设置名字为name的request的参数值

getAttribute(String name):返回由name指定的属性值

getAttributeNames():返回request对象所有属性的名字集合,结果是一个枚举的实例

getCookies():返回客户端的所有Cookie对象,结果是一个Cookie数组

getCharacterEncoding():返回请求中的字符编码方式

getContentLength():返回请求的Body的长度

getHeader(String name):获得HTTP协议定义的文件头信息

getHeaders(String name):返回指定名字的request Header的所有值,结果是一个枚举的实例

getHeaderNames():返回所以request Header的名字,结果是一个枚举的实例

getInputStream():返回请求的输入流,用于获得请求中的数据

getMethod():获得客户端向服务器端传送数据的方法

getParameter(String name):获得客户端传送给服务器端的有name指定的参数值

getParameterNames():获得客户端传送给服务器端的所有参数的名字,结果是一个枚举的实例

getParameterValues(String name):获得有name指定的参数的所有值

getProtocol():获取客户端向服务器端传送数据所依据的协议名称

getQueryString():获得查询字符串

getRequestURI():获取发出请求字符串的客户端地址

getRemoteAddr():获取客户端的IP地址

getRemoteHost():获取客户端的名字

getSession([Boolean create]):返回和请求相关Session

getServerName():获取服务器的名字

getServletPath():获取客户端所请求的脚本文件的路径

getServerPort():获取服务器的端口号

removeAttribute(String name):删除请求中的一个属性

 

数组有length属性
String有length()方法

 

Overriding重写:子类与父类之间
Overloading重载:同一个类之间,参数数量可以不同,类型可以不同,返回值可以不同。

 

error:表示一种严重问题,比如内存溢出不可能指望程序能处理这样的情况。
exception:表示可以处理的问题。

 

Collection:List(Vector、ArrayList、LinkedList)、Set
Map:Hashtable、HashMap 提供了从key到value的映射。

 

jsp中包含外部文件的方式:
<jsp:include page="include.jsp" flush="true" />适合用于包含动态页面,可以带参数。
<%@ include file="include.html" %>适合包含静态页面。

 

&位运算符
&&布尔逻辑运算符

 

应用服务器可以运行EJB,Web服务器不能运行EJB

 

forward()方法可以使用原来的对象,且速度较快,地址栏不变,只能在本机内的页面间跳转。
redirect()方法不可以使用原来的对象,速度较慢,地址栏变化,可以在任何页面和机器间跳转。

 

M:Model代表的是应用的业务逻辑(通过JavaBean,EJB组件实现)
V:View应用的表示层(由jsp页面产生)
C:Controller提供应用的处理控制过程(一般是一个Servlet)
通过这种模式将应用的业务逻辑、应用的页面显示、和应用的处理控制过程分开,这些组件可以进行交互重用。

 

jsp九大内置对象:request、response、application、page、error、pageContext、session、out、exception
jsp六大类基本动作:jsp:include、jsp:useBean、jsp:setProperty、jsp:getProperty、jsp:forward、jsp:plugin
servlet的生命周期:init()、service()、destroy()

 

java有几种修饰符和分别的有效范围?
 public  可以被任何类访问
 ptotected 可以被同一包中的所有类访问、可以被所有子类访问、子类没有在同一包中也可以访问
 private  只能够被当前类的方法访问
 缺省(无访问修饰符) 可以被同一包中的所有类访问、如果子类没有在同一个包中,也不能访问

 

java有基本数据类型?
 boolean、char、byte、int、short、long、float、double
   类型  描述   取值范围
   Boolean 布尔型   只有两个值true、false
   Char  字符型   占2个字节
   Byte  8位带符号整数  -128到127之间的任意整数
   Short  16位无符号整数  -32768~32767之间的任意整数
   Int  32位带符号整数  -231到231-1之间的任意整数
   Long  64位带符号整数  -263到263-1之间的任意整数
   Float  32位单精度浮点数 根据IEEE754-1985标准
   Double  64位双精度浮点数 根据IEEE754-1985标准
 一个汉字占2个字节,

 

int和Integer的区别?
 int是基本数据类型,Integer是对int进行了封装的一个类。
 声明为int的变量不需要实例化,声明为Interger的变量需要实例化

 

String怎么样转换为Integer?
 Integer ii = new Integer(Integer.parseInt(i));

 

forward和redirect的区别?
 其一、forward可以把index.jsp中的问号以及表单中的参数传到forward的目标页面(redirectOrForward.jsp),但是redirect不行;
 其二、forward的时候,请求的地址就是最终显示在浏览器地址栏中的URL,而redirect时,请求的地址与最终显示在浏览器地址栏中的URL一般不一样,而且后者以redirect时的参数(地址)为准。
 基于以上做一个简单的分析或者说推测:
 1、forward是你所请求的URL所在服务器,把你的请求封装成流传给forward到的目标页面(其中含有以及基本信息以及参数等),而redirect相当于你首先向你所请求的URL申请,然后此URL给你一个新的URL,你再向此新URL再来一次新的请求,所以浏览器地址栏会变,而且接受不到原先传的参数(index.jsp中传的)

 

动态include和静态include的区别?
 动态INCLUDE用jsp:include动作实现 它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数。
 静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面

 

final、finally、finalize的区别?
 final—修饰符(关键字)如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承。因此一个类不能既被声明为 abstract的,又被声明为final的。将变量或方法声明为final,可以保证它们在使用中不被改变。被声明为final的变量必须在声明时给定初值,而在以后的引用中只能读取,不可修改。被声明为final的方法也同样只能使用,不能重载。
 finally—再异常处理时提供 finally 块来执行任何清除操作。如果抛出一个异常,那么相匹配的 catch 子句就会执行,然后控制就会进入 finally 块(如果有的话)。
 finalize—方法名。Java 技术允许使用 finalize() 方法在垃圾收集器将对象从内存中清除出去之前做必要的清理工作。这个方法是由垃圾收集器在确定这个对象没有被引用时对这个对象调用的。它是在 Object 类中定义的,因此所有的类都继承了它。子类覆盖 finalize() 方法以整理系统资源或者执行其他清理工作。finalize() 方法是在垃圾收集器删除对象之前对这个对象调用的。

 

abstract class和interface的区别?
 1.interface的所有函数都是abstract的;
 2.interface的数据成员默认都是public static final的;
 3.Interface可以被多继承,abstract class单继承

 

编译期异常和运行期异常的区别?
 编译期和运行期进行的操作是不相同的,编译器只是进行语法的分析,分析出来的错误也只是语法上的错误,而运行期在真正在分配内存··
 比如说你写一个while循环,一直往栈里写,编译器是不会出错的,可是运行期就会出现栈满的错误··
 编译时是调用检查你的源程序是否有语法错误,如果没有就将其翻译成字节码文件。即.class文件。
 运行时是java虚拟机解释执行字节码文件

 

Statement和PreparedStatement的区别?
 PreparedStatement语句是进行预编译,下次执行相同的sql语句时,数据库端不会再进行预编译了,而直接用数据库的缓冲区,提高数据访问的效率,另外PreparedStatement 能有效防止Sql注入攻击,但失于灵活。
 Statement灵活性高些.
 它们的作用都一样,PreparedStatement在sql语句使用占位符,Statement不能使用占位符

 

HashMap和Hashtable的区别?
 一.历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现
 二.同步性:Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步的
 三.值:只有HashMap可以让你将空值作为一个表的条目的key或value
 所以,一般用HashMap,要求线程安全采用HashTable

 

ArrayList和Vector和LinkedList的区别?
 一.同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程序不安全的,不是同步的
 二.数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半

 

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

 

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

 

&和&&的区别?
 &是位运算符,表示按位与运算
 &&是逻辑运算符,表示逻辑运算与(and)

 

==和equal()的区别?
 判断字符串a和b是否相等可以用a.equals(b)或者b.equals(a),这两种方法效果都是一样的,因为都是字符串类型.所以括号里面不用再加双引号.否则就会报错,因为加双引号之后那双引号之间的就是一串字符串,另外加一点."equals()"是判断对象.而"=="则是对象的值..
 

jsp有几大内置对象?
 1)page:JavaBean只能在当前页面中使用。在JSP页面执行完毕后,该JavaBean将会被进行垃圾回收。
 (2)request:JavaBean在相邻的两个页面中有效。
 (3)session:JavaBean在整个用户会话过程中都有效。
 (4)application:JavaBean在当前整个Web应用的范围内有效。
 jsp:setProperty指令功能是设置JavaBean的属性。jsp:getProperty操作指令功能是得到某个JavaBean的属性值。


说出Servlet的生命周期,并说出Servlet和CGI的区别
 Servlet的生命周期分为5个阶段:
 实例化:Servlet容器创建Servlet类的实例。
 初始化:该容器调用init()方法,通常会申请资源。
 服务:由容器调用service()方法,(也就是doGet()和doPost())。
 破坏:在释放Servlet实例之前调用destroy()方法,通常会释放资源。
 不可用:释放内存的实例。

 CGI(Common Gateway Interface通用网关接口)程序来实现数据在Web上的传输,使用的是如Perl这样的语言编写的,它对于客户端作出的每个请求,必须创建CGI程序的一个新实例,这样占用大量的内存资源。由此才引入了Servlet技术。

 Servlet是一个用java编写的应用程序,在服务器上运行,处理请求信息并将其发送到客户端。对于客户端的请求,只需要创建Servlet的实例一次,因此节省了大量的内存资源。Servlet在初始化后就保留在内存中,因此每次作出请求时无需加载。

从来没有人说过Java的Class名字必须和其文件名相同。但public class的名字必须和文件名相同。

 

四种会话跟踪技术
会话作用域ServletsJSP 页面描述
page否是代表与一个页面相关的对象和属性。一个页面由一个编译好的 Java servlet 类(可以带有任何的 include 指令,但是没有 include 动作)表示。这既包括 servlet 又包括被编译成 servlet 的 JSP 页面
request是是代表与 Web 客户机发出的一个请求相关的对象和属性。一个请求可能跨越多个页面,涉及多个 Web 组件(由于 forward 指令和 include 动作的关系)
session是是代表与用于某个 Web 客户机的一个用户体验相关的对象和属性。一个 Web 会话可以也经常会跨越多个客户机请求
application是是代表与整个 Web 应用程序相关的对象和属性。这实质上是跨越整个 Web 应用程序,包括多个页面、请求和会话的一个全局作用域

 

/t 空格
/n 回车

 

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

 

doGet()和doPost()的区别?
 不管是post还是get方法提交过来的连接,都会在service中处理,然后,由service来交由相应的doPost或doGet方法处理,如果你重写了service方法,就不会再处理doPost或doGet了
 doGet()方法只能提交256个字符,doPost()则没有这个限制
 doGet()方法提交表单的时候会在url后边显示提交的内容,所以不安全,doPost()不会。

 

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

 

sleep()和wait()的区别?synchronized()方法什么意思?
 sleep()方法是使线程停止一段时间的方法。在sleep时间间隔期满后,线程不一定立即恢复执行。这是因为在那个时刻,其它线程可能正在运行而且没有被调度为放弃执行,
 除非(a)“醒来”的线程具有更高的优先级
       (b)正在运行的线程因为其它原因而阻塞。
 wait()是线程交互时,如果线程对一个同步对象x发出一个wait()调用,该线程会暂停执行,被调对象进入等待状态,直到被唤醒或等待时间到。

 功能差不多,都用来进行线程控制,他们最大本质的区别是:sleep()不释放同步锁,wait()释放同步锁
       还有用法的上的不同是:sleep(milliseconds)可以用时间指定来使他自动醒过来,如果时间不到你只能调用interreput()来强行打断;wait()可以用notify()直接唤起.

启动线程是start()方法

 

JAVA多线程 一:继承Thread、一是:实现Runnable借口
 虽然说线程是并发运行的。然而实际情况并非如此。对于多线程的程序,任务角色的不同使得每个线程的重要程度也不尽相同,
 如多个线程在等待获得CPU时间片,往往希望优先级高的线程优先抢占到CPU并得以执行。
 此外,多个线程交替执行时,不同优先级决定了级别高的线程将得到CPU的次数多一些且时间长一些,
 这样,高优先级的线程任务处理的效率明显就会更高一些,从而满足一些特殊的需要

 

JAVA实现序列化的方法是实现java.io.Serializable接口。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值