国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Table of Contents
Why is it recommended to use multi-process instead of multi-threading in python? --Reposted from an article by a colleague
Home Backend Development PHP Tutorial Why is it recommended to use multi-process instead of multi-threading in python? --Repost an article from a colleague_PHP Tutorial

Why is it recommended to use multi-process instead of multi-threading in python? --Repost an article from a colleague_PHP Tutorial

Jul 12, 2016 am 08:55 AM
android

Why is it recommended to use multi-process instead of multi-threading in python? --Reposted from an article by a colleague

Recently, I have been reading about multi-threading in Python. We often hear veterans say: "Multi-threading in python is useless, it is recommended to use multi-process!", but why? What do you mean?

You need to know what it is, and you also need to know why it is so. So with the following in-depth research:

First of all, emphasize the background:

1. What is GIL? The full name of GIL is Global Interpreter Lock (global interpreter lock). The source is the consideration at the beginning of python design and the decision made for data security.

2. Each CPU can only execute one thread at the same time (multi-threading under a single-core CPU is actually only concurrency, not parallelism. From a macro perspective, concurrency and parallelism both process multiple requests at the same time. The concept. But there is a difference between concurrency and parallelism. Parallelism means that two or more events occur at the same time; concurrency means that two or more events occur at the same time interval)

<.>Under Python multi-threading, the execution method of each thread:
1. Obtain GIL
2. Execute the code until sleep or the python virtual machine suspends it.
3. Release the GIL

It can be seen that if a thread wants to execute, it must first get the GIL. We can think of the GIL as a "pass", and in a python process, there is only one GIL. Threads that cannot obtain a pass are not allowed to enter the CPU for execution.


In python2.x, the release logic of GIL is that the current thread encounters an IO operation or the tick count reaches 100 (ticks can be regarded as a counter of python itself, specifically Used for GIL, it is reset to zero after each release. This count can be adjusted through sys.setcheckinterval) before release.

Every time the GIL lock is released, threads compete for locks and switch threads, which consumes resources. And because of the GIL lock, a process in Python can only execute one thread at the same time (the thread that has obtained the GIL can execute). This is why Python's multi-threading efficiency is not high on multi-core CPUs.

So is python’s multi-threading completely useless?

Here we have a classified discussion:

1. CPU-intensive code (various loop processing, counting, etc.). In this case, due to a lot of calculation work, the tick count is very The threshold will be reached soon, and then the release and re-competition of GIL will be triggered (switching back and forth between multiple threads certainly consumes resources), so multi-threading under Python is not friendly to CPU-intensive codes.

2. For IO-intensive codes (file processing, web crawlers, etc.), multi-threading can effectively improve efficiency (if there are IO operations under a single thread, IO waiting will be performed, causing unnecessary waste of time, and multi-threading is turned on It can automatically switch to thread B while thread A is waiting, without wasting CPU resources, thereby improving program execution efficiency). Therefore, Python's multi-threading is more friendly to IO-intensive code.


In python3. The program is more friendly, but it still does not solve the problem caused by GIL that only one thread can be executed at the same time, so the efficiency is still unsatisfactory.


Please note: Multi-core multi-threading is worse than single-core multi-threading. The reason is that under single-core multi-threading, every time the GIL is released, the thread that wakes up can get it. GIL lock, so it can be executed seamlessly, but under multi-core, after CPU0 releases the GIL, the threads on other CPUs will compete, but the GIL may be immediately obtained by CPU0, causing the awakened threads on several other CPUs to Waiting awake until the switching time and then entering the pending state will cause thread thrashing, resulting in lower efficiency


Back to the original question: We often hear veterans say: "If you want to make full use of multi-core CPUs in Python, use multi-processes." What is the reason?

The reason is: each process has its own independent GIL and does not interfere with each other, so that it can be executed in parallel in a true sense. Therefore, in python, the execution efficiency of multi-process is better than that of multi-threading (only for multi-core for CPU).


