• Go语言的断点续传


    一、Seeker接口

    Seeker是包装基本Seek方法的接口。

    1. type Seeker interface {
    2. Seek(offset int64, whence int) (int64, error)
    3. }

    seek(offset,whence),设置指针光标的位置,随机读写文件:

    第一个参数:偏移量
    第二个参数:如何设置            

                0:seekStart表示相对于文件开始,
                1:seekCurrent表示相对于当前偏移量,
                2:seek end表示相对于结束。

    const (
        SeekStart   = 0 // seek relative to the origin of the file
        SeekCurrent = 1 // seek relative to the current offset
        SeekEnd     = 2 // seek relative to the end
    )

    示例代码:

    1. package main
    2. import (
    3. "os"
    4. "fmt"
    5. "io"
    6. )
    7. func main() {
    8. file,_:=os.OpenFile("/Users/ruby/Documents/pro/a/aa.txt",os.O_RDWR,0)
    9. defer file.Close()
    10. bs :=[]byte{0}
    11. file.Read(bs)
    12. fmt.Println(string(bs))
    13. file.Seek(4,io.SeekStart)
    14. file.Read(bs)
    15. fmt.Println(string(bs))
    16. file.Seek(2,0) //也是SeekStart
    17. file.Read(bs)
    18. fmt.Println(string(bs))
    19. file.Seek(3,io.SeekCurrent)
    20. file.Read(bs)
    21. fmt.Println(string(bs))
    22. file.Seek(0,io.SeekEnd)
    23. file.WriteString("ABC")
    24. }

    二、断点续传

    通过断点续传可以实现:传的文件比较大,缩短耗时; 在文件传递过程中,如果被迫中断,那么下次再重启时,文件不需要重头开始,支持暂停和恢复。当然这些都是通过Seek()方法如何实现:

    先说一下思路:想实现断点续传,主要就是记住上一次已经传递了多少数据,那我们可以创建一个临时文件,记录已经传递的数据量,当恢复传递的时候,先从临时文件中读取上次已经传递的数据量,然后通过Seek()方法,设置到该读和该写的位置,再继续传递数据。

    示例代码:

    1. package main
    2. import (
    3. "fmt"
    4. "os"
    5. "strconv"
    6. "io"
    7. )
    8. func main() {
    9. srcFile:="/Users/ruby/Documents/pro/a/guliang.jpeg"
    10. destFile:="guliang4.jpeg"
    11. tempFile:=destFile+"temp.txt"
    12. //fmt.Println(tempFile)
    13. file1,_:=os.Open(srcFile)
    14. file2,_:=os.OpenFile(destFile,os.O_CREATE|os.O_WRONLY,os.ModePerm)
    15. file3,_:=os.OpenFile(tempFile,os.O_CREATE|os.O_RDWR,os.ModePerm)
    16. defer file1.Close()
    17. defer file2.Close()
    18. //1.读取临时文件中的数据,根据seek
    19. file3.Seek(0,io.SeekStart)
    20. bs:=make([]byte,100,100)
    21. n1,err:=file3.Read(bs)
    22. fmt.Println(n1)
    23. countStr:=string(bs[:n1])
    24. fmt.Println(countStr)
    25. //count,_:=strconv.Atoi(countStr)
    26. count,_:=strconv.ParseInt(countStr,10,64)
    27. fmt.Println(count)
    28. //2. 设置读,写的偏移量
    29. file1.Seek(count,0)
    30. file2.Seek(count,0)
    31. data:=make([]byte,1024,1024)
    32. n2:=-1// 读取的数据量
    33. n3:=-1//写出的数据量
    34. total :=int(count)//读取的总量
    35. for{
    36. //3.读取数据
    37. n2,err=file1.Read(data)
    38. if err ==io.EOF{
    39. fmt.Println("文件复制完毕。。")
    40. file3.Close()
    41. os.Remove(tempFile)
    42. break
    43. }
    44. //将数据写入到目标文件
    45. n3,_=file2.Write(data[:n2])
    46. total += n3
    47. //将复制总量,存储到临时文件中
    48. file3.Seek(0,io.SeekStart)
    49. file3.WriteString(strconv.Itoa(total))
    50. //假装断电
    51. //if total>8000{
    52. // panic("假装断电了。。。,假装的。。。")
    53. //}
    54. }
    55. }
  • 相关阅读:
    智能生活 App 垂直品类- IPC SDK 架构及快速集成配置(安卓版)
    数据库错误知识集2
    Unity与安卓⭐三、Unity报错合集
    【Java】面向对象的特性之一:多态性
    【原创】程序员团队管理的核心是什么?
    springcloudalibaba架构(19):链路追踪ZipKin数据持久化至mysql
    webpack5基于React+Antd搭建开发和生产环境
    VBA技术资料MF68:更改所选区域边框颜色
    go的日志库logrus
    Zabbix实现对Tomcat的监控
  • 原文地址:https://blog.csdn.net/m0_51530927/article/details/125886975