- 1、本文档共42页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
BT软件下载开发完整版01
Linux系统下的C编程
13.4.8 缓冲管理模块的设计和实现
缓冲管理模块维护一个大小为16MB 的缓冲区(大小可调整),将下载到的数据先保存在缓
冲区中,在达到一定的数值时再将数据写入硬盘的文件中。peer请求数据时,先在缓冲区中寻找,
若缓冲区中不存在所请求的数据,则读文件并把请求数据所在的 piece预先读入到缓冲区中。除
了管理缓冲区,本模块还负责创建待下载的文件,把下载到的piece写入文件,在peer请求数据
时读文件。本模块由data.h和data.c构成。
data.h
#ifndef DATA_H
#define DATA_H
#include peer.h
// 每个Btcache 结点维护一个长度为16KB 的缓冲区,该缓冲区保存一个slice 的数据
typedef struct _Btcache {
unsigned char *buff; // 指向缓冲区的指针
int index; // 数据所在的piece 块的索引
int begin; // 数据在piece 块中的起始位置
int length; // 数据的长度
unsigned char in_use; // 该缓冲区是否在使用中
unsigned char read_write; // 是发送给peer 的数据还是接收到的数据
// 若数据是从硬盘读出,read_write 值为0
// 若数据将要写入硬盘,read_write 值为1
unsigned char is_full; // 缓冲区是否满
unsigned char is_writed; // 缓冲区中的数据是否已经写入到硬盘中
int access_count; // 对该缓冲区的访问计数
struct _Btcache *next;
} Btcache;
Btcache* initialize_btcache_node(); // 为Btcache 结点分配内存空间并进行初始化
int create_btcache(); // 创建总大小为16K*1024 即16MB 的缓冲区
void release_memory_in_btcache(); // 释放data.c 中动态分配的内存
int get_files_count(); // 获取种子文件中待下载的文件个数
int create_files(); // 根据种子文件中的信息创建保存下载数据的文件
// 判断一个Btcache 结点中的数据要写到哪个文件以及具体位置,并写入
int write_btcache_node_to_harddisk(Btcache *node);
// 从硬盘读出一个slice 的数据存放到缓冲区中,在peer 需要时发送给peer
// 要读入的slice 的索引,index、begin、length 已存到node 所指向的结点中
int read_slice_from_harddisk(Btcache *node);
// 检查一个piece 的数据是否正确,若正确则写入硬盘上的文件
int write_piece_to_harddis
文档评论(0)