This is easier to understand. GIL ensures that python byte code only has one native thread running in the process at the same time. However, the logic of the byte code itself still requires locking/mutual exclusion, etc. to ensure that the thread can be reentrant, because the byte code may be interrupted at any point during the running process and switched to another thread.
This is easier to understand. GIL ensures that python byte code only has one native thread running in the process at the same time. However, the logic of the byte code itself still requires locking/mutual exclusion, etc. to ensure that the thread can be reentrant, because the byte code may be interrupted at any point during the running process and switched to another thread.
A piece of counter code:A simple example:
// Step 1
The expected result should be that both threads have counted, and the final Counter should be 2:counter = get_counter()
// Step 2
counter += 1
// Step 3
set_counter(counter)
Assume that the initial Counter is 0, and two threads execute this Python code at the same time without any synchronization.
But because there is no locking/mutual exclusion, the execution situation is as follows:
When thread A finishes executing Step 1, the counter is 0, which means switching to thread B
Thread B successfully executed Steps 1, 2, and 3. Now Counter is 1, and then switches to A
Thread A continues to execute Step 2 and gets counter to 1, and then Step 3 sets Counter to 1. -
The final result is 1.