2、主要以 pthread_开头,在用gcc来build时要加上-lpthread选项。
3、头文件在
4、 一个进程中的大部分东西都是多个线程共享的,但是一下东西在每个线程是独立的:线程id号,寄存器集合,用于保存局部变量和返回地址的堆栈,errno, 信号掩码,运行的优先级。
5、5个函数:
a、int pthread_create(pthread_t *tid, const pthread_attr_t *attr, void*(*func)(void*), void *arg); 相当于fork函数。
注 意成功返回0,线程id通过tid返回。
一般情况下,attr只需要传递空指针即可,(属性用系统默认的就足够了)
注 意:func是线程调用的函数,参数是通用指针void*,返回也是通用指针void*,arg是该函数的参数。
b、int pthread_join(pthread_t tid, void **status); 相当于waitpid函数
等待tid线程终 止,如果status非空,则tid线程终止的返回值将传到*status地方。
c、pthread_t pthread_self(void); 相当于getpid函数。
d、int ptrhead_detach(pthread_t tid)
线程状态或者是可汇合的(joinable),或者是可脱离的(detached)(默认为可汇合的)
脱离的线 程像守护进程(daemon):所有的资源将会被释放,因此不能用pthread_join等待其终止。
一般用法,使自己脱 离:pthread_detach(pthread_self());
e、void pthread_exit(void *status)
如果该线程未脱离,则其线程id和推出状态一直保留到某个线程调用pthread_join为止。
终止线程的其 他情况:
启动线程的func函数调用return 或者是 本进程的main函数返回 或者 某个线程调用了exit(这种情况本进程及其所有线程都终止)
===============================================================================
今 天写了个程序,但是很郁闷的是没有得到预想的结果:
pthread_t tid;
int main(void)
{
pthread_attr_t attr;
pthread_attr_init(&attr);
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
pthread_create(&attr, &tid, func, NULL);
pthread_attr_destroy(&attr);
printf("Main route exit.\n");
return 0;
}
void * func(void *args)
{
int i=0;
for(; 1;)
printf("Thread: i is %d\n", i);
return ((void *)0);
}
运行结果为,一直打印Thread:i,过了1s左右,打印Main route exit.然后所有打印结束了。
但是用detach方法新建thread,不是应该和主线程分离的么?想不同了。
------------------------------------------
ok, 还是贴一下pthread常用的几个方法,以免遗忘了。
#include
int pthread_create(struct pthread_attr_t *, pthread_t *, void *f*(void *), void *);
创建一个线程,f为线程函数。默认情况下线程属性为joinable,即当主线程退出时,线程也会退出。
int pthread_join(pthread_t, void **);
主线程阻塞直到这个thread结束后才继续往下走。这里第二个参数接收线程退出的返回值。
int pthread_exit(void);
线程自己主动退出。
int pthread_cancel(pthread_t);
被动退出。一个线程结束另外一个线程的运行。这里包括同步退出(默认),即线程立刻结束。
以及异步退出,即线程直到下一个cancellation point才退出。线程可以设置这样的cancellation point,
当然也可以设置为不被其他线程命令退出。
int pthread_self(void);
得到自己的thread id。
----------------------------------------
编译时需要加上-lpthread选项。
另外,发现c99不允许在for中直接声明变量,厄。。。