javajava基础笔试题总失败怎么办

  1 说得太少  尤其是那些开放式的问题,如“请介绍下你自己”或“请讲一下你曾经解决过的复杂问题”。面试官会通  过你对这些技术和非技术问题的回答来评估你的激情。他们也会通过模拟团队氛围和与你的交流互动来判  断你的经验和能力。   所以,仅仅只用两三句话来回答不但不能显示出你对这个专业的兴趣,还会让整个面试过程显得非常无聊  。如果你不能很好地说明你的经验、成就和技能可以给企业带来的价值,那么你的竞争力毫无疑问就高不  起来。所以,你需要对一些最常见的开放式问答作充分的准备,学会推销自己。  2 说得太多  不断地说,不断地说,却并没有什么实质性的内容。换句话说,就是废话连篇,言之无物。如果你不能简  洁的解释问题,那么面试官就会怀疑你在工作时的表现是不是也会像你的谈话一样拖泥带水?可以先问问  面试官,确定是否真的需要详细解释。   解释也是一门艺术,关键是确定重点,如果需要的话再深入到细节。当聊到业务的时候,就应该从业务的  角度看问题,不要涉及任何技术术语。学会用简洁明了的方式解释问题。如果你能时刻把握主旨,那么这  一点也不是问题。  3 回答不出一些必知的基本技术问题  面试不是技术竞赛,不是看谁答对的问题多,但是有一些“必须知道”的核心Java和Web基础知识,你不  能不知。例如,对于Java开发人员   1)不知道“==”和equals()之间的区别。  2)不知道equals()和hashCode()方法被隐式调用时的约定。  3)不知道OO的概念和设计原则。  4)不能很好地处理多线程。  5)不知道如何在HTTP客户端与服务器端之间保持状态。  6)不能解释曾投入精力过的应用程序的高层体系结构。  7)不知道SQL。  4 既写不好简单的代码,又回答不出如何解决棘手的问题  作为一个开发人员,你应该根据自己的经验水平,来针对给定的问题和情况编写代码。特别是如果碰到一  个比较棘手的问题,那么即使你还没有解决方案,也应该将你的思路讲给面试官听。  当然这在面试时会让人特别紧张,尤其是在还有时间限制的情况下,但是你也必须保持冷静,至少应该说  明你将如何试着去解决问题的方法。  5 糟糕的礼仪和态度  迟到,不适宜的着装,抖手抖脚,没有眼神接触,过于紧张,没有提问,显示不出对这份职业的兴趣,“  我什么都知道”的高傲态度,贬低你的现在和以前的雇主。  遇到技术问题时烦躁不安或者垂头丧气,为自己找理由而不是虚心接受错误,与面试官发生争执,不好的  肢体语言,随波逐流而没有自己的看法,过于呆板,撒谎,嗓门太大,无法成为良好的倾听者,等等。  提示:面试官要找的不是技术明星,而是实实在在具备了合适的技术技能、软技能、端正的态度以及能为  企业获取利益、全面的专业人才。  因此,不妨先研究下想要应聘的机构,深入了解其工作规范以调整回答问题时的方向和重点。将每一场面  试都当作免费的培训课程,积极调整心态,不但能达到一个双赢的局面,还可以减少紧张的情绪,从而获  得更好的表现。这样即使你并没有得到那份工作,也可以由此学到点什么,获得进步。  文章来源:长沙尚学堂
