semaphore实现浏览器的读写原理

本文探讨了在编程范式中使用信号量解决并发问题的方法,通过实例展示了如何利用信号量实现线程间的同步与互斥操作。

      在编程范式中的斯坦福大学的老师说了一个例子:好比世界上就只有一台互联网的服务器,当我们浏览网页的时候,就好比服务器进行了写操作,而浏览器则进行了读操作。

我如果用简单的伪代码c++写出来是这个样子的:

int  main(){
ITP(false);
ThreadNew("write",write,0);
ThreadNew("Reader",reader,0);

RunAllThread();

void writer(){
	for(int i=0;i<40; i++){
			char = PrepareRandom();
			buffer[i/8] = c;

	}
void reader(){
	for(int i=0; i<40; i++){
		char c = buffer[i%8];

		Processchar(c);

	}

}

}


}

用信号量的解决办法代码如下:

int  main(){

char buffer[8];
Semaphore emptyBuffer = (9);
Semaphore fullBuffer = (0);

ITP(false);
ThreadNew("write",write,0);
ThreadNew("Reader",reader,0);

RunAllThread();

void writer(){
	for(int i=0;i<40; i++){
			
			char c= PrepareRandom();
			semaphoreWait(emptyBuffer);  //Wait on the specified semaphore
			buffer[i/8] = c;
                        semaphoreSignal(fullbuffer);

	}
void reader(){
	for(int i=0; i<40; i++){
                semaphoreWait(fullbuffer);
		char c = buffer[i%8];

		Processchar(c);
	        semaphoreSignal(emptyBuffer);//Increments the semaphore count
	}

}

}


}


CSemaphore semaphore(1,2)中1为信号量的初始值(即此时只允许1个线程能拥有此信号量,当然这个值在0和

最大值之间可以增加或减小),2为信号量的最大值(也就是最大线程访问数目),比如此处设为2,表示此信号量最多只允许俩个线程同时拥有它,其它线程想要获得此信号量的

话只能等待这两个线程释放此信号量。


评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值