亲宝软件园·资讯

展开

C语言线程

Gy648 人气:0

线程的概念

可以简单理解为一个正在独立运行的函数

注:

1.posix线程是一套标准吗,而不是实现

2.线程标识: phread_t,可能是整形也可能是结构体指针等

*简单介绍关于线程标识的函数*
 *pthread_equarl() ;判断两个线程标识是否相等*
*pthread_self();返回自身的线程标识* 

线程的创建

pthread_creat();

int pthread_create(

pthread_t *restrict tidp, //新创建的线程ID指向的内存单元。

const pthread_attr_t *restrict attr, //线程属性,默认为NULL

void *(*start_rtn)(void *), //新创建的线程从start_rtn函数的地址开始运行

void *restrict arg //默认为NULL。若上述函数需要参数,将参数放入结构中并将地址作为arg传入。);

线程的调度取决于调度器策略

# include<stdlib.h>
# include<pthread.h>
static void* func(void* p)
{
 puts("thread is working");
 return NULL;
}
int main()
{
  pthread_t tid;
  int err;
  puts("begin!");
  err = pthread_create(&tid,NULL,func,NULL);
  if(err)
  {
   exit(-1);
  }
  puts("end!");
  exit(0);
}

线程的终止

3种方式 :

1)线程从启动历程返回,返回值就是线程的退出码

2)线程可以被同一进程中的其他线程取消

3)线程可以调用 pthread)exit()函数

线程退出函数

void pthread_exit(void *value_ptr);

线程标识的比较

获取线程号

pthread_t pthread_self(void);

比较

int pthread_equal(pthread_t t1, pthread_t t2);

线程的取消

int pthread_cancel(pthread_t thread);

取消有两种状态 : 允许和不允许

允许取消又分为: 异步cancel , 推迟 cancel(默认) -> 推迟到cancel点

cancel点: posix定义的canceldian 都是可能引发阻塞的系统调用

pthread_setcancelstate(int );//设置是否允许取消

pthread_setcanceltype(); //设置取消方式 异步还是推迟

注:pthread_cancel 调用具有具有一定的延时性,因为cancel点: posix定义的canceldian 都是可能引发阻塞的系统调用,并不会立即被处理,不建议当线程立即被创建后立即进行cancel取消(线程创建,并不会立即被调度);也不建议在线程退出前执行线程cancel取消(线程可能在取消之前就已经退出了);建议在线程执行中进行cancel取消线程

void pthread_testcancel(void); //本函数为设置取消点

当不关心线程的返回信息时可以直接使用线程分离函数进行回收

反之,需要获取线程的返回值时,可以使用线程等待

线程等待

int pthread_join(pthread_t thread, void **value_ptr);

第一个参数是线程标识,第二是传出型参数用来获取线程的返回值

注意:

终止获取的状态情况:

线程分离

int pthread_detach(pthread_t thread);

默认情况下,新创建的线程是joinable的,线程退出后,需要对其进行pthread_join操作,否则无法释放资源,从而造成系统泄漏

如果不关心线程的返回值,join是一种负担,这个时候,我们可以告诉系统,当线程退出时,自动释放线程资源

注:

可以是线程组内其他线程对目标线程进行分离,也可以是线程自己分离:

pthread_detach(pthread_self());

joinable和分离是冲突的,一个线程不能既是joinable又是分离的

线程的分离也是具有一定延时性,分离之后如果再进行等待那么得到返回的结果是未定义的

线程分离后只是回收的时候自动进行回收,如果主线程先退出,那么整个进程也会退出;如果分离的线程执行崩溃,同样的整个进行也会崩溃

加载全部内容

相关教程
猜你喜欢
用户评论