多进程无法结束?

import multiprocessing
import os
import time

def doChorme():
    time.sleep(0.1)

def booth(queue,lock):
    while True:
        i = queue.get()
        lock.acquire()
        if i > 0:
            i = i - 1
            queue.put(i)
            print("Process:",os.getpid(),"Left %d tickets!" %i)
            doChorme()
        else:
            print("Process:",os.getpid(),"No more tickets!")
        lock.release()
i = 10
record = []
lock = multiprocessing.Lock()
queue = multiprocessing.Queue(100)
queue.put(i)
if __name__ == "__main__":
    for n in range(5):
        process = multiprocessing.Process(target=booth, args=(queue, lock))
        process.start()
        record.append(process)
    queue.close()
    for m in record:
        m.join()

 

转载于:https://www.cnblogs.com/vincenshen/p/6164338.html

### C语言中多进程编程的使用方法 在C语言中,多进程编程主要依赖于 `fork()` 函数来实现。该函数用于创建一个新的进程,新进程被称为子进程,而调用 `fork()` 的进程称为父进程。`fork()` 函数的原型定义在 `<unistd.h>` 和 `<sys/types.h>` 头文件中,其函数原型为: ```c pid_t fork(void); ``` 当 `fork()` 被成功调用时,它会创建一个新的进程,该进程几乎完全复制了父进程的状态,包括代码段、数据段、堆栈段等。过,现代Linux系统采用了写时复制(Copy-on-Write)技术,这意味着实际的复制操作只有在父子进程之一尝试修改数据时才会发生。如果子进程随后调用了 `exec` 系列函数来执行新的程序,则会发生复制,因为子进程将加载并运行新的程序[^1]。 创建子进程后,`fork()` 的返回值用于区分父进程和子进程。在父进程中,`fork()` 返回子进程进程ID(PID);而在子进程中,`fork()` 返回0。如果 `fork()` 调用失败,则返回-1,此时会创建新进程。 以下是一个简单的 `fork()` 使用示例: ```c #include <stdio.h> #include <sys/types.h> #include <unistd.h> int main() { pid_t pid = fork(); // 创建子进程 if (pid < 0) { // 检查fork是否成功 fprintf(stderr, "Fork failed\n"); return 1; } else if (pid == 0) { // 子进程 printf("This is the child process, PID: %d\n", getpid()); } else { // 父进程 printf("This is the parent process, PID: %d, Child PID: %d\n", getpid(), pid); } return 0; } ``` 在上述代码中,`fork()` 被调用来创建一个子进程。如果 `fork()` 成功,子进程会输出自己的PID,而父进程则输出自己的PID以及子进程的PID。 需要注意的是,`fork()` 创建的子进程与父进程之间谁先运行是确定的,这取决于操作系统的调度策略。因此,在编写多进程程序时,通常需要使用同步机制(如信号量、管道等)来协调父子进程之间的执行顺序。 此外,进程在内存中的布局包括代码段、堆栈段和数据段。代码段可以被多个进程共享,而堆栈段和数据段则是每个进程独立拥有的。这是因为堆栈段主要用于保存进程的执行环境,而数据段则用于存储全局变量和常量[^2]。 最后,需要注意的是,`fork()` 创建的子进程拥有自己的 `task_struct` 结构和PID,这意味着它是一个独立的进程,具有自己的资源。然而,这并意味着所有的资源都会立即被复制,而是通过写时复制技术来优化资源的使用效率。 --- ### 相关问题 1. 如何在C语言中使用 `exec` 系列函数替换进程映像? 2. 在C语言中,如何使用 `wait()` 或 `waitpid()` 函数等待子进程结束? 3. 如何在多进程编程中实现进程间通信? 4. `fork()` 函数在创建子进程时有哪些潜在的问题需要注意? 5. 如何处理多进程程序中的僵尸进程问题?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值