最近自己写了一个类似网络蚂蚁和FlashGet一样的程序,主要是为了自己能学点东西,不过还好,已经有点样子了,已经实现了类似它们的界面风格和功能,只是里面的下载任务、错误任务、已完成任务、中止任务的调度问题还没有详细去做,通过IE右键菜单的传参数还没有解决,IE右键菜单已经现,已经能够取到鼠标位置的URL,只是不知如何将取得的一个URL传给下载程序,还有待解决。现在将多线程下载同一个文件的原理讲述一下:
1、首先得到要下载的文件的长度,这是通过Http的HEAD命令得到其长度。
2、根据长度和线程数,确定各线程所下载的数据范围。通过HTTP的Get命令,这里需要指定From和To.
3、创建一个文件,这个文件是一个空文件,不需要事先生成与下载文件同样大小的空文件。给每个线程只需要传递其打开的文件句柄即可。
4、创建各个下载线程,每个线程接受到数据后就保存到相应的位置上去。这里不需要对文件加锁,因为操作系统一级本身对文件的I/O有锁的,我们的应用不用管,而且各个线程所写的文件位置是不一样的,每一线程负责下载和写一段数据。每个线程都记录下来了当前已经下载到的位置,这样若有线程出错了,可以从断点处继续下载。
5、等各线程都下载完各自的数据块后,最后中关闭这个文件。
注意:这里的文件打开时一定要以二制打开,否则在调用fseek时将导致位置定位不正确。
FILE *f;
if(( f = fopen(szFileName, "wr") != NULL)
{
...............................;
fclose(f);
}