Table of Contents
fock knowledge
Example
Home Backend Development PHP Tutorial Detailed explanation of pcntl_fork execution process example

Detailed explanation of pcntl_fork execution process example

Mar 08, 2018 pm 02:14 PM
fork pcntl Example

This article mainly shares with you an example of the pcntl_fork execution process. The concept of process (process) is a process, which mainly contains three elements:

1. An executable program;
2. All data associated with the process (including variables, memory space, buffers, etc.);
3. The execution context of the program;

can be thought of like this

It may be simply understood that a process represents an execution process of an executable program a state in. The operating system's management of processes is typically accomplished through the process table. Each entry in the process table records the status of a process in the current operating system.
For the case of a single CPU, only one process occupies the CPU at a specific time, but there may be multiple active (waiting for execution or continued execution) processes in the system at the same time. A register called the program counter (pc) indicates the location of the next instruction to be executed by the process currently occupying the CPU. When the CPU time allocated to a process has been used up, the operating system saves the value of the register related to the process to the corresponding entry of the process in the process table; the context of the process that will take over the CPU from this process is Read from the process table and update the corresponding register (this process is called "Context switch (process context switch)". The actual context switch needs to involve more data, which has nothing to do with fork. No more details. The main thing to remember is that the program register pc indicates where the program has been executed. It is an important part of the process context. The process that is swapped out of the CPU must save the value of this register. The process that is swapped into the CPU must also be based on the process table. Update this register with the execution context information of this process saved in it).

fock knowledge

After fork, the operating system will copy a child process that is exactly the same as the parent process. Although it is a father-son relationship, from the perspective of the operating system, they are more like brothers Relationship, these two processes share code space, but the data space is independent of each other. The content in the child process's data space is a complete copy of the parent process, and the instruction pointer is exactly the same, but there is only one difference. If the fork succeeds, the child process's data space is a complete copy of the parent process. The return value of fork is 0. The return value of fork in the parent process is the process number of the child process. If fork fails, the parent process will return an error. It can be imagined that the two processes have been running at the same time and in the same pace. After the fork, they do different tasks respectively, that is, they bifurcate. This is why fork is called fork. As for which process runs first, this is related to the scheduling algorithm of the operating system platform, and this problem is not important in practical applications. If parent and child processes need to work together, it can be solved by controlling the syntax structure.

2

The child process can inherit the things of the parent process before fork, but after pcntl_fork(), the child process and the parent process have nothing. Inheritance relationship. Things created in the child process belong to the child process, and things created in the parent process belong to the parent process. They can be completely regarded as two independent processes.

3

After using pcntl_fork() in the program segment, the program bifurcated and two processes were derived. Which one is specific? The first thing to run depends on the scheduling algorithm of the system.
Here, we can think that when running to "pid=pcntl_fork();", the system spawns a subprocess that is exactly the same as the main program. The pid obtained in the "pid=pcntl_fork();" sentence of the process is the pid of the child process itself; after the child process ends, the pid obtained in the "pid=pcntl_fork();" sentence of the parent process is the pid of the parent process itself. So the program has two lines of output.

4

pcntl_fork() function copies the PCB of the current process and returns the pid of the derived child process to the parent process. The parent and child processes In parallel, the order of printing statements depends entirely on the scheduling algorithm of the system, and the content of printing is controlled by the pid variable. Because we know that pcntl_fork() returns the pid of the derived child process to the parent process, which is a positive integer; while the pid variable of the derived child process has not been changed, this difference allows us to see their different outputs.

5

  1. The process that derives the child process, that is, the parent process, has the same pid;

  2. For the child process, the fork() function returns 0 to it, but its own pid will never be 0; the reason why the fork() function returns 0 to it is because it can be used at any time Call getpid() to get your own pid;

  3. After fork, unless synchronization is used between the parent and child processes, it is impossible to determine who runs first or who ends first. It is wrong to think that the parent process returns from fork only after the child process ends. This is not the case with fork, but with vfork.

Example

<?php$lock = new swoole_lock(SWOOLE_MUTEX);echo "[主进程]create lock\n";$lock->lock();$res = pcntl_fork();if ($res>0)
{    echo "1\n";    $lock->unlock();
    sleep(1);    echo "222";
} 
else{    echo "[子进程] Wait Lock\n";    $lock->lock();    echo "[子进程] Get Lock\n";    $lock->unlock();    exit("[子进程] exit\n");
}echo "[主进程]release lock\n";unset($lock);echo "[主进程]exit\n";
Copy after login

