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/zh-hk/n/243674.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 12:57
下一篇 2024-12-12 12:57

相關推薦

發表回復

登錄後才能評論