多线程编程探索

一、编程之美之双线程高效下载

从网络上下载数据,单线程的工作模式是下载一块数据,写入硬盘,然后再下载,再写入硬盘,不断重复循环,直到文件下载完毕。

可对这个过程进行优化,采用双线程工作模式,一个线程提供下载,一个线程进行写入磁盘。两个线程尽量同时工作

假设所有数据块的大小固定,使用一个全局缓存区Block g_buffer[BUFFER_COUNT]

对应伪代码:

class Thread
{
public:
	Thread(void (*work_func)());
	~Thread();
	void start();
	void Abort();
};
class Semaphore
{
public:
	Semaphore(int count,int max_count);
	~Semaphore();
	void Unsignal();
	void Signal();
};
class Mutex
{
public:
	WaitMutex();
	RealeaseMutex();
};

#define BUFFER_COUNT 100
Block g_buffer[BUFFER_COUNT]

Thread g_threadA[ProcA];
Thread g_threadB[ProcB];
Semaphore g_seFull(0,BUFFER_COUNT);
Semaphore g_seEmpty(BUFFER_COUNT,BUFFER_COUNT);
bool g_downloadComplete;
int in_index=0;
int out_index=0;

void main()
{
	g_downloadComplete=false;
	threadA.start();
	threadB.start();
}
void ProcA()
{
	while(true)
	{
		g_seEmpty.Unsignal();
		g_downloadComplete=GetBloackFromNet(g_buffer+in_index);
		in_index=(in_index+1)%BUFFER_COUNT;
		g_seFull.Signal();
		if(g_downloadComplete)
			break;
	}
}
void ProcB()
{
	while (true)
	{
		g_seFull.Unsignal();
		WriteBlockToDisk(g_buffer+out_index);
		out_index=(out_index+1)%BUFFER_COUNT;
		g_seEmpty().Signal();
		if(g_downloadComplete && out_index==in_index)
			break;
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值