Size: 979
Comment:
|
Size: 1370
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 8: | Line 8: |
* https://jython.readthedocs.io/en/latest/chapter16/ | * https://jython.readthedocs.io/en/latest/GUIApplications/ {{{#!highlight python from javax.swing import JButton, JFrame |
Line 10: | Line 12: |
== GIL == | 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 }}} == GIL (Global Interpreter Lock) == |
Line 12: | Line 27: |
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.