线程

posix线程标准  pthread_t  类型未知,不一样实现不一样

int pthread_equal(pthread_t,pthread_t)比较线程标识

pthread_t pthread_self(void)   /  pid_t getpid() 

 int pthread_create(pthread_t *thread,pthread_attr_t *attr,void *(*start_routine)(void *),void *arg) 正常返回0,出错返回errno

errno是全局变量,可能自己还没来得及使用别的地方就修改了,返回errno就不会这样的问题 (这句话不一定对,好像errno是一个宏)

线程终止:

1.线程从启动例程返回,返回值就是线程的退出码

2.可以被其他线程取消

3.void pthread_exit(void *retval) 线程退出用,线程清理 /   exit()


int pthread_join(pthread_t thread,void **retval) 收尸 / wait()


栈清理:

void pthread_cleanup_push(void (*routine)(void *),void *arg)

pthread_cleanup_pop(int execute)

这2个是宏,得成对出现,不然语法出错


线程取消:

int pthread_cancel(pthread_t thread)

取消有2种状态:允许和不允许

取消方式:异步cancel,推迟到cancel点(默认)

cancel点:posix定义的cancel点是可能引发阻塞的系统调用,如open

int pthread_setcancelstate(int state,int *oldstate) 设置是否允许取消

int pthread_setcanceltype()设置取消方式

void pthread_testcancel(void)本函数什么都不做就是一个取消点


线程分离:

int pthread_detach(pthread_t thread)线程可以自己消亡自己结束,不能pthread_join来收尸了


先读文件 +1 写回去的时候,写的时候要fseek到文件起始位置


线程同步

互斥量,保护临界资源:

pthread_mutex_t

pthread_mutex_init() 分动态初始化,PTHREAD_MUTEX_INITIALIZER静态初始化

pthread_mutex_destroy()

pthread_mutex_lock() 

pthread_mutex_trylock()

pthread_mutex_unlock()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值