java自定义异常信息日志输出(java 输出日志文件)

本文目录一览:

Java用户自定义异常处理

一、第一种定义方式,继承Exception类

public class MyFirstException extends Exception {

public MyFirstException() {

super();

}

public MyFirstException(String msg) {

super(msg);

}

public MyFirstException(String msg, Throwable cause) {

super(msg, cause);

}

public MyFirstException(Throwable cause) {

super(cause);

}

//自定义异常类的主要作用是区分异常发生的位置,当用户遇到异常时,

//根据异常名就可以知道哪里有异常,根据异常提示信息进行修改。

}

二、 第二种定义方式:继承Throwable 类

public class MySecondException extends Throwable {

public MySecondException() {

super();

}

public MySecondException(String msg) {

super(msg);

}

public MySecondException(String msg, Throwable cause) {

super(msg, cause);

}

public MySecondException(Throwable cause) {

super(cause);

}

}

三、测试

/**

* 自定义异常类的使用

* @author new

*

*/

public class TestMyException {

public static void firstException() throws MyFirstException{

throw new MyFirstException(“\”firstException()\” method occurs an exception!”);

}

public static void secondException() throws MySecondException{

throw new MySecondException(“\”secondException()\” method occurs an exception!”);

}

public static void main(String[] args) {

try {

TestMyException.firstException();

TestMyException.secondException();

} catch (MyFirstException e1){

System.out.println(“Exception: ” + e1.getMessage());

e1.printStackTrace();

} catch (MySecondException e2){

System.out.println(“Exception: ” + e2.getMessage());

e2.printStackTrace();

}

//当一个try块后面跟着多个catch块时,如果发生的异常匹配第一个catch块的参数,便将异常处理权利交给第一个catch块。

//如果发生的异常与第一个catch块不匹配,便看是否与第二个catch块匹配,依次下去,如果到最后依然无法匹配该异常,

//便需要在方法声明中添加一条throw语句,将该异常抛出。

//因此,在有多个catch块,而且每次处理的异常类型具有继承关系时,应该首先catch子类异常,再catch父类异常。

//比如,如果MySecondException继承MyFirstException,那么最好将catch (MySecondException e2)放在前面,

//把catch (MyFirstException e1)放在后面。

}

tomcat7怎么输出java异常日志

1.找到tomcat安装目录下的bin目录。

2.修改bin目录下面的catalina.bat文件,对照这个文件,将最后一部分修改成下面这样。

rem Execute Java with the applicable properties

if not “%JPDA%” == “” goto doJpda

if not “%SECURITY_POLICY_FILE%” == “” goto doSecurity

%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs=”%JAVA_ENDORSED_DIRS%” -classpath “%CLASSPATH%” -Dcatalina.base=”%CATALINA_BASE%” -Dcatalina.home=”%CATALINA_HOME%” -Djava.io.tmpdir=”%CATALINA_TMPDIR%” %MAINCLASS% %CMD_LINE_ARGS% %ACTION% %CATALINA_BASE%\logs\catalina.out

goto end

:doSecurity

%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs=”%JAVA_ENDORSED_DIRS%” -classpath “%CLASSPATH%” -Djava.security.manager -Djava.security.policy==”%SECURITY_POLICY_FILE%” -Dcatalina.base=”%CATALINA_BASE%” -Dcatalina.home=”%CATALINA_HOME%” -Djava.io.tmpdir=”%CATALINA_TMPDIR%” %MAINCLASS% %CMD_LINE_ARGS% %ACTION% %CATALINA_BASE%\logs\catalina.out

goto end

:doJpda

if not “%SECURITY_POLICY_FILE%” == “” goto doSecurityJpda

%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %JPDA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs=”%JAVA_ENDORSED_DIRS%” -classpath “%CLASSPATH%” -Dcatalina.base=”%CATALINA_BASE%” -Dcatalina.home=”%CATALINA_HOME%” -Djava.io.tmpdir=”%CATALINA_TMPDIR%” %MAINCLASS% %CMD_LINE_ARGS% %ACTION% %CATALINA_BASE%\logs\catalina.out

goto end

:doSecurityJpda

%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %JPDA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs=”%JAVA_ENDORSED_DIRS%” -classpath “%CLASSPATH%” -Djava.security.manager -Djava.security.policy==”%SECURITY_POLICY_FILE%” -Dcatalina.base=”%CATALINA_BASE%” -Dcatalina.home=”%CATALINA_HOME%” -Djava.io.tmpdir=”%CATALINA_TMPDIR%” %MAINCLASS% %CMD_LINE_ARGS% %ACTION% %CATALINA_BASE%\logs\catalina.out

goto end

:end

3.将startup.bat中倒数第二行 call “%EXECUTABLE%” start %CMD_LINE_ARGS%?? 改为? call “%EXECUTABLE%” run %CMD_LINE_ARGS%

注:以上加粗的是指定输出路径。路径前面的“ ”代表的是输出是对当前文件的内容进行覆盖,也就是如果自己指定的catalina.out文件中有内容,将会被覆盖。如果使用“ ”, 则不会覆盖,而是在catalina.out文件尾部追加信息。

java 我想把一个服务里面的所有异常信息全部记录在logger里怎么配置

用log4j

配置文件:

?xml version=”1.0″ encoding=”UTF-8″?

!DOCTYPE log4j:configuration PUBLIC “-//log4j/log4j Configuration//EN” “log4j.dtd”

 

log4j:configuration xmlns:log4j=””

 

