bufio包實作了有緩沖的I/O,它封裝了一個io.Reader或io.Write介面物件,創建一個實作實作了該介面,同時提供緩沖和一些文本I/O的幫助函式.
簡單的說就是,把檔案讀取進緩沖(記憶體)之后再讀取的時候就可以避免檔案系統的io 從而提高速度,同理,在進行寫操作時,先把檔案寫入緩沖(記憶體),然后由緩沖寫入檔案系統,看完以上解釋有人可能會表示困惑了,直接把 內容->檔案 和 內容->緩沖->檔案相比, 緩沖區好像沒有起到作用嘛,其實緩沖區的設計是為了存盤多次的寫入,最后一口氣把緩沖區內容寫入檔案,下面會詳細解釋
bufio 封裝了io.Reader或io.Writer介面物件,并創建另一個也實作了該介面的物件
io.Reader或io.Writer 介面實作read() 和 write() 方法,對于實作這個介面的物件都是可以使用這兩個方法的
以下是bufio的簡單使用:
func main() { fileName := "C:\\Users\\fcl18\\Desktop\\發言.txt" file, err := os.Open(fileName) if err != nil { fmt.Println("err", err) return } defer file.Close() // b1 := bufio.NewReader(file) //1,Read() 高效讀取 // p := make([]byte, 1024) // n1, err1 := b1.Read(p) // if err1 != nil { // fmt.Println("err", err1) // return // } // fmt.Println(n1) // fmt.Println(string(p[:n1])) //2, ReadLine 比較低級 // data, flag, err := b1.ReadLine() // fmt.Println(data) // fmt.Println(flag) // fmt.Println(err) // fmt.Println(string(data)) //3, ReadString // str, err := b1.ReadString('\n') //讀取一行 // fmt.Println(err) // fmt.Println(str) // str1, err1 := b1.ReadString('\n') //再讀一行 // fmt.Println(err1) // fmt.Println(str1) // for { // s, err := b1.ReadString('\n') // if err == io.EOF { // fmt.Println("讀取完畢") // break // } // fmt.Println(s) // } //4, ReadByte // data, err1 := b1.ReadBytes('\n') // fmt.Println(data) // fmt.Println(err1) //Scanln只讀取空格前面的資料 // s2 := "" // fmt.Println("請輸入:") // fmt.Scanln(&s2) // fmt.Println(s2) // b2 := bufio.NewReader(os.Stdin) // s2, _ := b2.ReadString('\n') //通過換行來表示讀取完畢 // fmt.Println(s2) }
bufio寫檔案:
func main() { fileName := "C:\\Users\\fcl18\\Desktop\\cc.txt" file, err := os.OpenFile(fileName, os.O_CREATE|os.O_WRONLY, os.ModePerm) if err != nil { fmt.Println("err", err) return } defer file.Close() w1 := bufio.NewWriter(file) for i := 1; i <= 1000; i++ { w1.WriteString(fmt.Sprintf("%d:hello", i)) } w1.Flush() //將緩沖區的內容寫入 }
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/514270.html
標籤:Go
上一篇:C語言小白刷題
下一篇:Nacos 動態配置原理
