如何在Windows下编写基于Posix标准的多线程程序

如何在Windows下编写基于Posix标准的多线程程序,第1张

在Windows下编写基于Posix标准的多线程程序的方法:

1、进入pthread-win32开源库官网,单击pthread-win32-2-9-1-release.zip进行下载

2、下载后的文件解压缩后,进行二次开发只需要里面的Pre-built.2文件夹里面的内容

Pre-built.2文件夹下面有:dll(程序运行时需要的动态运行卜猜时库),

include(程序编写时利用的头码清文件),

lib(程序连接过程中需要的静态库)

3、建立code

blocks下的C工程,工程结构,包括main.c测试代码

codeblocks的工程配置,型模型右键工程名选择build

options,配置linker

settings,与search

direction里面的compiler选项

编写main.c,代码如下:

#include

"pthread.h"#include

<stdio.h>void*

func(void

*

Parame){

printf("I

am

Child

Thread\n")

return

NULL}int

main(){

printf("Pthread

Test

Begin\n")

pthread_t

pid

pthread_attr_t

attr

pthread_attr_init(&attr)

pthread_attr_setscope(&attr,

PTHREAD_SCOPE_PROCESS)

pthread_attr_setdetachstate(&attr,

PTHREAD_CREATE_DETACHED)

pthread_create(&pid,

&attr,

func,

NULL)

getchar()

pthread_attr_destroy(&attr)

return

0}

在生成的exe文件所在同级目录下应该自己添加前文所说的dll文件,否则无法运行。

使用线程间通信,在才确定的代码位置使用mutex就可以完成你所要的功能。

线程互斥

互斥意味着“排它”,即两个线程不能同枣神时进入被互斥保护的代码。Linux下可以通过pthread_mutex_t 定义互斥体机制完成多线程的互斥 *** 作,该机制的作用是对某个需要互斥的部分,在进入时先得到互斥体,如果没有得到互斥体,表明互斥部分被其它线程拥有,此时欲获取互斥体的线程阻塞,直到拥有该互斥体的线程完成互斥部分的 *** 作为止。

下面的代码实现了对共享全局变量x 用互斥体mutex 进行保护的目的:

int x// 进程中的全局变量

pthread_mutex_t mutex

pthread_mutex_init(&mutex, NULL)//按缺省的属性初始化互斥体变量mutex

pthread_mutex_lock(&mutex)// 给互斥体变量加锁

… //对变量x 的 *** 作

phtread_mutex_unlock(&mutex)// 给互斥体变量解除锁

线程同步

同步就是线程等待某个事件的发生。只有当等待的事件发生线程才继续执行,否则线程挂起并放弃处理器。当多个线程协作时,相互作用的任务必须在一定的条件下同步。

Linux下的C语言编程有多种线程同步机制,最典型的是条件变量(condition variable)。pthread_cond_init用来创建一个条件变量,其函数原型为:

pthread_cond_init (pthread_cond_t *cond, const pthread_condattr_t *attr)

pthread_cond_wait和pthread_cond_timedwait用来等待条件变量被设置,值得注意的是这两个等待调用需要一个已经上锁的互斥体mutex,这是为了防止在真正进入等待状态之前别的线程有可能设置该条件变量而产生竞争。pthread_cond_wait的函数原型为:

pthread_cond_wait (pthread_cond_t *cond, pthread_mutex_t *mutex)

pthread_cond_broadcast用于设置条件变量,即使得事件发生,这样等待该事件的线程将不再阻塞:

pthread_cond_broadcast (pthread_cond_t *cond)

pthread_cond_signal则用于解除某一个等待线程的阻塞状态:

pthread_cond_signal (pthread_cond_t *cond)

pthread_cond_destroy 则用于释放一个条件变量的资源。

在头文件semaphore.h 中定义的信号量则完成了互斥体和条件变量的封装,按照多线程程序设计中访问控制机制,控制对资源的同步访问,提供程序设计人员更方便的调用接口。

sem_init(sem_t *sem, int pshared, unsigned int val)

这个函数初始化一个信号量sem 的值为val,参数pshared 是共享属性控制,表明是否在进程间共享。

sem_wait(sem_t *sem)

调用该函数时,若sem为无状态,调用线程阻塞,等待信号量sem值增加(post )成为有信号状态;若sem为有状态,调用线程顺序执行,但信号量的值减一凳辩亏。

sem_post(sem_t *sem)

调用该函数,信号量灶液sem的值增加,可以从无信号状态变为有信号状态。

出其不意

福兮祸所伏

暗于大理

不耻下问

可以攻玉

不成人之恶

非为礼也

不知其可也

耳不能两听而聪

师肢掘敬不必不如弟子

成事在天

无以至千里,无以成江海

然后知松柏而后凋也

乐散型以忘忧,不知老之将至

其死也坚强

必有近忧

从善如流

后生可畏的实在不知,所以历慎空了~~


欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/yw/12443779.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-23
下一篇2023-05-23

发表评论

登录后才能评论

评论列表(0条)

    保存