処理のためにいくつかのトランザクションを実行する小さなコードがあります。各トランザクションにはトランザクション番号が付けられています。トランザクション番号は外部プログラムによって生成され、必ずしも順序付けられているとは限りません。処理コードで例外をキャッチすると、それをメインクラスにスローし、後で確認するためにログに記録します。このスローされた例外にトランザクション番号を追加したいと思います。正しいスタックトレースを維持しながらこれを行うことは可能ですか?
例えば:
public static void main(String[] args) {
try{
processMessage();
}catch(Exception E){
E.printStackTrace();
}
}
private static void processMessage() throws Exception{
String transNbr = "";
try{
transNbr = "2345";
throw new Exception();
}catch(Exception E){
if(!transNbr.equals("")){
//stack trace originates from here, not from actual exception
throw new Exception("transction: " + transNbr);
}else{
//stack trace gets passed correctly but no custom message available
throw E;
}
}
}