0

Swingを使用して、データベースを使用するアプリケーションを構築しています。解決方法がわからないという奇妙な問題があります。

特定のパネルに、DBクエリを使用してレコードを入力するcomboBoxがあります。コンボボックスを保持するJPanelの構築が完了した後、ワーカーを実行しています

private void populateLists(){
    GetSimpleRecordsWorker worker = new GetSimpleRecordsWorker(Tables.characters,panelLeftDetails);
    worker.execute();
}

SELECTdoInBackgroundクエリを実行し、結果を取得した後(ワーカーのdone()メソッドで)、パネルのモデルを更新し、パネルのを呼び出しますrefreshFromModel

charI.setSimpleModel(simpleModel);
charI.refreshFromModel();

refreshFromModel次のことを行います:

private void refreshFromSimpleModel(){
    charSelectCombo.removeAllItems();
    Pair[] pairs = simpleModel.getRecords();
    for (int i=0; i<pairs.length; i++){
        charSelectCombo.addItem(pairs[i]);
    }
    charSelectCombo.setSelectedItem(null);
}

ここで問題となるのは、refreshFromModelが終了した後、GUIがスタック/フリーズすることです。なぜ私にはアイデアがありません!奇妙なことは、別のフレームで、私は同じ方法論を使用しています-そしてそれは問題なく動作します

また、removeAll代わりに試してみるremoveAllItemsと機能しますが、ComboBoxは矢印を失い、奇妙な動作をします。

デバッガーでフレームトレースを取得しました。removeSourceEventやUnsafe.parkなどがあります。

 GUI.GuiHandler at localhost:53547 (Suspended)  
Daemon System Thread [Attach Listener] (Suspended)  
Daemon System Thread [Signal Dispatcher] (Suspended)    
Daemon System Thread [Finalizer] (Suspended)    
    Object.wait(long) line: not available [native method]   
    ReferenceQueue<T>.remove(long) line: not available  
    ReferenceQueue<T>.remove() line: not available  
    Finalizer$FinalizerThread.run() line: not available 
Daemon System Thread [Reference Handler] (Suspended)    
    Object.wait(long) line: not available [native method]   
    Reference$Lock(Object).wait() line: 485 
    Reference$ReferenceHandler.run() line: not available    
Thread [AWT-Shutdown] (Suspended)   
    Object.wait(long) line: not available [native method]   
    Object.wait() line: 485 
    AWTAutoShutdown.run() line: not available   
    Thread.run() line: not available    
Daemon System Thread [Java2D Disposer] (Suspended)  
    Object.wait(long) line: not available [native method]   
    ReferenceQueue<T>.remove(long) line: not available  
    ReferenceQueue<T>.remove() line: not available  
    Disposer.run() line: not available  
    Thread.run() line: not available    
Daemon Thread [AWT-Windows] (Suspended) 
    WToolkit.eventLoop() line: not available [native method]    
    WToolkit.run() line: not available  
    Thread.run() line: not available    
