• 上传——断点续传之理论篇


    一、流与缓存区
     
    1.1  如何理解流?
     
            流是一种连接,一种管道,它建立了与物理文件或网络相关联的机制,方便读写文件或者网络。当然还有其它类型的流。  
         
    1.2  流的操作
     
          读取:将数据从流传输到缓存区,缓冲区就是内存中的一块区域,代码中常用byte数组。
          写入:将数据从数据源传输到流中。
          流用完后需要释放资源,因为文件或者网络连接都属于非托管资源,需要手动释放。
     
    二、客户端和服务器的通信
     
           http通信,通过接口请求、响应。
     
    三、何为断点续传
     
         从哪跌倒,就从哪爬起,顾名思义,从上次断开的位置接着传输。
     
    四、为什么需要断点续传
     
         优点:针对大文件且网络不太稳定的情况,断点续传能节省带宽。
         缺点:增加额外的通信
     
    五、如何进行断点续传
          断点续传的解决方案,如下图所示:
         

    上图中,主要描述了客户端和服务器通信的情况

    客户端:

         1、需要知道上次断点位置

         2、计算当前开始传输的位置

         3、传输文件

    如何传输文件,比如分片还是不分片,是多线程还是不用多线程,这些都需要设计与考虑。如果用了多线程,就会增加问题的复杂度。当然用好了,好处也很多。

    服务端:

        创建文件的服务

        提供断点位置的服务

        如果是分片传输,还要提供合并分片的服务

          
  • 相关阅读:
    mysql:基础管理、体系结构、升级降级
    Linux网络基础
    mysql 忘记本地密码
    seq命令的用法
    mysql03-SQL应用
    SolidWorks 如何改变封闭草图的背景颜色
    新版 AD 无法选中某些部件(如 Via,Pad)的问题
    安装 dot net 时出现严重错误 0x80070643 安装时发生严重错误 1603 ndp48
    IO 口扩展
    自动波特率检测
  • 原文地址:https://www.cnblogs.com/wangqiang3311/p/14890587.html
Copyright © 2020-2023  润新知