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

IO进、线程——线程(线程的创建、线程的退出、线程的回收、线程的分离和多线程并发编程)

线程

并发执行的轻量级进程

进程是资源分配的最小单位,线程是任务调度的最小单位

线程是进程的一部分,是任务调度的最小单位。一个进程可以包含多个线程,这些线程可以并发执行,共享进程的资源,但每个线程都有自己的执行路径。在多核处理器上,多个线程可以同时运行,提高了程序的性能和响应能力。下面将对线程的创建、退出、回收和分离

1 创建线程

#include <pthread.h>int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *(*start_routine) (void *), void *arg);

功能:创建子线程去执行任务
返回值:成功返回0,失败返回非0
参数说明
thread:线程对象(线程取个名字)
attr:线程属性,使用默认属性写NULL
start_routine:线程要去执行的任务(任务以函数为单位)

void *dosomething(void *arg);

arg:传递给start_routine的参数

pthread_t th;
pthread_t th1;
int ret = pthread_create(&th, NULL, test, "线程1");
int ret1 = pthread_create(&th1, NULL, test, "线程2");
if(ret != 0 || ret1 != 0){perror("pthread_create");return -1;
}

2 线程退出

void pthread_exit(void *retval);

功能:退出当前线程
参数说明
retval:线程退出时想要传递的信息

在线程执行完任务后,可以调用**pthread_exit(NULL)**来正常退出线程。

3 线程回收

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

功能:阻塞回收退出的子线程
返回值:成功返回0,失败返回-1
参数说明:
thread:要回收的线程
retval:指向线程退出时传递的信息

void *retval;
ret = pthread_join(th, &retval);
ret1 = pthread_join(th1, &retval);
if(ret < 0 || ret1 < 0){perror("pthread_join");return -1;
}

4 线程分离

int pthread_detach(pthread_t thread);

功能:断绝父子线程的关系
返回值:成功返回0,失败返回-1
参数说明:
thread:要断绝关系的子线程对象
注:一般在创建完子线程过后马上调用分离函数

当线程分离后,线程执行完任务后会自动释放资源,不需要再主线程中调用pthread_join()来回收线程。一般在创建完子线程后,如果不需要回收子线程资源,可以立即调用pthread_detach()函数进行分离。

pthread_detach(th);
pthread_detach(th1);

多线程并发

①两个线程同时在打印40个数,各打印个互不干扰。

#include <stdio.h>
#include <pthread.h>
#include <unistd.h>
void *test(void *args){char *name = (char *)args;for(int i = 0; i < 40; i++){printf("线程:%s 正在处理第:%d\n", name, i);}return NULL;
}int main(int argc, char *argv[])
{ pthread_t th;pthread_t th1;int ret = pthread_create(&th, NULL, test, "线程1");int ret1 = pthread_create(&th1, NULL, test, "线程2");if(ret != 0 || ret1 != 0){perror("pthread_create");return -1;}pthread_detach(th);pthread_detach(th1);void *retval;ret = pthread_join(th, &retval);ret1 = pthread_join(th1, &retval);if(ret < 0 || ret1 < 0){perror("pthread_join");return -1;}sleep(2);return 0;
} 

②三个线程共同分担打印50个数

/*===============================================
*   文件名称:并发多线程.c
*   创 建 者:杨桃清
*   创建日期:2023年07月31日 00:22
*   描    述:
================================================*/
#include <stdio.h>
#include <unistd.h>
#include <pthread.h>//声明互斥锁
pthread_mutex_t mutex;
int count = 0;void *print_num(void *args){char *name = (char *)args;while(1){//申请互斥锁pthread_mutex_lock(&mutex);if(count >= 50){//释放互斥锁pthread_mutex_unlock(&mutex);break;}printf("线程:%s  正在打印:%d\n", name, count);count++;//最后释放锁pthread_mutex_unlock(&mutex);}return NULL;
}int main(int argc, char *argv[])
{ pthread_t th1;pthread_t th2;pthread_t th3;//初始化锁pthread_mutex_init(&mutex, NULL);//创3个建线程int ret1 = pthread_create(&th1, NULL, print_num, "th1");int ret2 = pthread_create(&th2, NULL, print_num, "th2");int ret3 = pthread_create(&th3, NULL, print_num, "th3");if(ret1 != 0 || ret2 != 0 || ret3 != 0){perror("pthread_create");return -1;}//void* retval;pthread_join(th1, NULL);//等待第一个线程执行完毕pthread_join(th2, NULL);//等待第二个线程执行完毕pthread_join(th3, NULL);//等待第三个线程执行完毕//销毁互斥锁pthread_mutex_destroy(&mutex);return 0;
} 
http://www.lryc.cn/news/102482.html

相关文章:

  • neo4j教程-Cypher操作
  • 秋招算法备战第31天 | 贪心算法理论基础、455.分发饼干、376. 摆动序列、53. 最大子序和
  • 页面生成图片或PDF node-egg
  • go常用知识点
  • ComPDFKit PDF SDK(支持Web、Android、IOS、Windows、Server、API、跨平台)
  • 使用maven容器打包java项目
  • 超前端相关的学习网站和一些靠谱的小工具
  • uniapp跳转到外部链接
  • 初识DBT以及搭建第一个DBT工程
  • Python基于PyTorch实现卷积神经网络回归模型(CNN回归算法)项目实战
  • (AcWing)集合-Nim游戏
  • ConcurrentHashMap源码详解
  • 医疗流程自动化盛行,RPA成为医疗保健行业的重点应用技术
  • Java 版 spring cloud + spring boot 工程系统管理 工程项目管理系统源码 工程项目各模块及其功能点清单
  • java重试机制实现方案
  • 参数量仅有50KB的超轻量级unet变种网络egeunet【参数和计算量降低494和160倍】医疗图像分割实践
  • Android10 Settings系列(三)根据需求动态添加删除一级菜单、二级菜单的设置项
  • 51单片机——串行口通信
  • 洛谷题单 Part 6.7.1 矩阵
  • Spring中c3p0与dbcp配置
  • Flutter 添加 example流程
  • 数据治理8种方法
  • 大模型成互联网真正蜕变的标志,亦是各种新技术开始衍生的标志
  • 指针进阶详解---C语言
  • 设计模式思考,简单工厂模式和策略模式的区别?
  • Java - sh 脚本启动 jar 包等服务 - sh 脚本模板 - 适用于任何类似的服务启动
  • MySQL高级篇第5章(存储引擎)
  • openssl 命令行国密sm2的签名验签操作
  • 开源代码分享(9)—面向100%清洁能源的发输电系统扩展规划(附matlab代码)
  • 为 Google Play 即将推出基于区块链的内容政策做好准备