linux(线程,线程同步 方法 互斥锁 信号量 条件变量 )

//线程 进程内部的一条执行序列 一个进程中可以有多个线程

//进程是资源分配的最小单位 线程是CPU调度的最小单位

//进程有独立的地址空间 线程共享进程中的地址空间

//int pthread_create() 线程创建

//线程创造函数

//thread 线程ID

//attr 线程属性 (默认NULL)

// start_routine ; 线程入口函数

//arg 传递给线程函数的参数

//当主线程结束时 子线程也会结束

//线程的特性

//1 线程间并发执行,具体调度根据操作系统的不同决定

//2 资源共享 线程共享进程的资源(全局变量,堆内存,文件描述符)

//3 独立的栈空间 局部变量存储在各自的栈空间中

//int pthread_join(pthread_t thread,void **retval) 等待某个线程结束并回收线程资源

//thread; 等待的线程ID

//retval 接受线程返回值的指针

//void pthread_exit(void *retval)

//终止当前线程 并返回结果

//如果不需要返回值 填NULL;

//如果需要返回值 则必须指向全局变量或动态分配的内存(不能是栈上的内容,因为线程终止后会被释放)

//练习 创建全局变量val初值为0 创建俩个子线程运行val++ 每个子线程循环1000次 主线程打印val的值、

//线程同步 方法 互斥锁 信号量 条件变量 、

//信号量

// #include<semaphore.h>

//int sem_init (sem_t*sem,int pshared,unsigned int value);//初始化信号量

// sem 表示指向sem_t类型的指针

// pshare 决定信号量的共享范围 0 表示仅在当前进程内的所有进程共享 非0值 在多个进程内共享(需要将该信号量放在共享内存中)

// value 信号量的初值

//int sem_wait (sem_t*sem);//原子操作 将信号量-1 获取资源 如果信号量为0 该操作会堵塞 此时将线程放入等待队列

//int sem_post (sem_t*sem);//原子操作 将信号量+1 释放资源 随机从等待队列中唤醒一条线程

//int sem_destory (sem_t*sem);销毁初始化的信号量 释放所有也信号量有关的资源

//练习 实现俩个线程分别输出123和ABC

相关推荐
Xxtaoaooo2 小时前
企业财务自动化实战:JiuwenSwarm 多智能体协作完成报销审核
运维·自动化·多智能体协作·jiuwenswarm·企业报销审核
Languorous.2 小时前
Linux发行版区别——CentOS、Ubuntu、Debian、Rocky怎么选?
linux·ubuntu·centos
神经网络机器学习智能算法画图绘图2 小时前
基于改进的支持向量机多分类预测研究
算法·支持向量机·分类
阿Y加油吧2 小时前
两道经典算法题复盘:最长有效括号 & 不同路径
算法
小肝一下2 小时前
5. 基础IO
android·linux·shell·基础io·操作系统底层·伊涅夫·伊雷娜
code tsunami2 小时前
如何通过Hermes Agent和CapSolver解决浏览器自动化中的CAPTCHA
运维·自动化
晚风叙码2 小时前
一文吃透二叉树:前中后序遍历+节点数+树高+叶子节点(含完整源码)
数据结构·算法
迦南的迦 亚索的索2 小时前
机器学习_05_k-means算法
算法·机器学习·kmeans
霍格沃兹测开D2 小时前
n8n + MCP:自动化工作流开始拥有“动手能力”
运维·自动化