楼主发言:1次 发图:0张 | 更多
<span class="count" title="万
<span class="count" title="万
请遵守言论规则,不得违反国家法律法规回复(Ctrl+Enter)003java面试笔记——【java基础篇】从团八百失败面试总结的java面试题(未完待续)
8、java 线程
1)线程概念,线程与进程
线程:线程是“进程”中某个单一顺序的控制流。也被称为轻量进程。线程是进程中的实体,一个进程可以拥有多个线程,一个线程必须有一个父进程。线程不拥有系统资源,只有运行必须的一些数据结构;它与父进程的其它线程共享该进程所拥有的全部资源。进程可以创建和撤消线程,从而实现程序的并发执行。
进程:进程是操作系统结构的基础;是一个正在执行的程序;计算机中正在运行的程序实例;可以分配给处理器并由处理器执行的一个实体;由单一顺序的执行显示,一个当前状态和一组相关的系统资源所描述的活动单元。
线程与进程:有时候,线程也称作轻量级进程。就象进程一样,线程在程序中是独立的、并发的执行路径,每个线程有它自己的堆栈、自己的程序计数器和自己的局部变量。但是,与分隔的进程相比,进程中的线程之间的隔离程度要小。它们共享内存、文件句柄和其它每个进程应有的状态。进程可以支持多个线程,它们看似同时执行,但互相之间并不同步。一个进程中的多个线程共享相同的内存地址空间,这就意味着它们可以访问相同的变量和对象,而且它们从同一堆中分配对象。进程是资源分配的基本单位。所有与该进程有关的资源,都被记录在进程控制块PCB中。以表示该进程拥有这些资源或正在使用它们。另外,进程也是抢占处理机的调度单位,它拥有一个完整的虚拟地址空间。与进程相对应,线程与资源分配无关,它属于某一个进程,并与进程内的其他线程一起共享进程的资源。当进程发生调度时,不同的进程拥有不同的虚拟地址空间,而同一进程内的不同线程共享同一地址空间。线程只由相关堆栈(系统栈或用户栈)寄存器和线程控制表TCB组成。寄存器可被用来存储线程内的局部变量,但不能存储其他线程的相关变量。发生进程切换与发生线程切换时相比较,进程切换时涉及到有关资源指针的保存以及地址空间的变化等问题;线程切换时,由于同不进程内的线程共享资源和地址空间,将不涉及资源信息的保存和地址变化问题,从而减少了操作系统的开销时间。而且,进程的调度与切换都是由操作系统内核完成,而线程则既可由操作系统内核完成,也可由用户程序进行。
守护线程:在Java中有两类线程:User
Thread(用户线程)、Daemon Thread(守护线程)
Daemon的作用是为其他线程的运行提供便利服务,比如垃圾回收线程就是一个很称职的守护者。User和Daemon两者几乎没有区别,唯一的不同之处就在于虚拟机的离开:如果 User Thread已经全部退出运行了,只剩下Daemon Thread存在了,虚拟机也就退出了。 因为没有了被守护者,Daemon也就没有工作可做了,也就没有继续运行程序的必要了。
值得一提的是,守护线程并非只有虚拟机内部提供,用户在编写程序时也可以自己设置守护线程。下面的方法就是用来设置守护线程的。
public final void setDaemon(boolean on)
2)线程的生命周期
派生:线程在进程内派生出来,它即可由进程派生,也可由线程派生。
阻塞(Block):如果一个线程在执行过程中需要等待某个事件发生,则被阻塞。
激活(unblock):如果阻塞线程的事件发生,则该线程被激活并进入就绪队列。
调度(schedule):选择一个就绪线程进入执行状态。
结束(Finish):如果一个线程执行结束,它的寄存器上下文以及堆栈内容等将被释放。
3)线程同步与死锁
同步:许多线程在执行中必须考虑与其他线程之间共享数据或协调执行状态。这就需要同步机制。在Java中每个对象都有一把锁与之对应。但Java不提供单独的lock和unlock操作。它由高层的结构隐式实现,
来保证操作的对应。(然而,我们注意到Java虚拟机提供单独的monito renter和monitorexit指令来实现lock和unlock操作。)
synchronized语句计算一个对象引用,试图对该对象完成锁操作, 并且在完成锁操作前停止处理。当锁操作完成synchronized语句体得到执行。当语句体执行完毕(无论正常或异常),解锁操作自动完成。作为面向对象的语言,synchronized经常与方法连用。一种比较好的办法是,如果某个变量由一个线程赋值并由别的线程引用或赋值,那么所有对该变量的访问都必须在某个synchromized语句或synchronized方法内。
死锁:是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。如果程序中有几个竞争资源的并发线程,那么保证均衡是很重要的。系统均衡是指每个线程在执行过程中都能充分访问有限的资源。系统中没有饿死和死锁的线程。Java并不提供对死锁的检测机制。对大多数的Java程序员来说防止死锁是一种较好的选择。最简单的防止死锁的方法是对竞争的资源引入序号,如果一个线程需要几个资源,那么它必须先得到小序号的资源,再申请大序号的资源。
4)java线程创建与启动
两种方式创建线程:扩展java.lang.Thread类、实现java.lang.Runnable接口。
启动线程:在线程的Thread对象上调用start()方法,而不是run()或者别的方法。在调用start()方法之前:线程处于新状态中,新状态指有一个Thread对象,但还没有一个真正的线程。在调用start()方法之后:发生了一系列复杂的事情:启动新的执行线程(具有新的调用栈);该线程从新状态转移到可运行状态;当该线程获得机会执行时,其目标run()方法将运行。
线程的名字:一个运行中的线程总是有名字的,名字有两个来源,一个是虚拟机自己给的名字,一个是你自己的定的名字。在没有指定线程名字的情况下,虚拟机总会为线程指定名字,并且主线程的名字总是main,非主线程的名字不确定。线程都可以设置名字,也可以通过Thread.currentThread()获取线程的名字。
5)java的优先级
线程的优先级仍然无法保障线程的执行次序。只不过,优先级高的线程获取CPU资源的概率较大,优先级低的并非没机会执行。线程的优先级用1-10之间的整数表示,数值越大优先级越高,默认的优先级为5。在一个线程中开启另外一个新线程,则新开线程称为该线程的子线程,子线程初始优先级与父线程相同。
Thread t1 = new MyThread1();
Thread t2 = new Thread(new MyRunnable());
t1.setPriority(10);
t2.setPriority(1);
6)wait(),sleep(),yield(),join(),notify(),notifyAll()
wait():是Object 类的方法,对此对象调用wait 方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象发出notify
方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态。
sleep():是Thread类的方法,导致此线程暂停执行指定时间,给执行机会给其他线程,但是监控状态依然保持,到时后会自动恢复。调用sleep() 不会释放对象锁。
yield():方法只是把线程的状态有执行状态打回准备就绪状态,所以,执行这个方法后,有可能马上又开始运行,有可能等待很长时间,yield()方法只能让同优先级的线程有执行的机会,调用yield()不会释放对象锁。 yield()方法先检测当前是否有相同优先级的线程处于同可运行状态,如有,则把
CPU 的占有权交给此线程,否则继续运行原来的线程。所以yield()方法称为“退让”,它把运行机会让给了同等优先级的其他线程。
join(): join()方法使调用该方法的线程在此之前执行完毕,也就是等待调用该方法的线程执行完毕后再往下继续执行。 join()
方法主要是让调用该方法的thread完成run方法里面的东西后, 在执行join()方法后面的代码。
t.join():表示当前线程停止执行直到t线程运行完毕;
t.join(1000): 表示当前线程等待t线程运行1000后执行;
notify()/notifyAll():notify和notifyAll都是把某个对象上休息区内的线程唤醒,notify只能唤醒一个,但究竟是哪一个不能确定,而notifyAll则唤醒这个对象上的休息室中所有的线程。
7)volatile关键字
用volatile修饰的变量,线程在每次使用变量的时候,都会读取变量修改后的最的值。volatile很容易被误用,用来进行原子性操作。
Java 语言中的 volatile 变量可以被看作是一种 “程度较轻的 synchronized”;与 synchronized 块相比,volatile 变量所需的编码较少,并且运行时开销也较少,但是它所能实现的功能也仅是 synchronized 的一部分。锁提供了两种主要特性:互斥(mutual exclusion) 和可见性(visibility)。互斥即一次只允许一个线程持有某个特定的锁,因此可使用该特性实现对共享数据的协调访问协议,这样,一次就只有一个线程能够使用该共享数据。可见性必须确保释放锁之前对共享数据做出的更改对于随后获得该锁的另一个线程是可见的,如果没有同步机制提供的这种可见性保证,线程看到的共享变量可能是修改前的值或不一致的值,这将引发许多严重问题。Volatile
变量具有 synchronized 的可见性特性,但是不具备原子特性。这就是说线程能够自动发现 volatile 变量的最新值。
要使 volatile 变量提供理想的线程安全,必须同时满足下面两个条件:对变量的写操作不依赖于当前值;该变量没有包含在具有其他变量的不变式中。
第一个条件的限制使 volatile 变量不能用作线程安全计数器。虽然增量操作(x++)看上去类似一个单独操作,实际上它是一个由读取-修改-写入操作序列组成的组合操作,必须以原子方式执行,而 volatile 不能提供必须的原子特性。实现正确的操作需要使 x 的值在操作期间保持不变,而 volatile 变量无法实现这点。
每一个线程运行时都有一个线程栈,线程栈保存了线程运行时候变量值信息。当线程访问某一个对象时候值的时候,首先通过对象的引用找到对应在堆内存的变量的值,然后把堆内存变量的具体值load到线程本地内存中,建立一个变量副本,之后线程就不再和对象在堆内存变量值有任何关系,而是直接修改副本变量的值,在修改完之后的某一个时刻(线程退出之前),自动把线程变量副本的值回写到对象在堆中变量。这样在堆中的对象的值就产生变化了。
read and load 从主存复制变量到当前工作内存
use and assign
执行代码,改变共享变量值
store and write 用工作内存数据刷新主存相关内容
其中use and assign 可以多次出现,但是这一些操作并不是原子性,也就是 在read load之后,如果主内存count变量发生修改之后,线程工作内存中的值由于已经加载,不会产生对应的变化,所以计算出来的结果会和预期不一样。
看过本文的人也看了:
我要留言技术领域:
取消收藏确定要取消收藏吗?
删除图谱提示你保存在该图谱下的知识内容也会被删除,建议你先将内容移到其他图谱中。你确定要删除知识图谱及其内容吗?
删除节点提示无法删除该知识节点,因该节点下仍保存有相关知识内容!
删除节点提示你确定要删除该知识节点吗?java异常架构图 和几个面试题 - 京灬小涛 - 博客园
1.java异常架构图
粉红色的是受检查的异常(checked exceptions),其必须被 try{}catch语句块所捕获,或者在方法签名里通过throws子句声明.受检查的异常必须在编译时被捕捉处理,命名为 CHecked Exception 是因为Java编译器要进行检查,Java虚拟机也要进行检查,以确保这个规则得到遵守.绿色的异常是运行时异常(runtime exceptions),需要程序员自己分析代码决定是否捕获和处理,比如 空指针,被0除...而声明为Error的,则属于严重错误,需要根据业务信息进行特殊处理,Error不需要捕捉。
2.try{}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,在return前还是后?
也许你的答案是在return之前,但往更细地说,我的答案是在return中间执行,请看下面程序代码的运行结果:
classTest {
public static void main(String[] args) {
System.out.println(newTest().test());
staticint test()
int x = 1;
---------执行结果 ---------
运行结果是1,为什么呢?主函数调用子函数并得到结果的过程,好比主函数准备一个空罐子,当子函数要返回结果时,先把结果放在罐子里,然后再将程序逻辑返回到主函数。所谓返回,就是子函数说,我不运行了,你主函数继续运行吧,这没什么结果可言,结果是在说这话之前放进罐子里的。
3。final, finally, finalize的区别。
  final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。
内部类要访问局部变量,局部变量必须定义成final类型,例如,一段代码&&
finally是异常处理语句结构的一部分,表示总是执行。
finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等。JVM不保证此方法总被调用
4.请写出你最常见到的5个runtime exception。
这道题主要考你的代码量到底多大,如果你长期写代码的,应该经常都看到过一些系统方面的异常,你不一定真要回答出5个具体的系统异常,但你要能够说出什么是系统异常,以及几个系统异常就可以了,当然,这些异常完全用其英文名称来写是最好的,如果实在写不出,那就用中文吧,有总比没有强!
所谓系统异常,就是&..,它们都是RuntimeException的子类,在jdk doc中查RuntimeException类,就可以看到其所有的子类列表,也就是看到了所有的系统异常。我比较有印象的系统异常有:NullPointerException、ArrayIndexOutOfBoundsException、ClassCastException。
5.JAVA语言如何进行异常处理,关键字:throws,throw,try,catch,finally分别代表什么意义?在try块中可以抛出异常吗?
Java 通过面向对象的方法进行异常处理,把各种不同的异常进行分类,并提供了良好的接口。在 Java 中,每个异常都是一个对象,它是 Throwable 类或其它子类的实例。当一个方法出现异常后便抛出一个异常对象,该对象中包含有异常信息,调用这个对象的方法可以捕获到这个异常并进行处理。Java 的异常处理是通过 5 个关键词来实现的:try、catch、throw、throws 和 finally。一
般情况下是用 try 来执行一段程序,如果出现异常,系统会抛出(throws)一个异常,这时候你可以通过它的类型来捕捉(catch)它,或最后(finally)由缺省处理器来处理;
&try 用来指定一块预防所有&异常&的程序;
&catch 子句紧跟在 try 块后面,用来指定你想要捕捉的&异常&的类型;
&throw 语句用来明确地抛出一个&异常&;
&throws 用来标明一个成员函数可能抛出的各种&异常&;
&Finally 为确保一段代码不管发生什么&异常&都被执行一段代码;
&可以在一个成员函数调用的外面写一个 try 语句,&&& 在这个成员函数内部写另一个 try 语句保护其他代码。每当遇到一个 try 语句,&异常&的框架就放到堆栈上面,直到所有的 try 语句都完成。如果下一级的 try 语句没有对某种&异常&进行处理,堆栈就会展开,直到遇到有处理这种&异常&的 try 语句。
6.运行时异常与一般异常有何异同?
异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。
7..下面的程序代码输出的结果是多少?
public class& smallT{
&&&&&&&& public static void& main(String args[]){
&&&&&&&&&&&&&&&&&& smallT t& = new&smallT();
&&&&&&&&&&&&&&&&&& int& b&=& t.get();
&&&&&&&&&&&&&&&&&& System.out.println(b);
&&&&&&&& }
&&&&&&&& public int& get()
&&&&&&&& {
&&&&&&&&&&&&&&&&&& try&&&& {return 1;}
&&&&&&&&&&&&&&&&&& finally{return 2;}
&&&&&&&& }}
返回的结果是2。
我可以通过下面一个例子程序来帮助我解释这个答案,从下面例子的运行结果中可以发现,try中的return语句调用的函数先于finally中调用的函数执行,也就是说return语句先执行,finally语句后执行,所以,返回的结果是2。Return并不是让函数马上返回,而是return语句执行后,将把返回结果放置进函数栈中,此时函数并不是马上返回,它要执行finally语句后才真正开始返回。
在讲解答案时可以用下面的程序来帮助分析:
public& class&Test {
&&&&public static void&main(String[]args) {
&&&&&&& System.out.println(new&Test().test());;
&&&&int&test()
&&&&&&& try&&&&&&&& {return func1();}
&&&&&&& finally&&& {return func2();}
&&&&int&func1()
&&&&&&& System.out.println("func1");
&&&&&&&&return&1;
&&&&int&func2()
&&&&&&& System.out.println("func2");
&&&&&&&&return&2;
-----------执行结果-----------------
结论:finally中的代码比return 和break语句后执行
阅读(...) 评论()Java面试集锦:面试官只问一个问题,30几人集体懵圈
有的时候面试官的问题真的层出不穷,今天就又遇到了一个奇葩的问题(你是面试官你说了算)。面试时候,直接给拿出了一个特别“复杂”的异常(虽然代码并不多),但是全部去面试的人直接就蒙圈了。事后我赶紧恶补了一下Java异常方面的所有资料,整理一番,分享给大家,希望大家能够引以为戒。别再犯错。介绍知识点之前,我要先说明一点,大家遇到异常一定要自己动手解决Java的各种异常。一个合格的Java程序员,必须要对Java项目开发中各种常见的问题和各种异常有自己的见解。而且关于Java各种异常的全部说明,在api里都可以查的到。新手遇到这些异常的时候一定要自己动手处理异常,并且快速地记住这些异常的特点和解决方案。如果大家只是一直死写程序,遇到异常也不看重的话,对你未来的发展也不太好。异常类基本就那两种类型:(各位Java爱好者有空可以来我的Java学习群,每天都有企业项目视频+素材源码分享,小白也可以来,群里有完整成熟的Java学习体系供大家参考学习)ErrorExceptionJava异常类结构图如果说Error类代表了系统和编译的错误;那Exception类就代表了标准Java库方法所激发的异常。Error类的异常是不允许捕获的,而发生Exception异常的程序可以通过捕获处理后正常运行保持程序的可读性及可靠性。这其中Exception类还包含运行异常类(Runtime_Exception)和非运行异常类(Non_RuntimeException)这两个直接的子类。运行异常类对应于编译错误,它是指Java程序在运行时产生的由解释器引发的各种异常。运行异常可能出现在任何地方,且出现频率很高,出现运行错误往往表示代码有错误,如:算数异常(如被0除)、下标异常(如数组越界)等。非运行异常又称为可检测异常。Java编译器利用分析方法或构造方法中可能产生的结果来检测Java程序中是否含有检测异常的处理程序,对于每个可能的可检测异常,方法或构造方法的throws子句必须列出该异常对应的类。如:java.lang java.util 、 java.net中定义的异常都是非运行异常。我整理了一下,常见的Java Exception异常java.lang.ArithmeticException:算术条件异常。譬如:整数除零等。java.lang.ArrayIndexOutOfBoundsException:数组索引越界异常。当对数组的索引值为负数或大于等于数组大小时抛出。java.lang.ArrayStoreException:数组存储异常。当向数组中存放非数组声明类型对象时抛出。java.lang.ClassCastException:类造型异常。假设有类A和B(A不是B的父类或子类),O是A的实例,那么当强制将O构造为类B的实例时抛出该异常。该异常经常被称为强制类型转换异常。java.lang.ClassNotFoundException:找不到类异常。当应用试图根据字符串形式的类名构造类,而在遍历CLASSPAH之后找不到对应名称的class文件时,抛出该异常。java.lang.CloneNotSupportedException:不支持克隆异常。当没有实现Cloneable接口或者不支持克隆方法时,调用其clone方法则抛出该异常。java.lang.EnumConstantNotPresentException:枚举常量不存在异常。当应用试图通过名称和枚举类型访问一个枚举对象,但该枚举对象并不包含常量时,抛出该异常。java.lang.Exception:根异常。用以描述应用程序希望捕获的情况。java.lang.IllegalAccessException:违法的访问异常。当应用试图通过反射方式创建某个类的实例、访问该类属性、调用该类方法,而当时又无法访问类的、属性的、方法的或构造方法的定义时抛出该异常。java.lang.IllegalMonitorStateException:违法的监控状态异常。当某个线程试图等待一个自己并不拥有的对象(O)的监控器或者通知其他线程等待该对象(O)的监控器时,抛出该异常。java.lang.IllegalStateException:违法的状态异常。当在Java环境和应用尚未处于某个方法的合法调用状态,而调用了该方法时,抛出该异常。java.lang.IllegalThreadStateException:违法的线程状态异常。当县城尚未处于某个方法的合法调用状态,而调用了该方法时,抛出异常。java.lang.IndexOutOfBoundsException:索引越界异常。当访问某个序列的索引值小于0或大于等于序列大小时,抛出该异常。java.lang.InstantiationException:实例化异常。当试图通过newInstance方法创建某个类的实例,而该类是一个抽象类或接口时,抛出该异常。java.lang.InterruptedException:被中止异常。当某个线程处于长时间的等待、休眠或其他暂停状态,而此时其他的线程通过Thread的interrupt方法终止该线程时抛出该异常。java.lang.NegativeArraySizeException:数组大小为负值异常。当使用负数大小值创建数组时抛出该异常。java.lang.NoSuchFieldException:属性不存在异常。当访问某个类的不存在的属性时抛出该异常。java.lang.NoSuchMethodException:方法不存在异常。当访问某个类的不存在的方法时抛出该异常。java.lang.NullPointerException:空指针异常。当应用试图在要求使用对象的地方使用了null时,抛出该异常。譬如:调用null对象的实例方法、访问null对象的属性、计算null对象的长度、使用throw语句抛出null等等。java.lang.NumberFormatException:数字格式异常。当试图将一个String转换为指定的数字类型,而该字符串确不满足数字类型要求的格式时,抛出该异常。java.lang.RuntimeException:运行时异常。是所有Java虚拟机正常操作期间可以被抛出的异常的父类。java.lang.SecurityException:安全异常。由安全管理器抛出,用于指示违反安全情况的异常。java.lang.StringIndexOutOfBoundsException:字符串索引越界异常。当使用索引值访问某个字符串中的字符,而该索引值小于0或大于等于序列大小时,抛出该异常。java.lang.TypeNotPresentException:类型不存在异常。当应用试图以某个类型名称的字符串表达方式访问该类型,但是根据给定的名称又找不到该类型是抛出该异常。该异常与ClassNotFoundException的区别在于该异常是unchecked(不被检查)异常,而ClassNotFoundException是checked(被检查)异常。java.lang.UnsupportedOperationException:不支持的方法异常。指明请求的方法不被支持情况的异常。常见的Error类异常(各位Java爱好者有空可以来我的Java学习群,每天都有企业项目视频+素材源码分享,小白也可以来,群里有完整成熟的Java学习体系供大家参考学习)java.lang.AbstractMethodError:抽象方法错误。当应用试图调用抽象方法时抛出。java.lang.AssertionError:断言错。用来指示一个断言失败的情况。java.lang.ClassCircularityError:类循环依赖错误。在初始化一个类时,若检测到类之间循环依赖则抛出该异常。java.lang.ClassFormatError:类格式错误。当Java虚拟机试图从一个文件中读取Java类,而检测到该文件的内容不符合类的有效格式时抛出。java.lang.Error:错误。是所有错误的基类,用于标识严重的程序运行问题。这些问题通常描述一些不应被应用程序捕获的反常情况。java.lang.ExceptionInInitializerError:初始化程序错误。当执行一个类的静态初始化程序的过程中,发生了异常时抛出。静态初始化程序是指直接包含于类中的static语句段。java.lang.IllegalAccessError:违法访问错误。当一个应用试图访问、修改某个类的域(Field)或者调用其方法,但是又违反域或方法的可见性声明,则抛出该异常。java.lang.IncompatibleClassChangeError:不兼容的类变化错误。当正在执行的方法所依赖的类定义发生了不兼容的改变时,抛出该异常。一般在修改了应用中的某些类的声明定义而没有对整个应用重新编译而直接运行的情况下,容易引发该错误。java.lang.InstantiationError:实例化错误。当一个应用试图通过Java的new操作符构造一个抽象类或者接口时抛出该异常.java.lang.InternalError:内部错误。用于指示Java虚拟机发生了内部错误。java.lang.LinkageError:链接错误。该错误及其所有子类指示某个类依赖于另外一些类,在该类编译之后,被依赖的类改变了其类定义而没有重新编译所有的类,进而引发错误的情况。java.lang.NoClassDefFoundError:未找到类定义错误。当Java虚拟机或者类装载器试图实例化某个类,而找不到该类的定义时抛出该错误。java.lang.NoSuchFieldError:域不存在错误。当应用试图访问或者修改某类的某个域,而该类的定义中没有该域的定义时抛出该错误。java.lang.NoSuchMethodError:方法不存在错误。当应用试图调用某类的某个方法,而该类的定义中没有该方法的定义时抛出该错误。java.lang.OutOfMemoryError:内存不足错误。当可用内存不足以让Java虚拟机分配给一个对象时抛出该错误。java.lang.StackOverflowError:堆栈溢出错误。当一个应用递归调用的层次太深而导致堆栈溢出时抛出该错误。java.lang.ThreadDeath:线程结束。当调用Thread类的stop方法时抛出该错误,用于指示线程结束。java.lang.UnknownError:未知错误。用于指示Java虚拟机发生了未知严重错误的情况。java.lang.UnsatisfiedLinkError:未满足的链接错误。当Java虚拟机未找到某个类的声明为native方法的本机语言定义时抛出。java.lang.UnsupportedClassVersionError:不支持的类版本错误。当Java虚拟机试图从读取某个类文件,但是发现该文件的主、次版本号不被当前Java虚拟机支持的时候,抛出该错误。java.lang.VerifyError:验证错误。当验证器检测到某个类文件中存在内部不兼容或者安全问题时抛出该错误。java.lang.VirtualMachineError:虚拟机错误。用于指示虚拟机被破坏或者继续执行操作所需的资源不足的情况。最后面是几种不经常出现但是偶尔而会出现的Java异常javax.servlet.jsp.JspException: Cannot retrieve mapping for action /Login :这个异常中就是系统没有找到匹配的action也就是action没有在struts-config.xml中定义。也可能是打错了字符或者是某些不符合规则,可以使用strutsconsole工具来检查。org.apache.jasper.JasperException: Cannot retrieve definition for form bean null:这个异常是因为Struts根据struts-config.xml中的mapping没有找到action期望的form bean。action和form都应该各自有一个name属性,并且要精确匹配(包括大小写)(Java学习群)javax.servlet.jsp.JspException: No getter method for property username of bean org.apache.struts.taglib.html.BEAN:这个异常是没有位form bean中的某个变量定义getter方法,这个错误主要发生在表单提交的FormBean中,用struts标记&html:text property=”username”&时,在FormBean中必须有一个getUsername方法。注意字母“U”。(大写)java.lang.NoClassDefFoundError: org/apache/struts/action/ActionForm:这个异常是因为classpath中找不到相应的Java .class文件。如果这个错误发生在web应用程序的运行时,主要是因为指定的class文件不在web server的classpath中(/WEB-INF/classes和 /WEB-INF/lib)。在上面的错误中,原因是应该找不到ActionForm类。javax.servlet.jsp.JspException: Cannot find ActionMappings or ActionFormBeans collection:不是标识Struts actionServlet的&servlet&标记就是映射.do扩展名的&sevlet-mapping&标记或者两者都没有在web.xml中声明。在struts-config.xml中的打字或者拼写错误也可导致这个异常的发生。例如缺少一个标记的关闭符号/&。最好使用struts console工具检查一下。另外,load-on-startup必须在web.xml中声明,这要么是一个空标记,要么指定一个数值,这个数值用来表servlet运行的优先级,数值越大优先级越低。还有一个和使用load-on-startup有关的是使用Struts预编译JSP文件时也可能导致这个异常。java.lang.NullPointerException atorg.apache.struts.util.RequestUtils.forwardURL(RequestUtils.java:1223):这个异常就是在struts-config.xml中的forward元素缺少path属性。例如应该是如下形式:&forward name="userhome" path="/user/userhome.jsp"/&javax.servlet.jsp.JspException: Cannot find bean org.apache.struts.taglib.html.BEAN in any scopeProbable Causes:试图在Struts的form标记外使用form的子元素。这常常发生在你在&/html:form&后面使用Struts的html标记。另外要注意可能你不经意使用的无主体的标记javax.servlet.jsp.JspException: Missing message for key xx.xx.xxProbable Causes这个key的值对没有在资源文件ApplicationResources.properties中定义。资源文件ApplicationResources.properties到 WEB-INF/classes目录下就可以了Cannot find message resources under key org.apache.struts.action.MESSAGE:很显然,这个错误是发生在使用资源文件时,而Struts没有找到资源文件。Strange and seemingly random characters in HTML and on screen, but not in original JSP or servlet.:混和使用Struts的html:form标记和标准的HTML标记不正确。使用的编码样式在本页中不支持。"Document contained no data" in Netscape No data rendered (completely empty) page in Microsoft Internet Explorer:使用一个Action的派生类而没有实现perform方法或execute方法。ServletException: BeanUtils.populate:在用Struts上传文件时,遇到了javax.servlet.ServletException: BeanUtils.populate异常。我的ActionServlet并没有用到BeanUtils这些工具类。后来仔细检查代码发现是在jsp文件里的form忘了加enctype="multipart/form-data"了。所以写程序遇到错误或异常应该从多方面考虑问题存在的可能性,想到系统提示信息以外的东西。1.定义Action后,如果指定了name,那么必须要定义一个与它同名的FormBean才能进行form映射.2.如果定义Action后,提交页面时出现 "No input attribute for mapping path..."错误,则需要在其input属性中定义转向的页面.3.如果插入新的数据时出现 "Batch update row count wrong:..."错误,则说明XXX.hbm.xml中指定的key的类型为原始类型(int, long),因为这种类型会自动分配值,而这个值往往会让系统认为已经存在该记录,正确的方法是使用java.lang.Integer或java.lang.Long对象.4.如果插入数据时出现 "argument type mismatch"错误,可能是你使用了Date等特殊对象,因为struts不能自动从String型转换成Date型,所以,你需要在Action中手动把String型转换成Date型.5. Hibernate中, Query的iterator比list方法快很多.6.如果出现 "equal symbol expected"错误,说明你的strtus标签中包含另一个标签或者变量,例如:&html:select property="test" mock="&%=test%&"/&或者&html:hidden property="test" value="&bean:write name="t" property="p"/&"/&这样的情况...最后希望我整理的这些东西能给大家带来一点点帮助最后再给大家一个提醒:不要怕异常,困难只是我们成功路上的垫脚石,困难越多,我们就会爬的越高。谁在学习Java过程中都不会是一帆风顺的。
(来源:www.yidianzixun.com,如对本网转载内容、版权有异议,请联系我们: )
安卓网官方微信
微信号 Hiapk2013
这里有最无节操的小编和最鲜辣的资讯!
手机扫描二维码访问

我要回帖

更多关于 java面试笔试题 的文章

 

随机推荐