pthread_create thread删除
时间: 2024-04-27 16:17:42 浏览: 50
pthread_create是一个函数,用于创建一个新的线程。它的原型如下:
```c
int pthread_create(pthread_t *thread, const pthread_attr_t *attr,
void *(*start_routine) (void *), void *arg);
```
其中,`thread`是一个指向pthread_t类型的指针,用于存储新线程的标识符;`attr`是一个指向pthread_attr_t类型的指针,用于设置新线程的属性;`start_routine`是一个指向函数的指针,该函数将作为新线程的入口点;`arg`是传递给`start_routine`函数的参数。
创建线程后,新线程将开始执行`start_routine`函数,并且可以使用传递给它的参数`arg`。线程的执行可以在任何时候被其他线程中断或者结束。
关于线程删除,通常使用pthread_join函数来等待一个线程的结束并回收其资源。其原型如下:
```c
int pthread_join(pthread_t thread, void **retval);
```
其中,`thread`是要等待的线程的标识符;`retval`是一个指向指针的指针,用于存储线程的返回值。
调用pthread_join函数会阻塞当前线程,直到指定的线程结束。一旦线程结束,它的返回值将被存储在`retval`指向的位置。
需要注意的是,如果不关心线程的返回值,可以将`retval`参数设置为NULL。
相关问题
pthread_create,pthread_join和pthread_exit
pthread_create是一个函数,用于创建一个新的线程。它接受四个参数:指向pthread_t类型的指针thread,指向pthread_attr_t类型的指针attr,指向一个函数的指针start_routine和一个参数arg。start_routine是线程的入口函数,它接受一个void类型的指针参数并返回一个void类型的指针。pthread_create函数成功时返回0,失败时返回错误编号。
pthread_join是一个函数,用于等待一个线程的结束。它接受两个参数:pthread_t类型的参数thread和一个void类型的指针rval_ptr。rval_ptr用于获取线程的返回值。pthread_join函数会阻塞调用线程,直到指定的线程结束。成功时返回0,失败时返回错误编号。
pthread_exit是一个函数,用于终止当前线程。它接受一个void类型的指针参数rval_ptr,用于指定线程的返回值。调用pthread_exit函数会立即终止当前线程,并将指定的返回值传递给等待该线程的线程。它类似于进程的exit函数。pthread_exit函数不会返回任何值。
pthread_t *thread是一个指向pthread_t类型的指针,它用于存储线程的ID。可以使用pthread_self函数获取当前线程的ID,类似于使用getpid函数获取进程的ID。
综上所述,pthread_create用于创建新线程,pthread_join用于等待线程的结束,pthread_exit用于终止当前线程。
#include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <string.h> #include <pthread.h> #include <semaphore.h> void * pthread_odd_function(void * arg); void * pthread_even_function(void * arg); pthread_mutex_t work_mutex; pthread_cond_t work_cond; #define MAX_COUNT 10 int count = 0; int main(int argc, char const *argv[]) { pthread_t pthread_odd; pthread_t pthread_even; pthread_attr_t pthread_attr; int res; res = pthread_attr_init(&pthread_attr);//init pthread attribute,step 1 if (res != 0){ perror("pthread_attr_init failed!"); exit(EXIT_FAILURE); } res = pthread_cond_init(&work_cond,NULL); if (res != 0){ perror("pthread_cond_init failed!"); exit(EXIT_FAILURE); } res = pthread_mutex_init(&work_mutex,NULL); if (res != 0){ perror("pthread_mutex_init failed!"); exit(EXIT_FAILURE); } pthread_attr_setdetachstate(&pthread_attr,PTHREAD_CREATE_DETACHED);//design pthread attribute step 2 res = pthread_create(&pthread_odd,&pthread_attr,pthread_odd_function,NULL);//step 3 if (res != 0){ perror("pthread_create failed!"); exit(EXIT_FAILURE); } res = pthread_create(&pthread_even,&pthread_attr,pthread_even_function,NULL); if (res != 0){ perror("pthread_create failed!"); exit(EXIT_FAILURE); } while(count < MAX_COUNT) ; //wait the two sons threads finished pthread_mutex_destroy(&work_mutex); pthread_cond_destroy(&work_cond); pthread_exit(NULL); return 0; } void * pthread_odd_function(void *arg)//step 4 { pthread_mutex_lock(&work_mutex); while(count < MAX_COUNT){ if (count % 2 == 1){ printf("the odd count is : %d\n", count); ++count; pthread_cond_signal(&work_cond);//in order to release the thread of even } else pthread_cond_wait(&work_cond,&work_mutex);//the pthread is blocked,wait for the condition } pthread_mutex_unlock(&work_mutex); } void * pthread_even_function(void *arg)//step 5 { pthread_mutex_lock(&work_mutex); while(count < MAX_COUNT){ if (count % 2 == 0){ printf("the even count is : %d\n", count); ++count; pthread_cond_signal(&work_cond);//in order to release the thread of odd } else pthread_cond_wait(&work_cond,&work_mutex);//wait the condition satisfied } pthread_mutex_unlock(&work_mutex); }给我讲一下这段代码
这段代码是一个线程同步的例子,它创建了两个线程,一个线程打印出所有奇数,另一个线程打印出所有偶数。具体来说,代码中使用了互斥锁和条件变量来保证线程同步。互斥锁的作用是保护共享资源,只允许一个线程访问该资源。条件变量用于线程之间的通信,当一个线程需要等待某个条件满足时,它会进入阻塞状态,等待其他线程发送信号通知它条件已满足。
在主函数中,先初始化了互斥锁和条件变量,然后创建了两个线程,并使用pthread_attr_setdetachstate函数将线程属性设置为PTHREAD_CREATE_DETACHED,表示线程被创建后马上就进入分离状态,不需要等待其他线程回收资源。接着主线程进入一个循环,等待两个子线程执行完毕。
在子线程中,先获取互斥锁,进入while循环,判断count是否小于最大值,如果是,则进入条件判断。奇数线程打印出奇数并将count加1,然后调用pthread_cond_signal函数发送信号通知偶数线程可以执行了。偶数线程同样进入条件判断,打印出偶数,将count加1,然后调用pthread_cond_signal函数通知奇数线程可以执行了。如果条件不满足,则调用pthread_cond_wait函数将线程阻塞,等待其他线程发送信号通知它条件已满足。最后释放互斥锁,线程结束。
值得注意的是,条件变量的使用必须与互斥锁一起使用,否则可能会出现竞争条件,导致程序出现错误。
阅读全文