    appender name=”RollingAppender” class=”org.apache.log4j.DailyRollingFileAppender”

       param name=”File” value=”logs/app.log” /

       param name=”Encoding” value=”UTF-8″ /

       param name=”DatePattern” value=”‘.’yyyy-MM-dd” /

       layout class=”org.apache.log4j.PatternLayout”

          param name=”ConversionPattern” value=”[%p] %d %c %M – %m%n”/          

       /layout

    /appender

 

    root

        priority value=”DEBUG”/

        appender-ref ref=”RollingAppender” /

    /root

     

/log4j:configuration

运用

先实例化

运用

java自定义异常处理类

[java] view plain copy print?

/*下面做了归纳总结,欢迎批评指正*/

/*自定义异常*/

class ChushulingException extends Exception

{

public ChushulingException(String msg)

{

super(msg);

}

}

class ChushufuException extends Exception

{

public ChushufuException(String msg)

{

super(msg);

}

}

/*自定义异常 End*/

class Numbertest

{

public int shang(int x,int y) throws ChushulingException,ChushufuException

{

if(y0)

{

throw new ChushufuException(“您输入的是”+y+”,规定除数不能为负数!”);//抛出异常

}

if(y==0)

{

throw new ChushulingException(“您输入的是”+y+”,除数不能为0!”);

}

int m=x/y;

return m;

}

}

class Rt001

{

public static void main(String[]args)

{

Numbertest n=new Numbertest();

//捕获异常

try

{

System.out.println(“商=”+n.shang(1,-3));

}

catch(ChushulingException yc)

{

System.out.println(yc.getMessage());

yc.printStackTrace();

}

catch(ChushufuException yx)

{

System.out.println(yx.getMessage());

yx.printStackTrace();

}

catch(Exception y)

{

System.out.println(y.getMessage());

y.printStackTrace();

}

finally{ System.out.println(“finally!”);} ////finally不管发没发生异常都会被执行

}

}

/*

[总结]

1.自定义异常:

class 异常类名 extends Exception

{

public 异常类名(String msg)

{

super(msg);

}

}

2.标识可能抛出的异常:

throws 异常类名1,异常类名2

3.捕获异常:

try{}

catch(异常类名 y){}

catch(异常类名 y){}

4.方法解释

getMessage() //输出异常的信息

printStackTrace() //输出导致异常更为详细的信息

*/

为什么我在java中自定义的异常,运行时什么也没有输出??我打算想输出那个throw new MyException中的a的

e.printStackTrace();只会输出异常的调用栈信息,要输出a你要用System.out.println(e.getMessage());

java输出为:这是我自定义的异常类 MyException: 这是我自定义的异常类。我并没有输出MyException啊,

Exception的toString方法描述如下:

public String toString()

返回此 throwable 的简短描述。结果是以下字符串的串联:

此对象的类的 name + “: “(冒号和一个空格)+ 调用此对象 getLocalizedMessage()

方法的结果

如果 getLocalizedMessage 返回 null,则只返回类名称,此处 getLocalizedMessage返回时你定义的字符串,不为空。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/243674.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-12 12:57
下一篇 2024-12-12 12:57

相关推荐

