4

UncaughtExceptionHandlerコード内のキャッチされていない例外をキャッチしてログに記録し、それらを報告する Swing アプリをセットアップしました。これらのエラーのほとんどのスタック トレースは、問題の診断に役立ちます。ただし、次のような問題が発生することがあります。

Thread : AWT-EventQueue-2
   Thread[AWT-EventQueue-2,6,javawsApplicationThreadGroup]

Error Message:
java.lang.Double cannot be cast to java.lang.Integer

Error String:
java.lang.ClassCastException: java.lang.Double cannot be cast to java.lang.Integer

StackTrace: class java.lang.ClassCastException
   java.lang.Integer.compareTo(Unknown Source)
   javax.swing.table.TableRowSorter$ComparableComparator.compare(Unknown Source)
   javax.swing.DefaultRowSorter.compare(Unknown Source)
   javax.swing.DefaultRowSorter.access$100(Unknown Source)
   javax.swing.DefaultRowSorter$Row.compareTo(Unknown Source)
   javax.swing.DefaultRowSorter$Row.compareTo(Unknown Source)
   java.util.ComparableTimSort.binarySort(Unknown Source)
   java.util.ComparableTimSort.sort(Unknown Source)
   java.util.Arrays.sort(Unknown Source)
   javax.swing.DefaultRowSorter.sortExistingData(Unknown Source)
   javax.swing.DefaultRowSorter.setSortKeys(Unknown Source)
   javax.swing.DefaultRowSorter.toggleSortOrder(Unknown Source)
   javax.swing.plaf.basic.BasicTableHeaderUI$MouseInputHandler.mouseClicked(Unknown Source)
   java.awt.AWTEventMulticaster.mouseClicked(Unknown Source)
   java.awt.Component.processMouseEvent(Unknown Source)
   javax.swing.JComponent.processMouseEvent(Unknown Source)
   java.awt.Component.processEvent(Unknown Source)
   java.awt.Container.processEvent(Unknown Source)
   java.awt.Component.dispatchEventImpl(Unknown Source)
   java.awt.Container.dispatchEventImpl(Unknown Source)
   java.awt.Component.dispatchEvent(Unknown Source)
   java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source)
   java.awt.LightweightDispatcher.processMouseEvent(Unknown Source)
   java.awt.LightweightDispatcher.dispatchEvent(Unknown Source)
   java.awt.Container.dispatchEventImpl(Unknown Source)
   java.awt.Window.dispatchEventImpl(Unknown Source)
   java.awt.Component.dispatchEvent(Unknown Source)
   java.awt.EventQueue.dispatchEventImpl(Unknown Source)
   java.awt.EventQueue.access$500(Unknown Source)
   java.awt.EventQueue$3.run(Unknown Source)
   java.awt.EventQueue$3.run(Unknown Source)
   java.security.AccessController.doPrivileged(Native Method)
   java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)
   java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)
   java.awt.EventQueue$4.run(Unknown Source)
   java.awt.EventQueue$4.run(Unknown Source)
   java.security.AccessController.doPrivileged(Native Method)
   java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source)
   java.awt.EventQueue.dispatchEvent(Unknown Source)
   java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
   java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
   java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
   java.awt.EventDispatchThread.pumpEvents(Unknown Source)
   java.awt.EventDispatchThread.pumpEvents(Unknown Source)
   java.awt.EventDispatchThread.run(Unknown Source)

この特定の問題を診断するのに助けは必要ありません。問題は明らかです (ユーザーはJTableアプリケーションのどこかで a をソートしようとしていますが、その列の値はDoubles ですが、テーブル宣言はIntegers を期待すると言われています)。ただし、このスタック トレースでJTableは、問題の原因がわかりません (アプリにはたくさんのテーブルがあります)。問題がどこから来ているのかわからないので、それを修正する方法はありません。

では、この問題や同様の問題の原因を見つけるのに役立つデバッグ情報が他にあるでしょうか?

注: スタック トレースにリストされているクラスはどれも私のクラスではなく、すべてライブラリ クラスであるため、すべての行に「不明なソース」と表示されているという事実だけではありません。したがって、問題に行番号が付けられたとしても、それは私が修正できないクラスになります。

4

1 に答える 1

1

このような場合、デバッグ情報を追加するためだけに何かをオーバーライドします。たとえば、この場合、スタック トレースで DefaultRowSorter.setSortKeys が呼び出されたことがわかるので、クラスを使用できます。

public class MyRowSorter<M, I> extends DefaultRowSorter<M, I> {
    ....

    @Override
    public void setSortKeys(List<? extends SortKey> sortKeys) {
        try {
            super.setSortKeys(sortKeys);
        } catch (Exception e) {
            //   
            // print debugging info here!
            //
            throw e;
        }
    }
}

これで、テーブルを並べ替えるように MyRowSorter を設定し、必要なデバッグ情報を MyRowSorter に追加して、どのテーブルに問題があったかをデバッグできます。

于 2015-07-21T02:17:14.050 に答える