c 多线程?C语言能实现多线程么
亲爱的读者们,你是否对c 多线程和C语言能实现多线程么的关系感到好奇?在本文中,我将深入探讨它们之间的联系,让你对此有更深刻的理解。
c语言实现多线程
目录:
Linux操作系统,C语言实现多线程
Windows操作系统,C语言实现多线程
Windows下的多线程(不带停止)
Linux操作系统,C语言实现多线程:#include<stdio.h>
#include<stdlib.h>
#include<pthread.h>
void*ThreadOne(void*threadArg)
{
printf("线程开始啦,参数是:%s\n",(char*)threadArg);
returnNULL;
}
intmain(void)
{
pthread_tThreadID;/*记录线程标识符*/
void*waitingResult;/*等待线程退出的等待结果*/
interrorCode;/*记录线程的错误代码*/
char*aMessage="这是线程的参数";
/*创建并启动线程ThreadOne。若返回值非零,则线程创建失败*/
errorCode=pthread_create(&ThreadID,NULL,ThreadOne,aMessage);
if(errorCode!=0)
{
printf("线程ThreadOne创建失败。错误代码:%d\n",errorCode);
returnEXIT_FAILURE;
}
/*等待线程标识符为的ThreadID的线程结束*/
errorCode=pthread_join(ThreadID,&waitingResult);
if(errorCode!=0)
{
printf("等待线程退出等待失败。错误代码:%d\n",errorCode);
returnEXIT_FAILURE;
}
printf("线程的返回值是%p\n",waitingResult);
returnEXIT_SUCCESS;
}Windows操作系统,C语言实现多线程:
#include<stdio.h>
#include<windows.h>
DWORDAPIENTRYThreadOne(LPVOIDthreadArg)
{
printf("线程开始啦,参数是:%s\n",(char*)threadArg);
return0;
}
intmain(void)
{
HANDLEhThread;/*记录线程句柄*/
DWORDThreadID;/*记录线程ID号*/
DWORDwaitingResult;/*等待线程退出的等待结果*/
DWORDthreadExitCode;/*记录线程的返回值*/
char*aMessage="这是线程的参数";
/*创建并启动线程ThreadOne,返回值为线程句柄,赋值给hThread*/
hThread=CreateThread(NULL,0L,ThreadOne,(LPVOID)aMessage,0L,&ThreadID);
if(hThread==NULL)
{
printf("线程ThreadOne创建失败。错误代码:%lu\n",GetLastError());
returnEXIT_FAILURE;
}
/*等待线程句柄为的hThread线程结束*/
waitingResult=WaitForSingleObject(hThread,INFINITE);
if(waitingResult==WAIT_FAILED)
{
printf("等待线程退出等待失败。错误代码:%lu\n",GetLastError());
returnEXIT_FAILURE;
}
if(GetExitCodeThread(hThread,&threadExitCode))
printf("线程的返回值是%lu\n",threadExitCode);
else
printf("获取线程的返回值获取失败。错误代码:%lu\n",GetLastError());
returnEXIT_SUCCESS;
}Windows下的多线程:(不带停止)
#include<stdio.h>
#include<windows.h>
DWORDWINAPIduoxianchen(LPVOIDlpParam);
intmain(intargc,char*argv[])
{
intnum=0;
CreateThread(NULL,NULL,duoxianchen,&num,NULL,NULL);
while(1)
{
num++;
printf("主线程!%05d\n",nu***eep(40);
}
return0;
}
DWORDWINAPIduoxianchen(LPVOIDlpParam)
{
int*a=lpParam;
while(1)
{
++*a;
printf("副线程!%05d0x%p\n",*a,a);
Sleep(80);
}
return0;
}
c语言如何编写一个简单的多线程程序
这是一个多线程例子,里面只有两个线程,是生产者/消费者模式,已编译通过,注释很详细,\x0d\x0a如下:\x0d\x0a\x0d\x0a/*以生产者和消费者模型问题来阐述Linux线程的控制和通信你 \x0d\x0a生产者线程将生产的产品送入缓冲区,消费者线程则从中取出产品。\x0d\x0a缓冲区有N个,是一个环形的缓冲池。\x0d\x0a*/\x0d\x0a#include \x0d\x0a#include
\x0d\x0a\x0d\x0a#define BUFFER_SIZE 16\x0d\x0a\x0d\x0astruct prodcons\x0d\x0a{\x0d\x0a int buffer[BUFFER_SIZE];/*实际存放数据的数组*/\x0d\x0a pthread_mutex_t lock;/*互斥体lock,用于对缓冲区的互斥操作*/\x0d\x0a int readpos,writepos;/*读写指针*/\x0d\x0a pthread_cond_t notempty;/*缓冲区非空的条件变量*/\x0d\x0a pthread_cond_t notfull;/*缓冲区未满的条件变量*/\x0d\x0a};\x0d\x0a\x0d\x0a/*初始化缓冲区*/\x0d\x0avoid pthread_init( struct prodcons*p)\x0d\x0a{\x0d\x0a pthread_mutex_init(&p->lock,NULL);\x0d\x0a pthread_cond_init(&p->notempty,NULL);\x0d\x0a pthread_cond_init(&p->notfull,NULL);\x0d\x0a p->readpos= 0;\x0d\x0a p->writepos= 0;\x0d\x0a}\x0d\x0a\x0d\x0a/*将产品放入缓冲区,这里是存入一个整数*/\x0d\x0avoid put(struct prodcons*p,int data)\x0d\x0a{\x0d\x0a pthread_mutex_lock(&p->lock);\x0d\x0a/*等待缓冲区未满*/\x0d\x0a if((p->writepos+1)%BUFFER_SIZE==p->readpos)\x0d\x0a{\x0d\x0a pthread_cond_wait(&p->notfull,&p->lock);\x0d\x0a}\x0d\x0a p->buffer[p->writepos]=data;\x0d\x0a p->writepos++;\x0d\x0a if(p->writepos>= BUFFER_SIZE)\x0d\x0a p->writepos= 0;\x0d\x0a pthread_cond_signal(&p->notempty);\x0d\x0a pthread_mutex_unlock(&p->lock);\x0d\x0a}\x0d\x0a/*从缓冲区取出整数*/\x0d\x0aint get(struct prodcons*p)\x0d\x0a{\x0d\x0a int data;\x0d\x0a pthread_mutex_lock(&p->lock);\x0d\x0a/*等待缓冲区非空*/\x0d\x0a if(p->writepos== p->readpos)\x0d\x0a{\x0d\x0a pthread_cond_wait(&p->notempty,&p->lock);//非空就设置条件变量notempty\x0d\x0a}\x0d\x0a/*读书据,移动读指针*/\x0d\x0a data= p->buffer[p->readpos];\x0d\x0a p->readpos++;\x0d\x0a if(p->readpos== BUFFER_SIZE)\x0d\x0a p->readpos= 0;\x0d\x0a/*设置缓冲区未满的条件变量*/\x0d\x0a pthread_cond_signal(&p->notfull);\x0d\x0a pthread_mutex_unlock(&p->lock);\x0d\x0a return data;\x0d\x0a}\x0d\x0a/*测试:生产站线程将1到1000的整数送入缓冲区,消费者线程从缓冲区中获取整数,两者都打印信息*/\x0d\x0a#define OVER(-1)\x0d\x0astruct prodcons buffer;\x0d\x0avoid*producer(void*data)\x0d\x0a{\x0d\x0a int n;\x0d\x0a for( n=0;n\n",n);\x0d\x0a put(&buffer,n);\x0d\x0a}\x0d\x0a put(&buffer,OVER);\x0d\x0a return NULL;\x0d\x0a}\x0d\x0avoid*consumer(void*data)\x0d\x0a{\x0d\x0a int d;\x0d\x0a while(1)\x0d\x0a{\x0d\x0a d= get(&buffer);\x0d\x0a if(d== OVER)\x0d\x0a break;\x0d\x0a else\x0d\x0a printf("----->%d\n",d);\x0d\x0a}\x0d\x0a return NULL;\x0d\x0a}\x0d\x0aint main()\x0d\x0a{\x0d\x0a pthread_t th_p,th_c;\x0d\x0a void*retval;\x0d\x0a pthread_init(&buffer);\x0d\x0a pthread_create(&th_p,NULL,producer,0);\x0d\x0a pthread_create(&th_c,NULL,consumer,0);\x0d\x0a/*等待两个线程结束*/\x0d\x0a pthread_join(th_p,&retval);\x0d\x0a pthread_join(th_c,&retval);\x0d\x0a return 0;\x0d\x0a}
C语言能实现多线程么
可以通过调用C语言函数库pthread里的函数,创建多线程。
多线程是指程序中包含多个执行流,即在一个程序中可以同时运行多个不同的线程来执行不同的任务,也就是说允许单个程序创建多个并行执行的线程来完成各自的任务。
C语言最初并未设计多线程的机制,随着软硬件的发展及需求的发展,C语言才开发了线程库以支持多线程的操作和应用。
好了,文章到这里就结束啦,如果本次分享的c 多线程和C语言能实现多线程么问题对您有所帮助,还望关注下本站哦!