多线程编程

主题:
简介:
参考:
作者:
时间:

1.什么是线程
线程共享的进程资源:
代码:应用程序的代码;
数据:全局变量、static 变量、堆空间
进程空间:进程分得得内存空间;
打开的文件:各个线程打开的文件资源可以为所有线程共享;

线程的私有资源:
寄存器中存储的数据;
线程执行所需的局部变量;

多线程:
2.多线程程序举例
API:为了避免多个程序访问系统资源时产生冲突,所谓系统资源包含文件资源、I/O设备、网络,操作系统会将可能产生冲突的系统资源保护起来,阻止应用程序直接访问,如果程序中需要访问被操作系统保护起来的资源,需要使用操作系统规定的方法,这些调用方法称为接口。
注:gcc与gdb

pthread.h
pthread_create()
pthread_join()

3.创建线程
linux多线程操作

4.终止线程
(1)线程执行完成。自行终止;
(2)线程执行过程中遇到pthread_exit()或者return
(3)线程执行过程中,接收到其他线程发送的终止执行的信号
5.获取线程函数的返回值
调用pthread_join()函数获取某个线程执行结束时返回的数据。

6.线程终止执行的信号
调用pthread_cancel()函数,一个线程可以向同进程内另一个线程发送终止执行的cancel信号,使得目标线程结束执行。

7.线程同步机制
Linux环境实现线程同步的方法:
互斥锁
信号量
读写锁
条件变量
linux线程创建

主线程阻塞
pthread_t;
pthread_create;
pthread_join;
pthread_self;

链接动态库-lpthread

线程同步:当一个线程访问某公共资源时,其他线程不得访问该资源,它们只能等待此线程访问完成后,再逐个访问该资源。

互斥锁:当一个线程访问公共资源时,会及时的锁上该资源,组织其他线程访问,访问结束再进行解锁操作,其他线程便可以访问解锁之后会的资源。

信号量:控制同时访问公共资源的线程数量。
N≤1时,二元信号量;
N≥2时,多元信号量;

条件变量:条件成立等待的线程才可以访问目标资源

读写锁:针对线程对公共资源进行修改操作设计的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值