Detailed explanation of pcntl_fork execution process example

Related recommendations:

Weibo Qzone WeChat pcntl_fork implements PHP multi-process

Detailed introduction to pcntl_fork in php multi-process

php Usage of pcntl_fork and pcntl_fork

The above is the detailed content of Detailed explanation of pcntl_fork execution process example. For more information, please follow other related articles on the PHP Chinese website!

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

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.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

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)

SVM examples in Python SVM examples in Python Jun 11, 2023 pm 08:42 PM

Support Vector Machine (SVM) in Python is a powerful supervised learning algorithm that can be used to solve classification and regression problems. SVM performs well when dealing with high-dimensional data and non-linear problems, and is widely used in data mining, image classification, text classification, bioinformatics and other fields. In this article, we will introduce an example of using SVM for classification in Python. We will use the SVM model from the scikit-learn library

VUE3 Getting Started Example: Making a Simple Video Player VUE3 Getting Started Example: Making a Simple Video Player Jun 15, 2023 pm 09:42 PM

As the new generation of front-end frameworks continues to emerge, VUE3 is loved as a fast, flexible, and easy-to-use front-end framework. Next, let's learn the basics of VUE3 and make a simple video player. 1. Install VUE3 First, we need to install VUE3 locally. Open the command line tool and execute the following command: npminstallvue@next Then, create a new HTML file and introduce VUE3: &lt;!doctypehtml&gt;

The relationship between the number of Oracle instances and database performance The relationship between the number of Oracle instances and database performance Mar 08, 2024 am 09:27 AM

The relationship between the number of Oracle instances and database performance Oracle database is one of the well-known relational database management systems in the industry and is widely used in enterprise-level data storage and management. In Oracle database, instance is a very important concept. Instance refers to the running environment of Oracle database in memory. Each instance has an independent memory structure and background process, which is used to process user requests and manage database operations. The number of instances has an important impact on the performance and stability of Oracle database.

Learn best practice examples of pointer conversion in Golang Learn best practice examples of pointer conversion in Golang Feb 24, 2024 pm 03:51 PM

Golang is a powerful and efficient programming language that can be used to develop various applications and services. In Golang, pointers are a very important concept, which can help us operate data more flexibly and efficiently. Pointer conversion refers to the process of pointer operations between different types. This article will use specific examples to learn the best practices of pointer conversion in Golang. 1. Basic concepts In Golang, each variable has an address, and the address is the location of the variable in memory.

VAE algorithm example in Python VAE algorithm example in Python Jun 11, 2023 pm 07:58 PM

VAE is a generative model, its full name is VariationalAutoencoder, which is translated into Chinese as variational autoencoder. It is an unsupervised learning algorithm that can be used to generate new data, such as images, audio, text, etc. Compared with ordinary autoencoders, VAEs are more flexible and powerful and can generate more complex and realistic data. Python is one of the most widely used programming languages ​​and one of the main tools for deep learning. In Python, there are many excellent machine learning and deep

Verification code usage examples in Gin framework Verification code usage examples in Gin framework Jun 23, 2023 am 08:10 AM

With the popularity of the Internet, verification codes have become a necessary process for login, registration, password retrieval and other operations. In the Gin framework, implementing the verification code function has become extremely simple. This article will introduce how to use a third-party library to implement the verification code function in the Gin framework, and provide sample code for readers' reference. 1. Install dependent libraries Before using the verification code, we need to install a third-party library goCaptcha. To install goCaptcha, you can use the goget command: $goget-ugithub

PHP simple web crawler development example PHP simple web crawler development example Jun 13, 2023 pm 06:54 PM

With the rapid development of the Internet, data has become one of the most important resources in today's information age. As a technology that automatically obtains and processes network data, web crawlers are attracting more and more attention and application. This article will introduce how to use PHP to develop a simple web crawler and realize the function of automatically obtaining network data. 1. Overview of Web Crawler Web crawler is a technology that automatically obtains and processes network resources. Its main working process is to simulate browser behavior, automatically access specified URL addresses and extract all information.

GAN algorithm example in Python GAN algorithm example in Python Jun 10, 2023 am 09:53 AM

Generative Adversarial Networks (GAN) is a deep learning algorithm that uses two neural networks to compete with each other to generate new data. GAN is widely used for generation tasks in image, audio, text and other fields. In this article, we will use Python to write an example of a GAN algorithm for generating images of handwritten digits. Dataset Preparation We will use the MNIST data set as our training data set. The MNIST data set contains

See all articles