操作系统(3) 多处理器编程:从入门到放弃

本文介绍了操作系统中的多处理器编程,重点讨论了并发的概念、进程与线程的区别以及并发的三大特性:原子性、有序性和可见性。通过示例说明了线程创建后的不确定性以及共享内存带来的问题。
摘要由CSDN通过智能技术生成

操作系统(3) 多处理器编程:从入门到放弃

入门:理解多线程

三个放弃:原子性、有序性、可见性

并发:介绍

进程与线程的区别:

  • 进程:正在运行的程序,系统分配资源和调度的基本单位,内存中可以同时加载多个进程,每个进程都有自己独立的地址空间,互相不会干扰。每个一段时间,进程间会发生上下文切换,进程发生切换,信息会保存再进程控制块(PCB)中
  • 线程:线程是操作系统能够进行运算调度的最小单位。它被包含在线程中,是线程中的实际运作单位。一个进程内可以有多个线程,每个线程共享内存,但有独立的堆栈。多个线程之间也会发生上下文切换,但地址空间保持不变。

线程的创建:

#include <stdio.h>
#include <assert.h>
#include <pthread.h>

void *mythread(void *arg){
   
	printf("%s\n", (char*)arg);
	return NULL;
}

int main(int argc, char* argv[]){
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值