激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Golang - Go語言編程中對文件讀寫的基本方法整理

Go語言編程中對文件讀寫的基本方法整理

2020-04-27 11:37腳本之家 Golang

這篇文章主要介紹了Go語言編程中對文件讀寫的基本方法整理,是Go語言入門學習中的基礎知識,需要的朋友可以參考下

1.func Copy(dst Writer, src Reader) (written int64, err error)這個函數是從一個文件讀取拷貝到另外一個文件,一直拷貝到讀取文件的EOF,所以不會返回io.EOF錯誤,參數是寫入目標器和讀取目標器,返回int64的拷貝字節數和err信息

 

復制代碼 代碼如下:


import (
 "fmt"
 "io"
 "os"
)

 

func main() {
 r, _ := os.Open("test.txt")
 w, _ := os.Create("write.txt")
 num, err := io.Copy(w, w)
 if err != nil {
  fmt.Println(err)
 }
 fmt.Println(num) //返回int64的11 打開我的write.txt正是test.txt里邊的hello widuu

 

 

 

2.func CopyN(dst Writer, src Reader, n int64) (written int64, err error)看函數就知道了跟上述的是一樣的,只是多加了一個讀取數的限制,然后我們看下代碼

復制代碼 代碼如下:


import (
 "fmt"
 "io"
 "io/ioutil"
 "os"
)

 

func main() {
 r, _ := os.Open("test.txt")
 w, _ := os.Create("write1.txt")
 num, err := io.CopyN(w, r, 5)
 if err != nil {
  fmt.Println(err)
 }
 defer r.Close()
 b, _ := ioutil.ReadFile("write1.txt")
 fmt.Println(string(b)) //輸出 hello
 fmt.Println(num)       //5
}

 

 

 

3.func ReadAtLeast(r Reader, buf []byte, min int) (n int, err error)這個函數就是從讀取器中讀取數據放到我們的buf中,限定了最小的讀取字節數,如果我們讀取的數據小于最小讀取器,譬如你設定min的值是8,但是你讀取的數據字節數是5就會返回一個`io.ErrUnexpectedEOF`,如果大于就會返回`io.ErrShortBuffer`,讀取完畢會有`io.EOF`~~,多講一些哈,這個Reader只要我們滿足這個interface就可以用這個

復制代碼 代碼如下:


type Reader interface {
    Read(p []byte) (n int, err error)
}

 

 


其中*File就支持func (f *File) Read(b []byte) (n int, err error)

 

 

復制代碼 代碼如下:


import (
 "fmt"
 "io"
 "os"
)

 

func main() {
 r, _ := os.Open("write1.txt")
 b := make([]byte, 20)
 defer r.Close()
 var total int
 for {
  n, err := io.ReadAtLeast(r, b, 8)
  if err == nil {
   fmt.Println("Read enough value:", string(b)) // Read enough value: hello widuu
  }
  if err == io.ErrUnexpectedEOF { //讀取了的數據小于我們限定的最小讀取數據8
   fmt.Println("Read fewer value:", string(b[0:n]))
  }
  
  if err == io.ErrShortBuffer{   //這個是我們設定的buf也就是b小于我們限定8
   fmt.Println("buf too Short")
   os.Exit(1)
  }
  if err == io.EOF { //讀完了 輸出
   fmt.Println("Read end total", total) //Read end total 11
   break
  }
  total = total + n
 }
}

 

 

 

4.func ReadFull(r Reader, buf []byte) (n int, err error)這個函數和上邊的函數是相似,只不過是讀取len(buf)個,放在buf中

 

復制代碼 代碼如下:

 

 

import (
 "fmt"
 "io"
 "os"
)

func main() {
 r, _ := os.Open("write.txt")
 b := make([]byte, 20)
 num, err := io.ReadFull(r, b)
 defer r.Close()
 if err == io.EOF {
  fmt.Println("Read end total", num)
 }
 if err == io.ErrUnexpectedEOF {
  fmt.Println("Read fewer value:", string(b[:num])) //Read fewer value: hello widuu,依然是buf長度大于讀取的長度
  return
 }

 fmt.Println("Read  value:", string(b)) //如果b是5 就出現這里
}

 

 

 

5.func WriteString(w Writer, s string) (n int, err error)弄完讀了,當然帶要寫了,這個函數主要是向寫入目標中寫入字符創,返回是寫入的字節數還有error錯誤,主要是權限的錯誤,其中寫入呀!都是writer這個結構就可以寫入

 

復制代碼 代碼如下:

 

 

type Writer interface {
    Write(p []byte) (n int, err error)
}
跟read一樣我們的*File是有func (f *File) Write(b []byte) (n int, err error),當然其實我們的*File中就已經有WirteString了func (f *File) WriteString(s string) (ret int, err error)
import (
 "fmt"
 "io"
 "io/ioutil"
 "os"
)

func main() {
 w, _ := os.OpenFile("write1.txt", os.O_RDWR, os.ModePerm)
 n, err := io.WriteString(w, "ni hao ma")
 if err != nil {
  fmt.Println(err) //當我用os.open()的時候木有權限  悲催的~~輸出write write1.txt: Access is denied.
 }
 defer w.Close()
 b, _ := ioutil.ReadFile("write1.txt")
 fmt.Println("write total", n) //write total 9
 fmt.Println(string(b))        // ni hao ma
}

 

 

 

6.type LimitedReader

 

復制代碼 代碼如下:

 

 

type LimitedReader struct {
    R Reader // 讀取器了
    N int64  // 最大字節限制
}

 


只實現了一個方法func (l *LimitedReader) Read(p []byte) (n int, err error)其實我們不難發現這個跟我們的ReadAtLast()就是親兄弟的節奏

 

 

復制代碼 代碼如下:


import (
 "fmt"
 "io"
 "os"
)

 

func main() {
 reader, _ := os.Open("test.txt")
 limitedreader := io.LimitedReader{
  R: reader,
  N: 20,
 }
 p := make([]byte, 10)
 var total int
 for {
  n, err := limitedreader.Read(p)
  if err == io.EOF {
   fmt.Println("read total", total)     //read total 11
   fmt.Println("read value", string(p)) //read value hello widuu
   break
  }
  total = total + n

 }

}

 

 

 

7.type PipeReader

 

復制代碼 代碼如下:


type PipeReader struct {
    // contains filtered or unexported fields
}

 

 


(1)func Pipe() (*PipeReader, *PipeWriter)創建一個管道,并返回它的讀取器和寫入器,這個會在內存中進行管道同步,它的開啟會io.Reader然后等待io.Writer的輸入,沒有內部緩沖,它是安全的調用Read和Write彼此和并行調用寫

 

 

復制代碼 代碼如下:

 

 

import (
 "fmt"
 "io"
 "reflect"
)

func main() {
 r, w := io.Pipe()
 fmt.Println(reflect.TypeOf(r)) //*io.PipeReader
 fmt.Println(reflect.TypeOf(w)) //*io.PipeWriter
}

 


(2)func (r *PipeReader) Close() error管道關閉后,正在進行或后續的寫入Write操作返回ErrClosedPipe

復制代碼 代碼如下:


import (
 "fmt"
 "io"
)

 

func main() {
 r, w := io.Pipe()
 r.Close()

 _, err := w.Write([]byte("hello widuu")) 

 if err == io.ErrClosedPipe {
  fmt.Println("管道已經關閉無法寫入") //管道已經關閉無法寫入
 }
}

 


(3)func (r *PipeReader) CloseWithError(err error) error這個就是上邊的r.Close關閉的時候,寫入器會返回錯誤的信息

 

 

復制代碼 代碼如下:

 

 

import (
 "errors"
 "fmt"
 "io"
)

func main() {
 r, w := io.Pipe()
 r.Close()
 err := errors.New("管道符關閉了") //errors這個包我們前邊已經說過了,就一個方法New不會的可以看看前邊的
 r.CloseWithError(err)
 _, err = w.Write([]byte("test"))
 if err != nil {
  fmt.Println(err) //管道符關閉了
 }
}

 


(4)func (r *PipeReader) Read(data []byte) (n int, err error)標準的閱讀接口,它從管道中讀取數據、阻塞一直到一個寫入接口關閉,如果寫入端發生錯誤,它就會返回錯誤,否則返回的EOF

 

 

復制代碼 代碼如下:


import (
 "fmt"
 "io"
)

 

func main() {
 r, w := io.Pipe()
 go w.Write([]byte("hello widuu"))
 d := make([]byte, 11)
 n, _ := r.Read(d) //從管道里讀取數據
 fmt.Println(string(d))
 fmt.Println(n)
}

 

 

延伸 · 閱讀

精彩推薦
  • GolangGolang通脈之數據類型詳情

    Golang通脈之數據類型詳情

    這篇文章主要介紹了Golang通脈之數據類型,在編程語言中標識符就是定義的具有某種意義的詞,比如變量名、常量名、函數名等等,Go語言中標識符允許由...

    4272021-11-24
  • GolangGolang中Bit數組的實現方式

    Golang中Bit數組的實現方式

    這篇文章主要介紹了Golang中Bit數組的實現方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    天易獨尊11682021-06-09
  • Golanggolang json.Marshal 特殊html字符被轉義的解決方法

    golang json.Marshal 特殊html字符被轉義的解決方法

    今天小編就為大家分享一篇golang json.Marshal 特殊html字符被轉義的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    李浩的life12792020-05-27
  • Golanggo語言制作端口掃描器

    go語言制作端口掃描器

    本文給大家分享的是使用go語言編寫的TCP端口掃描器,可以選擇IP范圍,掃描的端口,以及多線程,有需要的小伙伴可以參考下。 ...

    腳本之家3642020-04-25
  • Golanggo日志系統logrus顯示文件和行號的操作

    go日志系統logrus顯示文件和行號的操作

    這篇文章主要介紹了go日志系統logrus顯示文件和行號的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    SmallQinYan12302021-02-02
  • Golanggolang如何使用struct的tag屬性的詳細介紹

    golang如何使用struct的tag屬性的詳細介紹

    這篇文章主要介紹了golang如何使用struct的tag屬性的詳細介紹,從例子說起,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看...

    Go語言中文網11352020-05-21
  • Golanggolang的httpserver優雅重啟方法詳解

    golang的httpserver優雅重啟方法詳解

    這篇文章主要給大家介紹了關于golang的httpserver優雅重啟的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,...

    helight2992020-05-14
  • Golanggolang 通過ssh代理連接mysql的操作

    golang 通過ssh代理連接mysql的操作

    這篇文章主要介紹了golang 通過ssh代理連接mysql的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    a165861639710342021-03-08
主站蜘蛛池模板: www.三区| 激情影院在线观看 | 精品国产精品久久 | 午夜精品久久久久久久久久久久久蜜桃 | 免看黄大片aa| 精品成人免费一区二区在线播放 | 黄色影院在线观看视频 | 美国一级毛片片aa久久综合 | 国产精品麻豆一区二区三区 | 久久亚洲精品久久国产一区二区 | 特级毛片免费 | 中文字幕综合 | 日韩高清影视 | 久久国产一| 精品国产一区二区三区四区阿崩 | 国产精品剧情一区二区三区 | 玩偶姐姐在线观看免费 | 一分钟免费观看完整版电影 | 精品国产一区二区三区成人影院 | 久久久久女人精品毛片九一 | 免费久久久久久 | 亚洲第九十九页 | 在线播放污| 国产精品爱久久久久久久 | 成人午夜免费国产 | 色播av在线| 精品成人免费一区二区在线播放 | 国产精品野外av久久久 | 最新中文在线视频 | 亚洲精品日韩色噜噜久久五月 | 欧美视频一区二区三区在线观看 | 有兽焉免费动画 | 播色网| 国产一级在线看 | 国产成人在线综合 | 春光影院理论片 | 巨乳毛片 | 久久综合狠狠综合久久 | 国产噜噜噜噜久久久久久久久 | 日本人乱人乱亲乱色视频观看 | 欧美精品电影一区 |