Size: 1013
Comment:
|
Size: 1370
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 9: | Line 9: |
{{{#!highlight python from javax.swing import JButton, JFrame frame = JFrame('Hello, Jython!', defaultCloseOperation = JFrame.EXIT_ON_CLOSE, size = (300, 300) ) def change_text(event): print 'Clicked!' button = JButton('Click Me!', actionPerformed=change_text) frame.add(button) frame.visible = Tru }}} |
jython
Python for the Java platform (2.7)
GUI app
1 from javax.swing import JButton, JFrame
2
3 frame = JFrame('Hello, Jython!',
4 defaultCloseOperation = JFrame.EXIT_ON_CLOSE,
5 size = (300, 300)
6 )
7
8 def change_text(event):
9 print 'Clicked!'
10
11 button = JButton('Click Me!', actionPerformed=change_text)
12 frame.add(button)
13 frame.visible = Tru
GIL (Global Interpreter Lock)
https://jython.readthedocs.io/en/latest/chapter19/#no-global-interpreter-lock
No Global Interpreter Lock
Jython lacks the global interpreter lock (GIL), which is an implementation detail of CPython. For CPython, the GIL means that only one thread at a time can run Python code.
Again, Jython does not have the straightjacket of the GIL. This is because all Python threads are mapped to Java threads and use standard Java garbage collection support (the main reason for the GIL in CPython is because of the reference counting GC system). The important ramification here is that you can use threads for compute-intensive tasks that are written in Python.