好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 談談對Golang IO讀寫的困惑

談談對Golang IO讀寫的困惑

熱門標簽:賺地圖標注的錢犯法嗎 長沙ai機器人電銷 廣東語音外呼系統供應商 福州鐵通自動外呼系統 地圖標注測試 澳門防封電銷卡 烏魯木齊人工電銷機器人系統 智能電銷機器人營銷 濮陽自動外呼系統代理

前言

Golang的IO讀寫提供了很多種方式,目前本人知道的有io庫、os庫、ioutil庫、bufio庫、bytes/strings庫等。

雖然庫多是一件好事,意味著選擇性多,但讓我困惑的一點是:什么場景下該用哪個庫? 為什么?

在給出結論前,我先想給出Golang內置IO庫的項目結構,主要方便理解和引用:

# 只列舉了核心的目錄及文件
src:
 - bufio
  - bufio.go
 - bytes
  - buffer.go
  - reader.go
 - io
  - ioutil
   - ioutil.go
  - io.go
 - os
  - file.go
 - strings 
  - reader.go

1.io庫屬于底層接口定義庫,其作用是是定義一些基本接口和一些基本常量,并對這些接口的作用給出說明,常見的接口有Reader、Writer等。一般用這個庫只是為了調用它的一些常量,比如io.EOF。

2.ioutil庫包含在io目錄下,它的主要作用是作為一個工具包,里面有一些比較實用的函數,比如 ReadAll(從某個源讀取數據)、ReadFile(讀取文件內容)、WriteFile(將數據寫入文件)、ReadDir(獲取目錄)

3.os庫主要是跟操作系統打交道,所以文件操作基本都會跟os庫掛鉤,比如創建文件、打開一個文件等。這個庫往往會和ioutil庫、bufio庫等配合使用

4.bufio庫可以理解為在io庫上再封裝一層,加上了緩存功能。它可能會和ioutil庫和bytes.Buffer搞混。
4.1 bufio VS ioutil庫:兩者都提供了對文件的讀寫功能,唯一的不同就是bufio多了一層緩存的功能,這個優勢主要體現讀取大文件的時候(ioutil.ReadFile是一次性將內容加載到內存,如果內容過大,很容易爆內存)

4.2 bufio VS bytes.Buffer:兩者都提供一層緩存功能,它們的不同主要在于 bufio 針對的是文件到內存的緩存,而 bytes.Buffer 的針對的是內存到內存的緩存(個人感覺有點像channel,你也可以發現 bytes.Buffer 并沒有提供接口將數據寫到文件)。

5.bytes和strings庫:這兩個庫有點迷,首先它們都實現了Reader接口,所以它們的不同主要在于針對的對象不同,bytes針對的是字節,strings針對的是字符串(它們的方法實現原理很相似)。另一個區別就是 bytes還帶有Buffer的功能,但是 strings沒提供。

注:關于Reader和Writer接口,可以簡單理解為讀取源和寫入源,即只要實現Reader里面的Read方法,這個東西就可以作為一個讀取源,里面可以包含數據并被我們讀取;Writer亦是如此。

以上就是個人的一些結論,下面會針對以上結論做進一步說明,如果有錯誤的地方麻煩請留言指正,比心❤️!

窺探 io 庫

io庫比較常用的接口有三個,分別是Reader,Writer和Close。

// Read方法會接收一個字節數組p,并將讀取到的數據存進該數組,最后返回讀取的字節數n。
// 注意n不一定等于讀取的數據長度,比如字節數組p的容量太小,n會等于數組的長度
type Reader interface {
  Read(p []byte) (n int, err error)
}

// Write 方法同樣接收一個字節數組p,并將接收的數據保存至文件或者標準輸出等,返回的n表示寫入的數據長度。
// 當n不等于len(p)時,返回一個錯誤。
type Writer interface {
  Write(p []byte) (n int, err error)
}

// 關閉操作
type Closer interface {
  Close() error
}

關于 Read 方法的具體實現,可以在strings庫中看到:

// 定義一個Reader接口體
type Reader struct {
  s    string
  i    int64 // current reading index
  prevRune int  // index of previous rune; or  0
}

// 通過NewReader方法得到 reader 對象,這里有個關鍵的地方是傳入的字符串被賦值到 s 變量中
func NewReader(s string) *Reader { 
 return Reader{s, 0, -1} 
}

// Read方法: 核心是 copy 方法,參數b雖然是切片,但是copy方法會影響到它的底層數組
func (r *Reader) Read(b []byte) (n int, err error) {
  if r.i >= int64(len(r.s)) {
    return 0, io.EOF
  }
 r.prevRune = -1
 // 核心方法
  n = copy(b, r.s[r.i:])
  r.i += int64(n)
  return
}

窺探 ioutil 庫

