C -线程

来源:互联网 发布:网络传输介质各自特点 编辑:程序博客网 时间:2024/06/05 03:00

编译器的一些知识

xcode编译器介绍
gnu ,gcc ,clang ,llvm区别与联系

线程的生命周期

线程的生命周期

主线程

1.  main函数执行时候,主线程启动, 当main函数退出时候,主线程结束。同时,进程内所有的线程也会结束,主线程中调用pthread_exit ,此时, 主线程会等待所有线程完成之后结束。2.  主线程接受参数的方式为argc, argv ,一般线程接受参数的方式为void*  (void * 为任意类型指针,是否相当于c中的id类型。)3.  绝大多数情况下 ,主线程在一个默认的堆栈上执行,其大小将会增长到足够的长度 ,而一般的线程是受限制的 ,一旦溢出 ,会出错。

线程的创建

1. 主线程在进程创建时候创建。2. 一般线程会通过调用函数pthread_create来进行创建 。3. ***新的线程可能在pthread_create返回之前已经开始运行, 甚至新的线程会在当前pthread_create函数返回之前已经运行完毕了。***

线程的状态

  1. 线程的4种状态
状态 含义 就绪 线程能够运行,但是在等待可用的处理器 运行 线程正在运行,在多核处理器中,可能同时多个线程运行 阻塞 线程在等待处理器以外的其他条件 终止 线程从启动函数中返回 ,或调用pthread_exit函数 ,或被取消

2. 线程的回收
1. 线程的分离属性 :分离一个线程时候,并不影响他,而是通知当前系统线程结束时候,其所使用的资源可以回收。没有被分离的进程终止时候回保留它的虚拟 ,保留堆栈信息和其他系统资源 ,这种线程成为‘僵尸线程’ ,线程
2. 终止被分离的线程会释放所有的系统资源,但是你必须释放由该线程占有的程序资源。由malloc或者mmap分配的内存可以在任何时候由任何线程释放,条件变量、互斥量、信号灯可以由任何线程销毁,只要他们被解锁了或者没有线程等待。但是只有互斥量的主人才能解锁它,所以在线程终止前,你需要解锁互斥量

线程有两种退出方式,有可能自己退出的,这是正常的退出方式,也有可能是非正常退出的,例如被其他线程取消,试想一下,如果一个线程已经上锁了,还没解锁就被其他线程取消了,那这个锁就一直锁着,没办解开。因为就需要在互斥锁上锁前使用pthread_cheanup_push(),这个函数可以在线程在非正常退出时,丢用指定函数来进行相应操作(解锁)若线程并没有在互斥锁上锁时被非正常退出,就要调用 pthread_cleanup_pop()来取消pthread_cleanup_push()的操作。pthread_cleanup_pop一般用再解锁之后所以这两个函数都是一对出现的
每个线程之间的栈是相互独立的,每个线程都拥有自己的栈区,虽然说它们的栈都是从进程空间的栈中分配的并且共享进程的栈,但是在创建线程的时候,每个线程都从进程栈区那儿获得一个私有的栈区。