首页 > 系统相关 >进程与线程

进程与线程

时间:2024-08-16 13:38:07浏览次数:15  
标签:创建 内存空间 调度 线程 Linux 进程

进程和线程的区别

1. 定义

  • 进程(Process):是操作系统中资源分配的基本单位。每个进程有自己的独立内存空间、文件描述符、程序计数器等资源。进程之间是相互独立的。
  • 线程(Thread):是操作系统调度的基本单位,一个进程可以包含多个线程,线程共享进程的内存空间和其他资源,但每个线程有自己的栈空间和程序计数器。

2. 内存空间

  • 进程:进程有自己独立的内存空间,一个进程不能直接访问另一个进程的内存。
  • 线程:线程共享进程的内存空间,可以直接访问其他线程的数据。线程之间的通信更快,但也更容易引起同步问题。

3. 资源开销

  • 进程:由于进程之间的独立性,创建、销毁进程的开销较大,进程切换也需要更高的开销(如上下文切换)。
  • 线程:线程的创建、销毁和切换的开销相对较小,线程间的通信速度也比进程间通信快。

4. 调度

  • 进程:操作系统通过进程调度器管理进程的执行。进程调度涉及较多的上下文切换。
  • 线程:线程调度比进程调度更频繁,尤其在多线程应用中,操作系统需要在各个线程之间快速切换。

5. 同步

  • 进程:进程间通常通过IPC(如管道、信号、消息队列、共享内存等)进行通信和同步。
  • 线程:线程间通过锁(如互斥锁、读写锁)和条件变量等机制进行同步,防止竞争条件。

举例:Linux中的进程和线程

1. 进程的例子

  • sshd进程:在Linux系统中,sshd是Secure Shell Daemon的进程,负责管理远程登录会话。每个用户连接到服务器时,sshd会为每个会话启动一个新的进程。这些进程彼此独立,互不干扰。
  • initsystemd进程:这是Linux系统启动后的第一个进程,负责启动系统中所有其他的服务进程。initsystemd是整个系统的根进程,所有其他进程都是它的子进程。

2. 线程的例子

  • ApacheNginx中的线程:这些Web服务器在处理HTTP请求时,会为每个请求创建一个新的线程。这些线程在同一个进程中运行,共享进程的资源,但独立处理各自的请求。
  • MySQL数据库中的线程:MySQL数据库在处理查询时,会为每个客户端连接创建一个新的线程。所有的查询线程共享数据库的缓存和表结构信息,但每个线程独立执行SQL查询。

Linux中的进程和线程管理

  • 查看进程:使用命令ps auxtophtop可以查看系统中运行的进程及其相关信息。
  • 查看线程:可以使用ps -eLf来查看线程。-L选项表示显示线程,f表示显示完整格式。
  • 创建进程:使用fork()系统调用来创建一个新的进程。
  • 创建线程:使用pthread_create()函数来创建一个新的线程。

标签:创建,内存空间,调度,线程,Linux,进程
From: https://www.cnblogs.com/mirsbo/p/18362684

相关文章

  • Xinference实战指南:全面解析LLM大模型部署流程,携手Dify打造高效AI应用实践案例,加速AI
    Xinference实战指南:全面解析LLM大模型部署流程,携手Dify打造高效AI应用实践案例,加速AI项目落地进程XorbitsInference(Xinference)是一个开源平台,用于简化各种AI模型的运行和集成。借助Xinference,您可以使用任何开源LLM、嵌入模型和多模态模型在云端或本地环境中运行推理,并......
  • Linux进程管理(保姆级教程)
    目录一、Linux中的进程和服务二、service服务管理(CentOS6版本-了解)(1).基本语法(2).经验技巧(3).案例实操三、chkconfig设置后台服务的自启配置(CentOS6版本)(1).基本语法(2).Linux运行级别(3).ntsysv服务界面控制自启动针对级别2345(4).案例实操四、systemctl(Ce......
  • 【容器安全系列Ⅰ】- 以进程视角探索容器
        使用容器的一个很大好处是,大多数时候你不必考虑后台发生了什么,像Docker和Kubernetes这样的工具,在向用户隐藏系统复杂性方面做得很好。    但是,当您需要调试和保护容器环境时,了解如何在底层与容器进行交互会非常有帮助。幸运的是,由于大多数容器化工具......
  • (路由卷1)-30-Tunnel和多进程方案
    隧道r2:inttunnel0ipadd172.16.100.2255.255.255.0tunnelsouce23.1.1.2tunneldestianation23.1.1.3r3:inttunnel0ipadd172.16.100.3255.255.255.0tunnelsource23.1.1.3tunneldestination23.1.1.2r2:routerospf1net172.16.100.20.0.0.0area......
  • 线程第二部分
    一、线程退出1.线程结束方式:    1.pthread_exit       2.在线程执行函数中return  (此时与1式相等)    3.pthread_cancel:    4.任何一个线程调用了exit或者主线程main函数return都会使进程结束2.pthread_cancel:intpthrea......
  • Java创建线程的方式
    1.继承Thread类第一步,创建一个线程类并继承Thread类第二步,重写run()方法,内部自定义线程执行体第三步,创建自定义的线程类对象,调用start()方法,启动线程示例代码如下publicclassMyThread1extendsThread{@Overridepublicvoidrun(){for(inti=0;i<......
  • 20240815有名管道双端线程通信
    //端1#include<stdio.h>#include<stdlib.h>#include<sys/types.h>#include<sys/stat.h>#include<fcntl.h>#include<unistd.h>#include<string.h>#include<pthread.h>#include<errno.h>#include<......
  • Linux线程
    一、线程的基本操作pthread_create(pthread_t*thread,constpthread_attr_t*attr,void*(*start_routine)(void*),void*arg) :此函数用于创建新线程。thread 用于存储新创建线程的标识符,attr 可指定线程属性,start_routine 是线程执行的函数指针,arg 为传递给线程执行......
  • miniomp.dll丢失全方位指南:解锁多线程应用程序的高效修复策略
    解决miniomp.dll丢失的问题,可以遵循以下专业步骤来确保多线程应用程序正常运行:1.手动下载miniomp.dll:•首先,从可信赖的DLL下载站点或软件供应商处找到适合您操作系统的miniomp.dll文件。请务必谨慎选择来源,以避免潜在的安全风险。2.放置DLL文件至正确路径:•将下载......
  • 线程池使用场景 调用多个微服务汇总数据
    importlombok.SneakyThrows;importjava.text.SimpleDateFormat;importjava.util.concurrent.*;publicclassT{@SneakyThrowspublicstaticvoidmain(String[]args){shopping_threadPool();}/*汇总数据使用线程池+Future耗时≈所有......