关于java难吗的一个问题

java学习中遇到的问题_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
java学习中遇到的问题
上传于|0|0|文档简介
&&java程序员必读基础word版本
阅读已结束,如果下载本文需要使用1下载券
想免费下载本文?
定制HR最喜欢的简历
你可能喜欢关于Java异常的处理的一个小问题 - ITeye问答
当double d1 = Double.parseDouble(args[0]);发生异常时,我想在catch里面得到发生异常的这句话......
就是通过使用传进来的 e 杂个能得到发生异常的"double d1 = Double.parseDouble(args[0]);"这句话,以及这句话发生的本JAVA文件名,JAVA文件中这句话的行号等呢?
public static void main(String[] args) {
if (3 != args.length){
System.out.println("Usage: TestArray1 " + "\"n1\""+" \"op\" " +"\"n2\"");
System.exit(-1);
double d1 = Double.parseDouble(args[0]);
&&&&&&&&& }catch (Exception e) {
//?????在这里杂个写呢?
采纳的答案
可以从e.getStackTrace();返回的字符串中解析出你要的信息(因为没有直接的接口):
public static void main(String[] args) throws UnsupportedEncodingException, ClassNotFoundException {
double d1 = Double.parseDouble("a");
} catch (Exception e) {
StackTraceElement[] trace = e.getStackTrace();
String firstException = trace[trace.length-1].toString();
String[] strList = firstException.split(".main");
String packageName = strList[0];
strList = strList[1].split(":");
String fileName = strList[0].substring(1);
String countNum = strList[1].substring(0, strList[1].length()-1);
System.out.println("packageName: " + packageName);
System.out.println("fileName: " + fileName);
System.out.println("countNum: " + countNum);
返回结果:
packageName: com.robert.base.TestClass
fileName: TestClass.java
countNum: 26
不过按照“effective java”说的,这是一种不好的获取信息的方式,最好不要采用。
catch (Exception e) {
e.printStackTrace();
public class ExceptionParser extends classStatus{
//String classPath = "/src/ExceptionParser.java";
public ExceptionParser() {
public static void main(String[] args) {
// TODO Auto-generated method stub
ExceptionParser test = new ExceptionParser();
double d1 = Double.parseDouble("a");
} catch (Exception e) {
// ?????在这里杂个写呢?
StackTraceElement[] st = e.getStackTrace();
StackTraceElement s = st[st.length-1];
System.out.println("异常发生的文件名为:" + s.getFileName());
System.out.println("异常发生的类名为:" + s.getClassName());
System.out.println("异常发生的方法名为:" + s.getMethodName());
System.out.println("异常发生的行号为:" + s.getLineNumber());
//System.getProperty("user.dir")+"/src/ExceptionParser.java"
//我的src是java的根目录,自己相应修改一下
System.out.println("异常发生的行:"+readF(s.getLineNumber(),System.getProperty("user.dir")+"/src/ExceptionParser.java"));
import java.io.BufferedR
import java.io.FileInputS
import java.io.FileNotFoundE
import java.io.IOE
import java.io.UnsupportedEncodingE
public class classStatus {
public static String readF(int errno,String childClassPath){
String line =
FileInputStream fin =
BufferedReader in =
int no = 1;//行数
fin = new FileInputStream(childClassPath);
in = new BufferedReader(new java.io.InputStreamReader(fin,"UTF-8"));
line = in.readLine();
while(line!=null){
line = in.readLine();
if(no==errno){
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally{
if(in!=null){
in.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
if(fin!=null){
fin.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
结果是
异常发生的类名为:ExceptionParser
异常发生的方法名为:main
异常发生的行号为:12
F:\companyWorkspace\paoding
异常发生的行:&&&&&&&&&&& double d1 = Double.parseDouble("a");
public class ExceptionParser {
* @param args
public static void main(String[] args) {
// TODO Auto-generated method stub
double d1 = Double.parseDouble(args[0]);
} catch (Exception e) {
// ?????在这里杂个写呢?
StackTraceElement[] st = e.getStackTrace();
StackTraceElement s = st[st.length-1];
System.out.println("异常发生的文件名为:" + s.getFileName() );
System.out.println("异常发生的类名为:" + s.getClassName() );
System.out.println("异常发生的方法名为:" + s.getMethodName() );
System.out.println("异常发生的行号为:" + s.getLineNumber() );
System.out.println(e.toString());
把异常堆栈打出来?里面信息就很全了。。。。
当前执行文件名可以这样
this.class.getName()
已解决问题
未解决问题一个JAVA SE有关问题 - J2SE当前位置:& &&&一个JAVA SE有关问题一个JAVA SE有关问题&&网友分享于:&&浏览:12次一个JAVA SE问题好久没搞SE了,今天偶然看到一个线程问题居然不解?哎在java程序中,有一个多线程类MyThread,包含一个方法run()和一个方法void disp()。以下描述正确的是(
) MyThreadmt=new MyThread (); mt.start();mt.disp();运行完线程体run方法后再运行disp()方法MyThreadmt=new MyThread ();mt.disp();mt.start();运行完disp()后才能启动线程体runMyThreadmt=new MyThread ();mt.start();mt.disp();线程体run一定会在disp结束前结束MyThreadmt=new MyThread ();mt.start();mt.disp();mt.start()和mt.disp()两条命令,哪条放在前面哪条放在后面运行结果一样。不要考虑run()方法有没有写while()吗?个人偏向第四个,但不知原因?求解------解决方案--------------------Bmt.disp(); mt如果不调用start,就跟一般类的实例一样,只是访问实例的方法,主线程会等待方法调用结束返回才继续执行后面的处理,所以mt.start在调用mt.disp以后才会被执行,线程也才开始被启动mt.start是启动线程,线程什么时候才可能被执行,有系统决定(CPU时间分配),所以mt.start在前,具有随机性,mt.start在后,主线程就是直接调用mt实例的方法,所以必须调用结束后才会执行后面的处理,所以结果是确定的,所以不存在两种结果一样
------解决方案--------------------MyThreadmt=new MyThread ();mt.start();mt.disp();mt.start()和mt.disp()两条命令,哪条放在前面哪条放在后面运行结果一样。因为是多线程类 所以即使 不调用disp()方法,disp()方法也会执行……
------解决方案--------------------探讨MyThreadmt=new MyThread ();mt.start();mt.disp();mt.start()和mt.disp()两条命令,哪条放在前面哪条放在后面运行结果一样。因为是多线程类 所以即使 不调用disp()方法,disp()方法也会执行……
12345678910
12345678910
12345678910 上一篇:下一篇:文章评论相关解决方案 12345678910 Copyright & &&版权所有java中常见的异常类 - with - 博客园
1. java.lang.nullpointerexception & 这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用了未经初始化的对象或者是不存在的对象,这个错误经常出现在创建图片,调用数组这些操作中,比如图片未经初始化,或者图片创建时的路径错误等等。对数组操作中出现空指针,很多情况下是一些刚开始学习编程的朋友常犯的错误,即把数组的初始化和数组元素的初始化混淆起来了。数组的初始化是对数组分配需要的空间,而初始化后的数组,其中的元素并没有实例化,依然是空的,所以还需要对每个元素都进行初始化(如果要调用的话)& 2. java.lang.classnotfoundexception & 这个异常是很多原本在jb等开发环境中开发的程序员,把jb下的程序包放在wtk下编译经常出现的问题,异常的解释是"指定的类不存在",这里主要考虑一下类的名称和路径是否正确即可,如果是在jb下做的程序包,一般都是默认加上package的,所以转到wtk下后要注意把package的路径加上。& 3. java.lang.arithmeticexception & 这个异常的解释是"数学运算异常",比如程序中出现了除以零这样的运算就会出这样的异常,对这种异常,大家就要好好检查一下自己程序中涉及到数学运算的地方,公式是不是有不妥了。& 4. java.lang.arrayindexoutofboundsexception & 这个异常相信很多朋友也经常遇到过,异常的解释是"数组下标越界",现在程序中大多都有对数组的操作,因此在调用数组的时候一定要认真检查,看自己调用的下标是不是超出了数组的范围,一般来说,显示(即直接用常数当下标)调用不太容易出这样的错,但隐式(即用变量表示下标)调用就经常出错了,还有一种情况,是程序中定义的数组的长度是通过某些特定方法决定的,不是事先声明的,这个时候,最好先查看一下数组的length,以免出现这个异常。& 5. java.lang.illegalargumentexception & 这个异常的解释是"方法的参数错误",很多j2me的类库中的方法在一些情况下都会引发这样的错误,比如音量调节方法中的音量参数如果写成负数就会出现这个异常,再比如g.setcolor(int red,int green,int blue)这个方法中的三个值,如果有超过255的也会出现这个异常,因此一旦发现这个异常,我们要做的,就是赶紧去检查一下方法调用中的参数传递是不是出现了错误。& 6. java.lang.illegalaccessexception & 这个异常的解释是"没有访问权限",当应用程序要调用一个类,但当前的方法即没有对该类的访问权限便会出现这个异常。对程序中用了package的情况下要注意这个异常。& 其他还有很多异常,我就不一一列举了,我要说明的是,一个合格的程序员,需要对程序中常见的问题有相当的了解和相应的解决办法,否则仅仅停留在写程序而不会改程序的话,会极大影响到自己的开发的。关于异常的全部说明,在api里都可以查阅。算术异常类:ArithmeticExecption空指针异常类:NullPointerException类型强制转换异常:ClassCastException数组负下标异常:NegativeArrayException数组下标越界异常:ArrayIndexOutOfBoundsException违背安全原则异常:SecturityException文件已结束异常:EOFException文件未找到异常:FileNotFoundException字符串转换为数字异常:NumberFormatException 操作数据库异常:SQLException 输入输出异常:IOException 方法未找到异常:NoSuchMethodExceptionjava.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.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类型不存在异常。关于Java反射机制的一个问题【java吧】_百度贴吧
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&签到排名:今日本吧第个签到,本吧因你更精彩,明天继续来努力!
本吧签到人数:0成为超级会员,使用一键签到本月漏签0次!成为超级会员,赠送8张补签卡连续签到:天&&累计签到:天超级会员单次开通12个月以上,赠送连续签到卡3张
关注:614,827贴子:
关于Java反射机制的一个问题收藏
1.这里先定义了一个包含多个构造方法的类:public class MoreConstructor {
int i,i2,i3;
private MoreConstructor(){
//不带参数的构造方法
protected MoreConstructor(String s,int i){//带两个可变参数的构造方法
public MoreConstructor(String... strings) throws NumberFormatException{
//带可变参数的构造方法
if(0&strings.length)
i=Integer.valueOf(strings[0]);
if(1&strings.length)
i2=Integer.valueOf(strings[1]);
if(2&strings.length)
i3=Integer.valueOf(strings[2]);
public void print(){
System.out.println(&s=&+s);
System.out.println(&i=&+i);
System.out.println(i2=+i2);
System.out.println(&i3=&+i3);
}}2.然后又定义了一个测试类,用来反射MoreConstructor类中的所有构造方法:import java.lang.reflect.Cpublic class AccessConstructor {
public static void main(String[] args){
Constructor[] declaredConstructors=MoreConstructor.class.getDeclaredConstructors();//创建数组获得所有构造方法
for(int i=0;i&declaredConstructors.i++){//遍历构造方法
Constructor constructor=declaredConstructors[i];//创建Constructor对象用来存放数组中的构造方法
System.out.println(&查看是否允许带有可变数量的参数:&+constructor.isVarArgs());
System.out.println(&该构造方法的入口参数类型依次为:&);
Class[] parameterTypes=constructor.getParameterTypes();//以Class数组的形式获得所有参数类型
for(int j=0;j&parameterTypes.j++){//遍历获得的参数类型
System.out.println(& &+parameterTypes[j]);
System.out.println(&该构造方法可能抛出的异常类型为:&);
Class[] exceptionTypes=constructor.getExceptionTypes();//以Class数组的形式获得该构造方法可能抛出的异常类型
for(int j=0;j&exceptionTypes.j++){//遍历获得的异常类型
System.out.println(& &+exceptionTypes[j]);
MoreConstructor example2=//创建MoreConstructor类的对象,定义为空
while(example2==null){
example2=(MoreConstructor)constructor.newInstance();//通过执行默认没有参数的构造方法创建对象
else if(i==1)
example2=(MoreConstructor)constructor.newInstance(&7&,5);//通过执行具有两个参数的构造方法创建对象
Object[] parameters=new Object[]{new String[]{&100&,&200&,&300&}};
example2=(MoreConstructor)constructor.newInstance(parameters);//通过执行具有可变参数的构造方法创建对象
}catch(Exception e){//如果该成员变量的访问权限为private,则抛出下面的异常,即不允许访问
System.out.println(&在创建对象时抛出异常,下面执行setAccessible()方法&);
constructor.setAccessible(true);//设置为允许访问
example2.print();
System.out.println();
}}3.运行的时候结果却一直抛出异常,如下,不知道为什么?,恳请高人解答。
南昌java教育机构选甲骨文培训,0基础,0学费入学,毕业包薪资,3个月入门到精通,先就业后付款,不用担心学费.
example2=(MoreConstructor)constructor.newInstance();//通过执行默认没有参数的构造方Object[] parameters=new Object[]{new String[]{&100&,&200&,&300&}};example2=(MoreConstructor)constructor.newInstance(parameters);//通过执行具有可变参数的构造方法创建对象位置交换一下试试
把i的三个值换一下就可以了
我修改过i的3个值的排序,但是还是不行,最后是一直显示下图,楼主找到解决的办法了吗?
登录百度帐号推荐应用
为兴趣而生,贴吧更懂你。或

我要回帖

更多关于 java难吗 的文章

 

随机推荐