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

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

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

客户端:

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

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

     3、传输文件

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

服务端:

    创建文件的服务

    提供断点位置的服务

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