Linux系统编程——多线程实现多任务
来源:互联网 发布:pianoboy知乎 编辑:程序博客网 时间:2024/06/03 12:44
概述
每个进程都拥有自己的数据段、代码段和堆栈段,这就造成进程在进行创建、切换、撤销操作时,需要较大的系统开销。为了减少系统开销,从进程中演化出了线程。为了让进程完成一定的工作,进程必须至少包含一个线程。线程存在于进程中,共享进程的资源。更多详情,请看《进程和线程的区别与联系》。
就像每个进程都有一个进程号一样,每个线程也有一个线程号。进程号在整个系统中是唯一的,但线程号不同,线程号只在它所属的进程环境中有效。进程号用 pid_t 数据类型表示,是一个非负整数。线程号则用 pthread_t 数据类型来表示,Linux 使用无符号长整数表示。有的系统在实现 pthread_t 的时候,用一个结构体来表示,所以在可移植的操作系统实现不能把它做为整数处理。
线程的常用函数
1)获取线程号
所需头文件:
#include <pthread.h>
pthread_t pthread_self(void);
功能:
获取线程号。
参数:
无
返回值:
调用线程的线程 ID 。
2)线程号的比较
所需头文件:
#include <pthread.h>
int pthread_equal(pthread_t t1, pthread_t t2);
功能:
判断线程号 t1 和 t2 是否相等。为了方便移植,尽量使用函数来比较线程 ID。
参数:
t1,t2:待判断的线程号。
返回值:
相等: 非 0
不相等:0
示例代码:
线程函数的程序在 pthread 库中,故链接时要加上参数 -lpthread。
运行结果如下:
3)线程的创建
所需头文件:
#include <pthread.h>
int pthread_create( pthread_t *thread,
const pthread_attr_t *attr,
void *(*start_routine)(void *),
void *arg );
功能:
创建一个线程。
参数:
thread:线程标识符地址。
attr:线程属性结构体地址,通常设置为 NULL。
start_routine:线程函数的入口地址。
arg:传给线程函数的参数。
返回值:
成功:0
失败:非 0
pthread_create() 创建的线程从指定的回调函数开始运行,该函数运行完后,该线程也就退出了。线程依赖进程存在的,共享进程的资源,如果创建线程的进程结束了,线程也就结束了。
示例一:
运行结果如下:
示例二:
运行结果如下:
4)回收线程资源
所需头文件:
#include <pthread.h>
int pthread_join(pthread_t thread, void **retval);
功能:
等待线程结束(此函数会阻塞),并回收线程资源,类似进程的 wait() 函数。如果线程已经结束,那么该函数会立即返回。
参数:
thread:被等待的线程号。
retval:用来存储线程退出状态的指针的地址。
返回值:
成功:0
失败:非 0
示例代码如下:
运行结果如下:
创建一个线程后应回收其资源,但使用 pthread_join() 函数会使调用者阻塞,linux 还提供了非阻塞函数 pthread_detach() 来回收线程的资源。
所需头文件:
#include <pthread.h>
int pthread_detach(pthread_t thread);
功能:
使调用线程与当前进程分离,分离后不代表此线程不依赖与当前进程,线程分离的目的是将线程资源的回收工作交由系统自动来完成,也就是说当被分离的线程结束之后,系统会自动回收它的资源。所以,此函数不会阻塞。
参数:
thread:线程号。
返回值:
成功:0
失败:非 0
注意,调用 pthread_detach() 后再调用 pthread_join() , pthread_join() 会立马返回,调用失败。
示例代码如下:
运行结果如下:
5)线程退出
在进程中我们可以调用 exit() 函数或 _exit() 函数来结束进程,在一个线程中我们可以通过 pthread_exit() 在不终止整个进程的情况下停止它的控制流。
所需头文件:
#include <pthread.h>
void pthread_exit(void *retval);
功能:
退出调用线程。一个进程中的多个线程是共享该进程的数据段,因此,通常线程退出后所占用的资源并不会释放。
参数:
retval:存储线程退出状态的指针。
返回值:
无
示例代码如下:
运行结果如下:
本教程示例代码下载请点此链接。
- Linux系统编程——多线程实现多任务
- Linux系统编程——多线程实现多任务
- Linux 多线程编程—线程池 实现
- Linux系统多线程编程
- linux系统多线程编程
- 多线程实现多任务
- 多线程实现多任务
- Linux系统编程——多任务的同步与互斥
- Linux系统编程——多任务的同步与互斥
- Linux系统编程多线程技术
- Linux多任务编程
- Linux多线程编程—初步
- C++多线程编程(4)多任务与多线程编程
- 多线程编程:任务取消
- 用python实现Linux系统编程——进程
- spring+ActiveMQ+JMS+线程池实现简单的分布式,多线程,多任务的异步任务处理系统
- spring+ActiveMQ+JMS+线程池实现简单的分布式,多线程,多任务的异步任务处理系统
- ActiveMQ(六):spring+ActiveMQ+线程池实现简单的分布式,多线程,多任务的异步任务处理系统
- Java中的equals和==
- SunlightDB区块链3.0技术架构简介
- IAR环境下STM32+IAP方案的实现(转)
- 重头开始设计一个系统吧
- FTP和Tomcat的设置_阿里云ECS相关
- Linux系统编程——多线程实现多任务
- 提供一种提高开发效率的思路。(IIS + wget)
- Unity2017使用Jenkins 自动多平台打包,无Tomcat
- Android Studio导入项目的时候,一直卡在Building gradle project info
- 【C语言】switch..case语句
- EJB原理——RMI原理【转】
- 【Docker构建】- 创建带apache服务的Centos Docker镜像
- JSplitPane
- java ----实现简单的21点纸牌游戏