  • vue下载无后缀名的文件被加上后缀.txt,有后缀名的文件下载正常问题的解决

    本文旨在解决vue下载无后缀名的文件被加上后缀.txt,有后缀名的文件下载正常的问题,提供完整的代码示例供参考。 一、分析问题 首先,需了解vue中下载文件的情况。一般情况下,我们…

    编程 2025-04-29
  • 如何在Java中拼接OBJ格式的文件并生成完整的图像

    OBJ格式是一种用于表示3D对象的标准格式,通常由一组顶点、面和纹理映射坐标组成。在本文中,我们将讨论如何将多个OBJ文件拼接在一起,生成一个完整的3D模型。 一、读取OBJ文件 …

    编程 2025-04-29
  • Python程序文件的拓展

    Python是一门功能丰富、易于学习、可读性高的编程语言。Python程序文件通常以.py为文件拓展名,被广泛应用于各种领域,包括Web开发、机器学习、科学计算等。为了更好地发挥P…

    编程 2025-04-29
  • 为什么用cmd运行Java时需要在文件内打开cmd为中心

    在Java开发中,我们经常会使用cmd在命令行窗口运行程序。然而,有时候我们会发现,在运行Java程序时,需要在文件内打开cmd为中心,这让很多开发者感到疑惑,那么,为什么会出现这…

    编程 2025-04-29
  • Python中读入csv文件数据的方法用法介绍

    csv是一种常见的数据格式,通常用于存储小型数据集。Python作为一种广泛流行的编程语言,内置了许多操作csv文件的库。本文将从多个方面详细介绍Python读入csv文件的方法。…

    编程 2025-04-29
  • Python将矩阵存为CSV文件

    CSV文件是一种通用的文件格式,在统计学和计算机科学中非常常见,一些数据分析工具如Microsoft Excel,Google Sheets等都支持读取CSV文件。Python内置…

    编程 2025-04-29
  • Python zipfile解压文件乱码处理

    本文主要介绍如何在Python中使用zipfile进行文件解压的处理,同时详细讨论在解压文件时可能出现的乱码问题的各种解决办法。 一、zipfile解压文件乱码问题的根本原因 在P…

    编程 2025-04-29
  • Python如何导入py文件

    Python是一种开源的高级编程语言,因其易学易用和强大的生态系统而备受青睐。Python的import语句可以帮助用户将一个模块中的代码导入到另一个模块中,从而实现代码的重用。本…

    编程 2025-04-29
  • Python合并多个相同表头文件

    对于需要合并多个相同表头文件的情况,我们可以使用Python来实现快速的合并。 一、读取CSV文件 使用Python中的csv库读取CSV文件。 import csv with o…

    编程 2025-04-29
  • Cron执行日志用法介绍

    本文将从多个方面对cron执行日志进行详细阐述,包括cron执行日志的定义、cron执行日志的产生原因、cron执行日志的格式以及如何解读cron执行日志。 一、定义 Cron是一…

    编程 2025-04-29

发表回复

登录后才能评论