线程字符串传递方式

|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| //扩展作业--参数传递 //思路: 当子线程退出的时候,pthread_exit((void *)88)--->传递给主线程 pthread_join(tid,(void *)&ret1) //函数---参数 #include <pthread.h> #include <stdio.h> #include <unistd.h> #include <stdlib.h> #include <string.h> void *task1(void *arg) //子线程1的任务 { int task1_arg = *(int *)arg; sleep(3); printf("task1 comming\r\n"); printf("arg = %d\r\n",task1_arg); pthread_exit((void *)88); //pthread_exit(void *retval); } void *task2(void *arg) //子线程2的任务 { int task2_arg = *(int *)arg; printf("task2 comming\r\n"); printf("arg = %d\r\n",task2_arg); //pthread_exit((void *)100); pthread_exit("hello world!\n"); } int main(void) { int task1_arg = 6, task2_arg = 8; int ret1; int ret2; void *thread_rs; //创建对应的线程 pthread_t tid1 , tid2; pthread_create(&tid1,NULL,task1,&task1_arg); pthread_create(&tid2,NULL,task2,&task2_arg); //作用:等待对应的子进程运行结束pthread_join(pthread_t thread,void **retval) pthread_join(tid1,(void *)&ret1); printf("ret1 = %d\r\n",(int)ret1); //pthread_join(tid2,(void *)&ret2); //printf("ret2 = %d\r\n",(int)ret2); pthread_join(tid2,&thread_rs); printf("thread finished value:%s\n",(char *)thread_rs); sleep(1); exit(0); } |

相关推荐
wWYy.几秒前
算法:最大子数组和
算法
吃着火锅x唱着歌4 分钟前
LeetCode 3829.设计共享出行系统
算法·leetcode·职场和发展
炸薯条!6 分钟前
二叉树的链式表示
数据结构·算法
CHHH_HHH7 分钟前
【C++】二叉搜索树全面升级,深度剖析AVL树
开发语言·数据结构·c++·算法·stl
Mumu12188 分钟前
P3211 [HNOI2011] XOR和路径
算法
高一学习c++会秃头吗9 分钟前
页面置换算法实现
算法
yuanyuan2o216 分钟前
Transformers NLP 任务:阅读理解问答
人工智能·算法·自然语言处理·nlp·github
菜菜的顾清寒26 分钟前
力扣HOT100(52)动态规划 - 最长递增子序列
算法·leetcode·动态规划
WBluuue32 分钟前
数据结构与算法:树上启发式合并
数据结构·c++·算法·启发式算法
x_xbx1 小时前
LeetCode:20. 有效的括号
算法·leetcode·职场和发展