pthread 线程

1.线程的创建

  int ret  = pthread_create(&thdid,NULL,th_func,void *p);

  

 th_func 执行程序任务  创建成功返回 0

  thid --->pthread_t 是线程号,在这里做传出参数。

   p 是th_func 的参数,使用时需要强制转换为void *

void* thread(void* p)
{ //线程的开始
    int i=(int)p;//强制转换为整型
    printf("I am child thread %d\n",i);
    while(1);
}//线程结束

int main()
{
    pthread_t th_id;
    int ret=pthread_create(&th_id,NULL,thread,(void*)5);//创建线程,将数值放入指针内
    if(ret!=0)
    {
        printf("pthread_create failed ret=%d\n",ret);
        return -1;
    }
    while(1);
    return 0;
}

2.线程等待

  void* p1;
  int ret = pthread_join( th_id, &p1 );//int pthread_join(pthread_t,void **p);

  这里void *p1是上面所用的线程在退出时用pthread_exit时的参数,在这里也做传出参数使用。thid自然就是其等待的线程id

ex:

#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
//创建线程,通过pthread_join拿到我们的线程的返回值

//线程函数
void* thread(void* p)
{ //线程的开始
    strcpy((char*)p,"hello");
    printf("I am child thread\n");
    printf("child p is %p\n",p);
    pthread_exit(p);//通过pthread_exit实现线程退出,没有返回值,就写pthread_exit(NULL);
}//线程结束

int main()
{
    pthread_t th_id;
    void* p=malloc(20);
    printf("p is %p\n",p);
    int ret=pthread_create(&th_id,NULL,thread,p);//创建线程,将数值放入指针内
    if(ret!=0)
    {
        printf("pthread_create failed ret=%d\n",ret);
        return -1;
    }
    void* p1;
    ret=pthread_join(th_id,&p1);
    if(ret!=0)
    {
        printf("pthread_join failed ret=%d\n",ret);
        return -1;
    }
    printf("main thread %s\n",(char*)p);
    printf("main thread p1=%p\n",p1);
    return 0;
}

3.线程退出

  pthread_exit(void *);一般在子线程结束需要传出参数时使用;

void* thread(void* p)
{ //线程的开始
    strcpy((char*)p,"hello");
    printf("I am child thread\n");
    printf("child p is %p\n",p);
    pthread_exit((void*)0);//通过pthread_exit实现线程退出,没有返回值,就写pthread_exit(NULL);
}//线程结束

4.线程申请内存问题

  子线程申请内存后,当子线程推出后,其他线程仍然可以使用内存。

时间: 2024-08-05 09:26:00

pthread 线程的相关文章

【C/C++多线程编程之四】终止pthread线程

多线程编程之终止pthread线程  Pthread是 POSIX threads 的简称,是POSIX的线程标准.           终止线程似乎是多线程编程的最后一步,但绝不是本系列教材的结束.线程创建到线程终止,希望先给读者一个关于多线程编程的总体认识.           1.终止Pthread线程:pthread_exit()           參数:           ret:地址指针,本质上是返回值写入的地址.           终止线程是线程的主动行为,一个线程调用pth

【C/C++多线程编程之五】pthread线程深入理解

多线程编程之pthread线程深入理解  Pthread是 POSIX threads 的简称,是POSIX的线程标准. 前几篇博客已经能给你初步的多线程概念.在进一步学习线程同步等多线程核心知识之前,须要对多线程深入的理解.非常多人忽略或者回避这部分内容,直接的问题是学习者无法把握多线程编程的内在原理,理解的层次太浅.           1.进程资源:                      进程资源有存储资源与其它资源.其它资源包括环境变量.地址,文件等.存储资源.进程的内存分配,博客[

【C/C++多线程编程之十】pthread线程私有数据

多线程编程之线程私有数据 Pthread是 POSIX threads 的简称,是POSIX的线程标准.  线程同步从互斥量[C/C++多线程编程之六]pthread互斥量,信号量[C/C++多线程编程之七]pthread信号量,条件变量[C/C++多线程编程之八]pthread条件变量,读写锁[C/C++多线程编程之九]pthread读写锁,多线程的同步机制已经有了清晰深入的探究,多线程编程的精髓所在,需要深入理解.        线程私有数据TSD(Thread-specific Data)

分享一个关于pthread线程栈在mm_struct里面的分布问题

大家好,本人被下面这个问题困扰了一段时间,最近似乎找到了答案. 这里和大家分享一下,可能对有相同困惑的同学有点帮助,同时也请各位帮忙看看错漏的地方. 1================问题: 在使用pthread库创建两个线程时clone()被调用了两次,可以用strace 看到: int main() { ...         err=pthread_create(&tid, NULL, job, NULL);         err=pthread_create(&tid1, NUL

多线程编程之pthread线程深入理解

不同的平台和操作系统上 进程和线程的实现机制不完全一致  但是一般来说线程栈都是独立的 只要得到地址就可以相互访问  Pthread是 POSIX threads 的简称,是POSIX的线程标准. 前几篇博客已经能给你初步的多线程概念,在进一步学习线程同步等多线程核心知识之前,需要对多线程深入的理解.很多人忽略或者回避这部分内容,直接的问题是学习者无法把握多线程编程的内在原理,理解的层次太浅.             1.进程资源:                      进程资源有存储资源与

pThread线程(二) 线程同步--互斥量/锁

互斥量(Mutex)是“mutual exclusion”的缩写.互斥量是实现线程同步,和保护同时写共享数据的主要方法. 互斥量对共享数据的保护就像一把锁.在Pthreads中,任何时候仅有一个线程可以锁定互斥量,因此,当多个线程尝试去锁定该互斥量时仅有一个会成功.直到锁定互斥量的线程解锁互斥量后,其他线程才可以去锁定互斥量.线程必须轮着访问受保护数据. 一个拥有互斥量的线程经常用于更新全局变量.确保了多个线程更新同样的变量以安全的方式运行,最终的结果和一个线程处理的结果是相同的.这个更新的变量

pThread线程(三) 线程同步--条件变量

条件变量(Condition Variables) 参考资料:http://game-lab.org/posts/posix-thread-cn/#5.1 条件变量是什么? 条件变量为我们提供了另一种线程间同步的方法,然而,互斥量是通过控制线程访问数据来实现同步,条件变量允许线程同步是基于实际数据的值. 如果没有条件变量,程序员需要让线程不断地轮询,以检查是否满足条件.由于线程处在一个不间断的忙碌状态,所以这是相当耗资源的.条件变量就是这么一个不需要轮询就可以解决这个问题的方法. 条件变量总是跟

pthread线程特定数据

线程特定数据,也被称为线程私有数据,是一种存储和查找一个特定线程相关数据的机制.我们称这个数据为线程特定或线程私有的原因,是因为每个线程访问它自己独立的数据拷贝,而不用担心和其它线程的访问的同步. 线程特定数据看似很复杂,其实我们可以把它理解为就是一个索引和指针.key结构中存储的是索引,pthread结构中存储的是指针,指向线程中的私有数据,通常是malloc函数返回的指针. POSIX要求实现POSIX的系统为每个进程维护一个称之为Key的结构数组(如图1所示),这个数组中的每个结构称之为一

pthread线程初始化(pthread_once)

pthread_once 语法 int pthread_once(pthread_once_t *once_control, void (*init_routine)(void)); #include <pthread.h> pthread_once_t once_control = PTHREAD_ONCE_INIT; int ret; ret = pthread_once(&once_control, init_routine); once_control 参数用来确定是否已调用相