多进程,多线程了解

需求 最新希望了解一下,多进程和多线程分别适用的场景 解决 多进程适合 CPU 密集型任务:如果应用程序需要大量的 CPU 计算,并且没有太多的 I/O 操作,则使用多进程可能更加适合。这是因为每个进程都有自己的 CPU 时间片,可以并行执行,从而提高整个应用程序的性能。 隔离性:如果应用程序需要隔离不同的任务或数据,以确保它们不会相互影响,则使用多进程可能更加适合。每个进程都有自己的地址空间和资源,因此不同的进程可以独立运行,互相不会干扰。 多线程适合 I/O 密集型任务:如果应用程序需要大量的 I/O 操作(例如网络通信、磁盘读写等),则使用多线程可能更加适合。这是因为 I/O 操作通常是阻塞的,一个线程被阻塞时,另一个线程可以继续执行,从而提高整个应用程序的性能。 共享性:如果应用程序需要共享数据,并且需要在不同的任务之间共享数据,那么使用多线程可能更加适合。线程可以在同一地址空间内运行,它们可以访问相同的变量和数据结构,从而可以方便地共享数据。 轻量级任务:如果应用程序需要处理大量的轻量级任务,并且创建进程的开销太大,那么使用多线程可能更加适合。 参考 多线程和多进程的适用场景 一文弄懂多进程与多线程 多线程还是多进程的选择及区别

<span title='2023-07-03 18:06:00 +0800 CST'>2023-07-03</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;26 words&nbsp;·&nbsp;RamLife

多进程通信几种方式介绍

需求 多进程通信有哪几种方式? 解决 管道 命名管道 FIFO 使用 mkfifo 来创建管道文件。 不相关进程也可以通信。 匿名管道 使用 fork 来创建。只能用于父子进程。 消息队列 queue 保存在内核中的消息列表,如果没有释放,会一直存在。缺点时,不适合大数据的传输,单个消息有长度限制,全部消息总长度也有限制。 共享内存 同一块内存,多个进程都可以读写,可以省去复制的时间。但是如何管理多个进程的读写是个问题。 信号量 信号量可以用来管理共享内存,只有拿到信号量的才能进行读写。 信号 异常工作下的情况,就需要使用信号来进行干预了。比如说 ctrl-c 发出的 SIGINT 用来终止进程。 socket 可以用来本机之间不同进程的通信,也可以用作网络上不同主机之间的通信。 参考 {整理} Linux 进程间通信的方式、应用场景及优缺点 Linux进程间通信(IPC)的六种方式 一文搞懂六大进程通信机制原理(全网最详细) Linux进程间通信详解(最全)

<span title='2023-06-28 18:06:00 +0800 CST'>2023-06-28</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;36 words&nbsp;·&nbsp;RamLife

多进程如何使用单串口的方案

需求 数据处理的程序是多进程的,那么如何让多进程的处理程序使用硬件上的单个的串口呢? 解决 最适合的方法还是,把串口部分的程序独立出来,做成一个服务程序。 这个服务,对下是一条一条的把数据帧通过硬件串口进行收发。 这个服务,自身需要对数据进行一定的加工处理,比如按照指定的协议对数据帧进行编解码。 这个服务,对上可以使用队列,管道等进程间通讯的方式,把相关数据送到不同的进程中去。 当然如果多进程的处理功能特别简单,也可以考虑把这个处理的功能和串口二合一,然后通过多线程的方式去做。 参考 这个很有必要讨论讨论,我搞过一小段时间售货机,串口通信 多个进程间如何实现串口控制共享 linux两个进程同时打开串口,linux串口操作及设置详解

<span title='2023-03-13 15:01:00 +0800 CST'>2023-03-13</span>&nbsp;·&nbsp;1 min&nbsp;·&nbsp;12 words&nbsp;·&nbsp;RamLife