版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/s564200489/article/details/50513018
相较于进程,线程不仅拥有进程的并发性,相互独立等特点,更有占用资源较少,效率高等特点。
创建线程
int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *(*start_routine) (void *), void *arg);
其中thread为线程ID地址
attr 为属性设置
start_routine为函数指针
arg为start_routine函数的参数
退出线程
void pthread_exit(void *retval);
其中retval为返回给主线程的参数
等待线程退出
int pthread_join(pthread_t thread, void **retval);
其中thread为线程id
retval为捕获的线程退出后的参数
实例:通过消息队列月线程实现两进程互相传送消息并打印
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <string.h>
#include <unistd.h>
#include <pthread.h>
struct msgbuf
{
long mtype;
char mtex[40];
};
int msid;
struct msgbuf msre,mswr;
void * f(void * buf)
{
while(1)//子线程
{
bzero(msre.mtex,40);
if(msgrcv(msid,&msre,sizeof(msre),100,0)==-1)//从消息队列msid中,获取类型(mtype)为100的信息,放到msre中,未获得则阻塞
{
perror("get massage fail");
exit(-1);
}
printf("massage : %s\n",msre.mtex);
if(strcmp(msre.mtex,"end")==0)
{
msgctl(msid,IPC_RMID,NULL);
exit(0);
}
printf("Please import massage or wait for massage:\n");
}
}
int main (void)
{
key_t key = ftok(".",123);
msid = msgget(key,IPC_CREAT|0666);
if(msid<0)
{
perror("get msgid fail");
return ;
}
mswr.mtype = 200;
char a[40] = {'\0'};
pthread_t id;
pthread_create(&id,NULL,f,NULL);
printf("Please import massage or wait for massage:\n");//创建线程
while(1)//主线程
{
bzero(mswr.mtex,40);
gets(a);
stpcpy(mswr.mtex,a);
if(msgsnd(msid,&mswr,strlen(mswr.mtex),0)==-1)//将mswr中的内容放到消息队列msid中放入大小为strlen,未发送则阻塞
{
perror("send fail");
return 0;
}
if(strcmp(msre.mtex,"end")==0)
{
msgctl(msid,IPC_RMID,NULL);
exit(0);
}
printf("Please import massage or wait for massage:\n");
}
pthread_join(id,NULL);
}