美文网首页
linux-14-线程---end

linux-14-线程---end

作者: vera姐姐 | 来源:发表于2016-05-23 12:48 被阅读24次

    1.1线程的概念

    线程-隶属于进程,是进程中的程序流

    在操作系统中支持多进程的,而每个进程的内部支持多个线程,多个线程并行

    进程是重量级单位,每个进程都需要独立的内存空间等资源,新建进程对于资源的消耗比较大,线程是轻量级的,不需要申请独立的内存等资源,但是每个线程也有一个独立的栈区,线程实际上更多的是共享进程中的资源

    1.2 线程的相关函数

    1)pthread_create函数

    pthread_create(pthread_t *thread,const pthread_attr_t *attr,void *(*start_routine) (void*),void *arg);

    第一个参数:用于存放线程id

    第二个参数:线程的属性,直接给0即可

    第三个参数:线程所调用的函数

    第四个参数:给线程调用函数传递的实参

    返回值:成功返回0,失败返回错误编号

    函数功能:用于创建一个新的线程

    注意:1)在编译链接时需要加选项 -lpthread

    2)但程序结束时,所有子线程都结束了

    创建出来的线程与主线程具有同等的优先级,不一定谁先执行

    2)pthread_join函数

    int pthread_join(pthread,void **retval);

    第一个参数:指定所要等待的线程id

    第二个参数:用于接受所等待线程的退出码返回值:成功返回0,失败返回错误编号函数功能:等待thread所指向的线程结束

    3)pthread_self函数#includepthread_tpthread_self(void);功能:获取正在执行的线程id,返回值就是线程的id

    4)pthread_exit函数#includevoid pthread_exit(void *retval);

    参数:用于返回一个数据

    功能:终止正在调用的线程

    exit函数,用于终止一个进程

    1.3线程的状态线程有两种状态

    1)非分离状态 pthread_join对于非分离状态的线程来说,线程资源的回收需要等到join函数结束之后

    2)分离状态 pthread_detach对于分离状态的线程来说,线程结束后资源马上回收,无法使用pthread_join函数等待的

    3)pthread_detach函数

    int pthread_detach(pthread_t thread);

    参数:线程id

    返回值:成功返回0,失败返回错误编号

    功能:用于分离线程

    2.线程

    2.1线程的取消1)pthread_cancel函数

    int pthread_cancel(pthread_t thread);

    参数:要取消的线程id

    回值:成功返回0,失败返回错误编号

    功能:对thread指向的线程发送取消的请求

    2)pthread_setcancelstate函数

    int pthread_setcancelstate(int state,int *oldstate);

    第一个参数:设置取消状态


    第一个参数:设置取消状态

    PTHREAD_CANCEL_ENABLE 可以被取消

    PTHREAD_CANCEL_DISABLE 不可以被取消

    第二个参数:带出原来的取消状态

    返回值:成功返回0;失败返回错误编号

    函数功能:设置线程是否允许被取消

    3)pthread_setcanceltype函数

    int pthread_setcanceltype(int type,int *oldtype);

    第一个参数:设置新的类型

    PTHREAD_CANCEL_DEFERRED 推到下一个取消点 取消

    PTHREAD_CANCEL_ASYNCHRONOUS 立即取消

    第二个参数:带出原来的取消类型

    返回值:成功返回0;失败返回错误编号

    函数功能:设置线程何时被取消

    2.2 线程的同步

    1)概念:

    多线程之间共享进程的资源,多个线程同时访问相同的资源时,需要相互协调,以防止出现数据的不一致和不完整的问题,线程之间的协调和通信 叫做 线程的同步

    2)线程同步的思路

    访问共享资源时,不能并行,而是创新

    3)线程同步的解决方案

    在线程中,提供了互斥量(互斥锁)实现线程同步

    4)使用互斥量实现线程同步的步骤

    a 定义互斥量

    pthread_mutex_t lock;

    b 初始化互斥量

    pthread_mutex_init(&lock,0);

    c 使用互斥量进行加锁

    pthread_mutex_lock(&lock);

    d 使用共享资源

    e 使用互斥量进行解锁

    pthread_mutex_unlock(&lock)

    f 销毁互斥量

    pthread_mutex_destroy(&lock)

    5)使用信号量实现线程的同步

    信号量 --就是一个计数器,用于控制同时访问共享资源的进程/线程数,如果信号量的值是1,等同于互斥量

    使用信号量实现线程同步的流程

    a 定义信号量

    sem_t sem;

    b 初始化信号量

    sem_init(&sem,o/*控制线程*/,最大值/*个数*/);

    c 获取一个信号量(相当于计数器减1)

    sem_wait(&sem);

    d 访问共享资源

    e 释放一个信号量(相当于计数器加1)

    sem_post(&sem)

    f 销毁信号量

    sem_destory(&sem)

    6)条件变量 以及 生产者-消费者模型 DMS项目

    相关文章

      网友评论

          本文标题:linux-14-线程---end

          本文链接:https://www.haomeiwen.com/subject/opbgrttx.html