亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

  • 站長資訊網(wǎng)
    最全最豐富的資訊網(wǎng)站

    兩個Golang超大文件讀取的方案

    下面由golang教程欄目給大家介紹兩個Golang超大文件讀取的方案,希望對需要的朋友有所幫助!

    兩個Golang超大文件讀取的方案

    Golang超大文件讀取的兩個方案

    1.流處理方式

    2.分片處理

    去年的面試中我被問到超大文件你怎么處理,這個問題確實當時沒多想,回來之后仔細研究和討論了下這個問題,對大文件讀取做了一個分析

    比如我們有一個log文件,運行了幾年,有100G之大。按照我們之前的操作可能代碼會這樣寫:

    func ReadFile(filePath string) []byte{     content, err := ioutil.ReadFile(filePath)     if err != nil {         log.Println("Read error")     }     return content }

    上面的代碼讀取幾兆的文件可以,但是如果大于你本身及其內存,那就直接翻車了。因為上面的代碼,是把文件所有的內容全部都讀取到內存之后返回,幾兆的文件,你內存夠大可以處理,但是一旦上幾百兆的文件,就沒那么好處理了。那么,正確的方法有兩種,第一個是使用流處理方式代碼如下:

    func ReadFile(filePath string, handle func(string)) error {     f, err := os.Open(filePath)     defer f.Close()     if err != nil {         return err     }     buf := bufio.NewReader(f)      for {         line, err := buf.ReadLine("n")         line = strings.TrimSpace(line)         handle(line)         if err != nil {             if err == io.EOF{                 return nil             }             return err         }         return nil     } }

    第二個方案就是分片處理,當讀取的是二進制文件,沒有換行符的時候,使用下面的方案一樣處理大文件

    func ReadBigFile(fileName string, handle func([]byte)) error {     f, err := os.Open(fileName)     if err != nil {         fmt.Println("can't opened this file")         return err     }     defer f.Close()     s := make([]byte, 4096)     for {         switch nr, err := f.Read(s[:]); true {         case nr < 0:             fmt.Fprintf(os.Stderr, "cat: error reading: %sn

    贊(0)
    分享到: 更多 (0)
    網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號