Session management using Hibernate in a *multi-threaded* Swing application

前端 未结 3 1585
耶瑟儿~
耶瑟儿~ 2021-02-09 10:11

I\'m currently working on a (rather large) pet project of mine , a Swing application that by it\'s very nature needs to be multi-threaded. Almost all user interactions might fet

3条回答
  •  遥遥无期
    2021-02-09 10:57

    There are two distinct problems, that should get resolved seperately:

    1. Handling of Hibernate Sessions in Swing Applications. Let me recommend my own article, regarding this problem: http://blog.schauderhaft.de/2008/09/28/hibernate-sessions-in-two-tier-rich-client-applications/

    The basic idea is to have a session for every frame, excluding modal frames which use the session of the spawning frame. It is not easy but it works. Meaning, you won't get any LLEs anymore.

    1. How to get your GUI thread separated from the back end.

    I recommend to keep the hibernate objects strictly on the back end thread they originate from. Only give wrapper objects to the ETD. If these wrapper objects are asked for a value, they create a request which gets passed to the backend thread, which eventually will return the value.

    I'd envision three kinds of wrapper Implementations:

    Async: requests the value, and gets notified when the value is available. It would return immediately with some dummy value. On notification it will fire a PropertyChange event i.O. to inform the GUI about the 'changed' value (changed from unknown to a real value).

    Sync: requests the value and waits for it to be available.

    Timed: a mixture between the two, waiting for a short time (0.01) seconds, before returning. This would avoid plenty change events, compared to the async version.

    As a basis for these wrappers a recommend the ValueModel of the JGoodies Binding library: http://www.jgoodies.com/downloads/libraries.html

    Obviously You need to take care that any action is only performed on actually loaded values, but since you don't plan on doing updates this shouldn't be to much of an issue.

    Let me end with a warning: I have thought about it a lot, but never actually tried it, so move with care.

提交回复
热议问题