So here’s the conclusion: under multi-core, if you want to improve efficiency in parallel, a more common method is to use multiple processes, which can effectively improve execution efficiency

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/1117253.htmlTechArticleWhy is it recommended to use multi-process instead of multi-threading in python? --Reposted from an article by a colleague. Recently, I have been reading about multi-threading in Python. We often hear veterans say: "Multi-threading under python is a waste...
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades Sep 12, 2024 pm 12:23 PM

In recent days, Ice Universe has been steadily revealing details about the Galaxy S25 Ultra, which is widely believed to be Samsung's next flagship smartphone. Among other things, the leaker claimed that Samsung only plans to bring one camera upgrade

Samsung Galaxy S25 Ultra leaks in first render images with rumoured design changes revealed Samsung Galaxy S25 Ultra leaks in first render images with rumoured design changes revealed Sep 11, 2024 am 06:37 AM

OnLeaks has now partnered with Android Headlines to provide a first look at the Galaxy S25 Ultra, a few days after a failed attempt to generate upwards of $4,000 from his X (formerly Twitter) followers. For context, the render images embedded below h

IFA 2024 | TCL\'s NXTPAPER 14 won\'t match the Galaxy Tab S10 Ultra in performance, but it nearly matches it in size IFA 2024 | TCL\'s NXTPAPER 14 won\'t match the Galaxy Tab S10 Ultra in performance, but it nearly matches it in size Sep 07, 2024 am 06:35 AM

Alongside announcing two new smartphones, TCL has also announced a new Android tablet called the NXTPAPER 14, and its massive screen size is one of its selling points. The NXTPAPER 14 features version 3.0 of TCL's signature brand of matte LCD panels

Vivo Y300 Pro packs 6,500 mAh battery in a slim 7.69 mm body Vivo Y300 Pro packs 6,500 mAh battery in a slim 7.69 mm body Sep 07, 2024 am 06:39 AM

The Vivo Y300 Pro just got fully revealed, and it's one of the slimmest mid-range Android phones with a large battery. To be exact, the smartphone is only 7.69 mm thick but features a 6,500 mAh battery. This is the same capacity as the recently launc

Samsung Galaxy S24 FE billed to launch for less than expected in four colours and two memory options Samsung Galaxy S24 FE billed to launch for less than expected in four colours and two memory options Sep 12, 2024 pm 09:21 PM

Samsung has not offered any hints yet about when it will update its Fan Edition (FE) smartphone series. As it stands, the Galaxy S23 FE remains the company's most recent edition, having been presented at the start of October 2023. However, plenty of

iQOO Z9 Turbo Plus: Reservations begin for the potentially beefed-up series flagship iQOO Z9 Turbo Plus: Reservations begin for the potentially beefed-up series flagship Sep 10, 2024 am 06:45 AM

OnePlus'sister brand iQOO has a 2023-4 product cycle that might be nearlyover; nevertheless, the brand has declared that it is not done with itsZ9series just yet. Its final, and possibly highest-end,Turbo+variant has just beenannouncedas predicted. T

New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades Sep 12, 2024 pm 12:22 PM

In recent days, Ice Universe has been steadily revealing details about the Galaxy S25 Ultra, which is widely believed to be Samsung's next flagship smartphone. Among other things, the leaker claimed that Samsung only plans to bring one camera upgrade

Xiaomi Redmi Note 14 Pro Plus arrives as first Qualcomm Snapdragon 7s Gen 3 smartphone with Light Hunter 800 camera Xiaomi Redmi Note 14 Pro Plus arrives as first Qualcomm Snapdragon 7s Gen 3 smartphone with Light Hunter 800 camera Sep 27, 2024 am 06:23 AM

The Redmi Note 14 Pro Plus is now official as a direct successor to last year'sRedmi Note 13 Pro Plus(curr. $375 on Amazon). As expected, the Redmi Note 14 Pro Plus heads up the Redmi Note 14 series alongside theRedmi Note 14and Redmi Note 14 Pro. Li

See all articles