基于内存缓冲区的流媒体数据缓存(5)
} //将缓冲区中的数据聚集到一个存储体中 remainer=remaindata(0,poutdata);
fseek(targetfilepoint,outdataoffset,SEEK_SET); fwrite(poutdata,remainer,1,targetfilepoint); outdataoffset=outdataoffset+remainer; cleardata(remainer);
}//输出缓冲区剩余数据函数;处理尾数据不需要endnumber的更新
int program::computer(int baglength){ int totaldata=0; int temp; b* help; help=buffer;
while(help!=NULL) {
totaldata=totaldata+help->arra.size(); help=help->next; }
temp=512*1024-totaldata; if(temp>=baglength) return 0;
return (baglength-temp); }//judge缓冲区大小函数
int program::forceout(int baglength) {
int remainer; int judge;
char* poutdata=NULL; b* help=NULL; judge=0; help=buffer;
while(help!=NULL) {
if((endnumber==help->offset)&&(help->arra.size()!=0)) {
help->judge=1;
poutdata=help->arra.data(); remainer=help->arra.size();
endnumber=endnumber+remainer; if(originaltwo.size()<1)
originaltwo.push_back(help->offset);//获取疑似第一个输出到目的文件中的数据包的首元素偏移量
judge=1;break; }
help=help->next; }//输出连续数据 if(judge==1) {
fseek(targetfilepoint,outdataoffset,SEEK_SET); fwrite(poutdata,remainer,1,targetfilepoint); outdataoffset=outdataoffset+remainer; cleardata(remainer); return 1;
}//如果连续数据存储体标记成功,数据输出 help=buffer;
while(help!=NULL) {
if(help->arra.size()!=0) {
help->judge=1;
poutdata=help->arra.data(); remainer=help->arra.size();
endnumber=help->offset+remainer; if(originaltwo.size()<1)
originaltwo.push_back(help->offset);//获取疑似第一个输出到目的文件中的数据包的首元素偏移量 judge=1;break; }
help=help->next; }
if(judge==1) {
fseek(targetfilepoint,outdataoffset,SEEK_SET); fwrite(poutdata,remainer,1,targetfilepoint); outdataoffset=outdataoffset+remainer; cleardata(remainer); return 1;
}//如果不连续数据存储体标记成功,数据输出 return 0; }//强制输出函数
void program::receivedata(int indataoffset,int length,char* databag){ b* helpone;b* helptwo;int totalone,totaltwo; helptwo=buffer;
helpone=buffer;//初始化两个辅助指针 while(helpone!=NULL)
{
totalone=helpone->arra.size()+helpone->offset;//计算当前存储体下一个数据的偏移量 totaltwo=length+indataoffset;//计算当前数据包下一个数据的偏移量 if(indataoffset==totalone) {
b* follow;follow=helpone->next; int total=0;
for(int i=0;i helpone->arra.push_back(databag[i]); total=helpone->arra.size()+helpone->offset; if(follow!=NULL) { while(total==follow->offset) { for(unsigned int i=0;i helpone->arra.push_back(follow->arra[i]); helpone->next=follow->next; delete follow;
…… 此处隐藏:318字,全部文档内容请下载后查看。喜欢就下载吧 ……
相关推荐:
- [实用模板]第八章:法国“新浪潮”与“左岸派”
- [实用模板]2021年北京上半年临床医学检验技师生物
- [实用模板]SAP GUI 7.10客户端安装配置文档
- [实用模板]2001年临床执业医师资格考试综合笔试试
- [实用模板]36机场工作实用英语词汇总结
- [实用模板](一)社会保险稽核通知书
- [实用模板]安全教育主题班会材料
- [实用模板]濉溪县春季呼吸道传染病防控应急演练方
- [实用模板]长沙房地产市场周报(1.30-2.3)
- [实用模板]六年级数学上册典中点 - 图文
- [实用模板]C程序设计(红皮书)习题官方参考答案
- [实用模板]中国证监会第一届创业板发行审核委员会
- [实用模板]桥梁工程复习题
- [实用模板]2011学而思数学及答案
- [实用模板]初中病句修改专项练习
- [实用模板]监理学习知识1 - 图文
- [实用模板]小机灵杯四年级试题
- [实用模板]国贸专业毕业论文模板
- [实用模板]教育学概论考试练习题-判断题4
- [实用模板]2015届高考英语一轮复习精品资料(译林
- 00Nkmhe_市场营销学工商管理_电子商务_
- 事业单位考试法律常识
- 诚信教育实施方案
- 吉大小天鹅食品安全检测箱方案(高中低
- 房地产销售培训资料
- 高一地理必修1复习提纲
- 新概念英语第二册lesson_1_练习题
- 证券公司内部培训资料
- 小学英语时间介词专项练习
- 新世纪英语专业综合教程(第二版)第1册U
- 【新课标】浙教版最新2018年八年级数学
- 工程建设管理纲要
- 外研版 必修一Module 4 A Social Surve
- Adobe认证考试 AE复习资料
- 基于H.264AVC与AVS标准的帧内预测技术
- 《食品检验机构资质认定管理办法》(质
- ABB变频器培训课件
- (完整版)小学说明文阅读练习题及答案
- 深思洛克(SenseLock) 深思IV,深思4,深
- 弟子规全文带拼音




