本文目錄一覽:
- 1、Java用戶自定義異常處理
- 2、tomcat7怎麼輸出java異常日誌
- 3、java 我想把一個服務裡面的所有異常信息全部記錄在logger里怎麼配置
- 4、java自定義異常處理類
- 5、為什麼我在java中自定義的異常,運行時什麼也沒有輸出??我打算想輸出那個throw new MyException中的a的
- 6、java輸出為:這是我自定義的異常類 MyException: 這是我自定義的異常類。我並沒有輸出MyException啊,
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-hant/n/243674.html