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无效。
- 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>