Thread [AWT-EventQueue-0] (Suspended)   
    EventQueue.removeSourceEvents(Object, boolean) line: not available  
    WindowsComboBoxUI$WindowsComboBoxRenderer(Component).removeNotify() line: not available 
    WindowsComboBoxUI$WindowsComboBoxRenderer(Container).removeNotify() line: not available 
    WindowsComboBoxUI$WindowsComboBoxRenderer(JComponent).removeNotify() line: not available    
    CellRendererPane(Container).remove(int) line: not available 
    CellRendererPane(Container).remove(Component) line: not available   
    WindowsComboBoxUI(BasicComboBoxUI).getSizeForComponent(Component) line: not available   
    WindowsComboBoxUI(BasicComboBoxUI).getDisplaySize() line: not available 
    WindowsComboBoxUI(BasicComboBoxUI).getMinimumSize(JComponent) line: not available   
    AutoCompleteComboBox(JComponent).getMinimumSize() line: not available   
    FlowLayout.minimumLayoutSize(Container) line: not available 
    JPanel(Container).minimumSize() line: not available 
    JPanel(Container).getMinimumSize() line: not available  
    JPanel(JComponent).getMinimumSize() line: not available 
    BoxLayout.checkRequests() line: not available   
    BoxLayout.minimumLayoutSize(Container) line: not available  
    JPanel(Container).minimumSize() line: not available 
    JPanel(Container).getMinimumSize() line: not available  
    JPanel(JComponent).getMinimumSize() line: not available 
    BoxLayout.checkRequests() line: not available   
    BoxLayout.preferredLayoutSize(Container) line: not available    
    JPanel(Container).preferredSize() line: not available   
    JPanel(Container).getPreferredSize() line: not available    
    JPanel(JComponent).getPreferredSize() line: not available   
    BorderLayout.layoutContainer(Container) line: not available 
    JPanel(Container).layout() line: not available  
    JPanel(Container).doLayout() line: not available    
    JPanel(Container).validateTree() line: not available    
    JPanel(Container).validateTree() line: not available    
    JPanel(Container).validateTree() line: not available    
    JLayeredPane(Container).validateTree() line: not available  
    JRootPane(Container).validateTree() line: not available 
    JRootPane(Container).validate() line: not available 
    RepaintManager.validateInvalidComponents() line: not available  
    SystemEventQueueUtilities$ComponentWorkRequest.run() line: not available    
    InvocationEvent.dispatch() line: not available  
    EventQueue.dispatchEvent(AWTEvent) line: not available  
    EventDispatchThread.pumpOneEventForFilters(int) line: not available 
    EventDispatchThread.pumpEventsForFilter(int, Conditional, EventFilter) line: not available  
    EventDispatchThread.pumpEventsForHierarchy(int, Conditional, Component) line: not available 
    EventDispatchThread.pumpEvents(int, Conditional) line: not available    
    EventDispatchThread.pumpEvents(Conditional) line: not available 
    EventDispatchThread.run() line: not available   
Thread [DestroyJavaVM] (Suspended)  
Daemon System Thread [D3D Screen Updater] (Suspended)   
    Object.wait(long) line: not available [native method]   
    D3DScreenUpdateManager.run() line: not available    
    Thread.run() line: not available    
Daemon System Thread [TimerQueue] (Suspended)   
    Object.wait(long) line: not available [native method]   
    TimerQueue.run() line: not available    
    Thread.run() line: not available    
Thread [Thread-3] (Suspended)   
    Thread.sleep(long) line: not available [native method]  
    JDCConnectionPool$ConnectionReaper.run() line: 93   
Daemon Thread [SwingWorker-pool-1-thread-1] (Suspended) 
    Unsafe.park(boolean, long) line: not available [native method]  
    LockSupport.park(Object) line: not available    
    AbstractQueuedSynchronizer$ConditionObject.await() line: not available  
    LinkedBlockingQueue<E>.take() line: not available   
    ThreadPoolExecutor.getTask() line: not available    
    ThreadPoolExecutor$Worker.run() line: not available 
    Thread.run() line: not available    

よろしくお願いします。

4

3 に答える 3

1

コンボボックスに100,000アイテムを追加することが、おそらく問題の根本です。

また、1人のユーザーがコンボボックス内の100,000個のアイテムをどのように処理できるのか疑問に思う必要があります。

JComboBox通常、このような大量のアイテムを処理することは想定されていません。

コードを最適化する1つの可能な方法は、明示的に呼び出すことです。この方法では、すべてのモデルアイテムのディメンションをチェックして、独自のディメンションを計算するsetPrototypeDisplayValue()ことを回避します。JComboBoxこれが、システムがフリーズしているように見える現在の理由である可能性があります。

于 2011-05-15T09:59:18.057 に答える
1

その doInBackground は SELECT クエリを実行し、結果を取得した後、パネルのモデルを更新し、パネルの refreshFromModel を呼び出します。

DB クエリは doInBackground() で実行されます。

モデルの更新は process() メソッドで行う必要があります。

詳細については、並行性に関するSwing チュートリアルのセクションを参照してください。

于 2011-05-13T20:36:06.000 に答える
0

大量の提案を含むオートコンプリート機能を探していることは承知しています。

おそらく、 glazedlistsライブラリを見ることができます。そのコア機能は監視可能なリストを提供することですが、非常に柔軟です。できることの 1 つは、そのようなリストに基づいて ComboBoxModel を構築し、(AutoCompleteSupportクラスを介して) コンボボックスのオートコンプリートを有効にすることです。

このアプローチは、addItem で ComboBox 関連のパフォーマンスの問題を回避する方法を提供する場合があります。その部分は glazedlists に移動されます。

于 2011-05-14T08:54:04.693 に答える