Linux系统编程.NO10——线程控制

8.线程控制

8.1.线程概念

1.主线程生成子线程,两者公用内数据段和代码段,不会产生内存复制,生成代价小。线程有独立的堆栈。
2.若主线程终结,则子线程也不能继续。
3.线程间通信比进程间通信消耗资源更小。
4.进程的运行稳定性更加优越。
5.线程是程序执行的最小单位,进程是资源分配的最小单位。

8.2.线程基本函数

1.int pthread_create(pthread_t *thread,const pthread_attr_t *attr,void *(start_toutine)(void),void *arg);
创建一个新线程,第一个参数用来保存线程创建成功后的新线程ID号,即任意定义一个pthread_t类型的值,不过需要取地址,attr是线程属性,默认填NULL,第三个参数是一个函数指针,指向一个函数,该函数就是新线程的执行函数,arg是该函数的参数,如果有多个参数,就以结构体的形式传入。成功返回0,失败返回错误码。
头文件是<pthread.h>
2.pthread_t pthread_self(void);
接受线程的ID,无参数,返回值是pthread_t,即线程ID.
头文件是<pthread.h>
3.void pthread_exit(void *retval);
线程退出函数,参数retval是线程结束时的返回值,由pthread_join函数接收。
头文件是<pthread.h>
4.ind pthread_join(pthread_t thread,void * * retval);
等待线程结束,thread是等待线程的ID,retval不为NULL时就是被等待线程结束时的返回值。函数返回值,成功执行返回0,错误执行返回错误码。
头文件是<pthread.h>

注意二级指针的意思是将这个空指针的地址传进入,然后函数内部会改变这个指针所指向的值

8.3.线程间通信之互斥锁

线程共享进程的空间地址,所以线程间通信要注意对于共享资源的同步与互斥,其中互斥锁就是一种实现线程间通信的方式,互斥锁其实就是一种01值,值为1有效,值为0无效。

  1. int pthread_mutex_init(pthread_mutex_t *restrict mutex,const pthread_mutexattr_t *restrict attr);
    函数功能是初始化一个互斥锁,这个函数是实现一个动态初始化,还可以静态初始化pthread_mutex_t mutex=PTHREAD_MUTEX_ INITIALIZER;初始化之后就可以使用加锁、解锁函数。
    mutex就是互斥锁,attr是互斥锁属性,NULL表示默认属性,成功返回0,失败返回错误码。
    头文件是<pthread.h>
    2.int pthread_mutex_lock(pthread_mutex_t *mutex)
    功能是对互斥锁上锁,mutex就是这个互斥锁。成功返回0,失败返回错误码。
    头文件是<pthread.h>
    3.int pthread_mutex_unlock(pthread_mutex_t *mutex)
    功能是对互斥锁解锁,mutex就是这个互斥锁。成功返回0,失败返回错误码。
    头文件是<pthread.h>
    4.int pthread_mutex_trylock(pthread_mutex_t *mutex)
    功能是尝试对互斥锁解锁,mutex就是这个互斥锁,如果失败则立刻返回,成功返回0,失败返回错误码。
    头文件是<pthread.h>
    5.int pthread_mutex_destroy(pthread_mutex_t *mutex)
    功能是注销互斥锁,参数就是将要注销的互斥锁,成功返回0,失败返回错误码。
    头文件是<pthread.h>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值