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()