上面提到,ioutil 庫就是一個工具包,里面主要是比較實用的函數,比如ReadFile、WriteFile等,唯一需要注意的是它們都是一次性讀取和一次性寫入,所以當讀取的時候注意文件不能過大。

從文件讀取數據:

func readByFile() {
  data, err := ioutil.ReadFile( "./lab8_io/file/test.txt")
  if err != nil {
    log.Fatal("err:", err)
    return
  }
  fmt.Println("data", string(data)) // hello world!
}

把數據寫入到文件:

func writeFile() {
  err := ioutil.WriteFile("./lab8_io/file/write_test.txt", []byte("hello world!"), 0644)
  if err != nil {
    panic(err)
    return
  }
}

遍歷目錄:遍歷目錄有一個需要注意的是它的排序并不是自然排序方式。

窺探bufio庫

bufio 庫在上面也提到過,它主要是在io庫上加了一層緩存的功能,以下是bufio讀取大文件的例子:

func readBigFile(filePath string) error {
  f, err := os.Open(filePath)
  defer f.Close()

  if err != nil {
    log.Fatal(err)
    return err
  }

  buf := bufio.NewReader(f)
  count := 0
  for {
    count += 1
    line, err := buf.ReadString('\n')
    line = strings.TrimSpace(line)
    if err != nil {
      return err
    }
  fmt.Println("line", line)
  // 這里是避免全部打印
    if count > 100 {
      break
    }
  }
  return nil
}

注:

1.bufio 的ReadLine/ReadBytes/ReadString/ReadSlice: ReadString和ReadBytes等同,ReadBytes和ReadLine都調用了ReadSlice

窺探bytes/strings庫

前面提過,就單純實現Reader接口,bytes和strings底層函數的實現方式是差不多的,可以查看其源碼得證:

// bytes/reader.go
// Read implements the io.Reader interface.
func (r *Reader) Read(b []byte) (n int, err error) {
  if r.i >= int64(len(r.s)) {
    return 0, io.EOF
  }
  r.prevRune = -1
  n = copy(b, r.s[r.i:])
  r.i += int64(n)
  return
}

// strings/reader.go
func (r *Reader) Read(b []byte) (n int, err error) {
  if r.i >= int64(len(r.s)) {
    return 0, io.EOF
  }
  r.prevRune = -1
  n = copy(b, r.s[r.i:])
  r.i += int64(n)
  return
}

參考/推薦

詳解golang中bufio包的實現原理
Golang 超大文件讀取的兩個方案
https://gist.github.com/suntong/032173e96247c0411140

到此這篇關于談談對Golang IO讀寫的困惑的文章就介紹到這了,更多相關Golang IO讀寫內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Golang實現對map的并發讀寫的方法示例
  • Golang通道的無阻塞讀寫的方法示例
  • 詳解golang RWMutex讀寫互斥鎖源碼分析
  • Golang讀寫Excel的方法教程
  • golang簡單讀寫文件示例

標簽:廣西 調研邀請 慶陽 西雙版納 阿克蘇 德州 太原 貴陽

巨人網絡通訊聲明:本文標題《談談對Golang IO讀寫的困惑》,本文關鍵詞  談談,對,Golang,讀,寫的,困惑,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《談談對Golang IO讀寫的困惑》相關的同類信息!
  • 本頁收集關于談談對Golang IO讀寫的困惑的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 久久免费久久| AAAAAAA欧美黃色大片| 任你躁在线精品免费| 日韩69| 极品丰满少妇XXXHD剃毛| 任我日| 一人上面2人下漫画| 特级特黄A片免费播放| 亚洲狠狠做婷婷一区二区三区伊人| 乱色精品无码一区二区国产盗 | 小妮子又嫩又紧h| 胸?啊?嗯~丝袜下面出水了作文| 成人国产Av欧美3D动漫| 推荐2021年没有封的a站| 亚洲腹肌男gay啪啪网站| 免费涩涩视频| 国内精品久久久久国产盗摄按摩女| 99久热视频在线精品| 国产熟妇色XXⅩ交白浆| 野人三级在线播放| 揉她的胸吃奶摸她的下面| 精品偷国情拍在线视频| 欧洲精品一区久久久久一品AV| 美女张开腿让男生桶免费观看| 表妺洗澡让我进去摸她奶| 性欧美videos另类hd高清| 午夜免费网址| 国产精品午夜福利免费去衣软件| 青青草原国产一区二区| 宠文婚后 大肉,到处做| 嗯嗯嗯不要啊| 羞羞视频AV在线观看| 成人3d动漫一区二区三区q1| 被cao的喷水| 桃花扇(古言,1v2)掌中宝串串香 | 18禁黄网站禁片免费观看不卡| 男人边吻奶边挵进去欧美 | 成人Av免费看| 操19p| 一二三四在线观看高清电影中国| 欧美护士激情第一欧美精品|