当前位置: 首页 > news >正文

【Linux】:线程控制

朋友们、伙计们,我们又见面了,本期来给大家带来线程控制相关代码和知识点,如果看完之后对你有一定的启发,那么请留下你的三连,祝大家心想事成!

C 语 言 专 栏:C语言:从入门到精通

数据结构专栏:数据结构

个  人  主  页 :stackY、

C + + 专 栏   :C++

Linux 专 栏  :Linux

目录

1. 创建线程

1.1 引入线程库

2. 获取线程id 

3. 线程终止 

4. 线程等待 

5. 线程的分离 

6. 线程的取消


1. 创建线程

在使用线程有关函数接口时需要引入头文件pthread.h

创建一个新的线程:

int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *
(*start_routine)(void*), void *arg);

参数:

  •  thread:返回新线程ID
  • attr:设置线程的属性,attr为NULL表示使用默认属性
  • start_routine:是个函数地址,线程启动后要执行的函数
  • arg:传给线程启动函数的参数 

返回值:

成功返回0,失败返回错误码。

代码演示: 

#include <iostream>
#include <unistd.h>
#include <pthread.h>
#include <sys/types.h>
#include <unistd.h>// 新线程
void *ThreadRoutine(void *arg)
{const char *threadname = (const char *)arg;while (true){std::cout << "I am a new thread: " << threadname << ", pid: " << getpid() << std::endl;sleep(1);}
}int main()
{pthread_t tid;// 创建线程pthread_create(&tid, nullptr, ThreadRoutine, (void *)"thread 1");// 主线程while (true){std::cout << "I am main thread" << ", pid: " << getpid() << std::endl;sleep(1);}return 0;
}

1.1 引入线程库

当我们直接编译时可以发现报错,明明已经引入了线程相关的头文件,为什么还会找不到该函数呢?

因为Linux没有真正的线程,只有轻量级进程的概念,所以Linux OS只会提供轻量级进程创建的系统调用,不会直接提供线程的创建的接口,Linux的线程是通过pthread原生线程库实现的,所以我们需要在编译选项中引入线程库

Makefile:

testThread:testThread.ccg++ -o $@ $^ -std=c++11 -lpthread
.PHONY:clean
clean:rm -f testThread

引入线程库之后再编译就不会出现报错了。

2. 获取线程id 

获取自己的线程id:

pthread_t pthread_self(void);

哪个线程调用该函数就可以返回哪个线程的id。

当我们将线程id获取并打印之后可以发现,线程id和线程的LWP毫无关系,并且线程id是一个比较大的数:

如果我们将这个id以十六进制的格式打印就会发现,线程的id本质上就是一个地址!

3. 线程终止 

线程终止一共有三种方法:

  • ① 直接在新线程中返回;
  • ② 使用pthread_exit函数;
  • ③ 使用pthread_cancel函数(线程的取消)。

线程终止可以直接在新线程中返回即可,还可以通过函数接口的方式进行终止:

void pthread_exit(void *retval);

注意:不能使用exit()来终止线程,这样会使整个进程退出。

参数:

  • retval:可以设为空,也可以设置退出信息

4. 线程等待 

线程和进程一样也是需要进行等待的,如果不等待就会发生和僵尸进程一样的情况(线程退出但是它的空间没有被释放),并且我们也会需要知道线程的退出信息,所以就需要有等待线程的接口。

int pthread_join(pthread_t thread, void **retval);

参数:

  • thread:要等待的线程ID
  • retval:它指向一个指针,后者指向线程的返回值(获取退出信息),也可以设为空

返回值:

成功返回0,失败返回错误码

代码演示: 

获取返回值信息和线程终止接口配合使用

// 新线程
void *ThreadRoutine(void *arg)
{int cnt = 1;const char *threadname = (const char *)arg;while (true){pthread_t id;// 获取线程idid = pthread_self();std::cout << "I am a new thread: " << threadname << " my id: " << ToHex(id) << std::endl;sleep(1);if(cnt == 5){// 线程退出,并带上退出信息pthread_exit((void *)"success");}cnt++;}
}int main()
{pthread_t tid;// 创建线程pthread_create(&tid, nullptr, ThreadRoutine, (void *)"thread 1");// 主线程// 等待新线程并获取退出信息void * message = nullptr;int n = pthread_join(tid, &message);std::cout << "Exit information for the new thread: " << (char *)message << ", " << n << std::endl;return 0;
}

5. 线程的分离 

  • 我们创建的新线程默认是joinable的,线程退出之后是需要进行pthread_join()操作的,否则无法释放资源,当我们进行pthread_join()操作时,如果线程不退出,那么就会一直阻塞住,直到线程退出;
  • 如果我们不关心线程的返回值,并且在等待线程时也是一种负担,所以这个时候就可以将线程设置为分离状态,即在线程退出的时候,自动释放线程的资源;
  • 设置为分离状态的可以是线程组内其他线程对目标线程进行分离,也可以是线程自己分离;
  • joinable和分离是冲突的,一个线程不能既是joinable又是分离的。

分离指定的线程:

int pthread_detach(pthread_t thread);

 

6. 线程的取消

取消一个执行中的线程:

int pthread_cancel(pthread_t thread);

线程如果被分离,是可以进行取消的,但是不能被等待!

朋友们、伙计们,美好的时光总是短暂的,我们本期的的分享就到此结束,欲知后事如何,请听下回分解~,最后看完别忘了留下你们弥足珍贵的三连喔,感谢大家的支持!    

http://www.lryc.cn/news/461760.html

相关文章:

  • 大数据-174 Elasticsearch Query DSL - 全文检索 full-text query 匹配、短语、多字段 详细操作
  • Spring Boot视频网站:构建可扩展的视频服务平台
  • 护眼台灯横评:书客、柏曼、明基哪款使用体验好,又能护眼?
  • RDMA笔记
  • Collection 单列集合 List Set
  • LabVIEW提高开发效率技巧----跨平台开发
  • 创建uniCloud新项目并且是新服务空间,运行会报Error: Invalid uni-id config file错误
  • 七、IPD 方法论框架(IPD的组织架构)
  • iPad mini 7惨遭暗砍一刀
  • 【计算机网络 - 基础问题】每日 3 题(三十六)
  • Docker镜像
  • Golang | Leetcode Golang题解之第478题在圆内随机生成点
  • 菜鸟笔记006 截图识别文字插件 textOCR
  • MySQL【知识改变命运】07
  • Matlab自学笔记三十八:日期时间序列的创建方法
  • fiber的原理
  • 重塑输电线路运维管理,巡检管理系统守护电网稳定运行
  • 各种排序方法总结
  • 【工欲善其事】巧用 PowerShell 自动清除复制 PDF 文本时夹杂的换行符号
  • Maven与Gradle的区别
  • 【linux 多进程并发】0202 Linux进程fork之后父子进程间的文件操作有着相同的偏移记录,多进程操作文件的方法
  • SQLite在安卓中的应用
  • Python数据库操作
  • 交叉熵损失函数为代表的两层神经网络的反向传播量化求导计算公式
  • 数据结构——八大排序(上)
  • vxe-table 导入导出功能全解析
  • 常用STL的操作以及特点
  • 025 elasticsearch索引管理-Java原生客户端
  • Gin框架操作指南10:服务器与高级功能
  • AIGC技术的学习 系列一