(转)golang 读写文件的四种方式
原文:https://blog.csdn.net/whatday/article/details/103938124
读文件
读取的文件放在file/test:也就是file包下的test这个文件,里面写多一点文件
读文件方式一:利用ioutil.ReadFile直接从文件读取到[]byte中
-
func Read0() (string){
-
f, err := ioutil.ReadFile("file/test")
-
if err != nil {
-
fmt.Println("read fail", err)
-
}
-
return string(f)
-
}
-
读文件方式二:先从文件读取到file中,在从file读取到buf, buf在追加到最终的[]byte
-
func Read1() (string){
-
//获得一个file
-
f, err := os.Open("file/test")
-
if err != nil {
-
fmt.Println("read fail")
-
return ""
-
}
-
-
//把file读取到缓冲区中
-
defer f.Close()
-
var chunk []byte
-
buf := make([]byte, 1024)
-
-
for {
-
//从file读取到buf中
-
n, err := f.Read(buf)
-
if err != nil && err != io.EOF{
-
fmt.Println("read buf fail", err)
-
return ""
-
}
-
//说明读取结束
-
if n == 0 {
-
break
-
}
-
//读取到最终的缓冲区中
-
chunk = append(chunk, buf[:n]...)
-
}
-
-
return string(chunk)
-
//fmt.Println(string(chunk))
-
}
-
读文件方式三:先从文件读取到file, 在从file读取到Reader中,从Reader读取到buf, buf最终追加到[]byte
-
//先从文件读取到file, 在从file读取到Reader中,从Reader读取到buf, buf最终追加到[]byte,这个排第三
-
func Read2() (string) {
-
fi, err := os.Open("file/test")
-
if err != nil {
-
panic(err)
-
}
-
defer fi.Close()
-
-
r := bufio.NewReader(fi)
-
var chunks []byte
-
-
buf := make([]byte, 1024)
-
-
for {
-
n, err := r.Read(buf)
-
if err != nil && err != io.EOF {
-
panic(err)
-
}
-
if 0 == n {
-
break
-
}
-
//fmt.Println(string(buf))
-
chunks = append(chunks, buf...)
-
}
-
return string(chunks)
-
//fmt.Println(string(chunks))
-
}
-
读文件方式四:读取到file中,再利用ioutil将file直接读取到[]byte中
-
//读取到file中,再利用ioutil将file直接读取到[]byte中, 这是最优
-
func Read3() (string){
-
f, err := os.Open("file/test")
-
if err != nil {
-
fmt.Println("read file fail", err)
-
return ""
-
}
-
defer f.Close()
-
-
fd, err := ioutil.ReadAll(f)
-
if err != nil {
-
fmt.Println("read to fd fail", err)
-
return ""
-
}
-
-
return string(fd)
-
}
-
读取速度比较
-
import (
-
"bufio"
-
"fmt"
-
"io"
-
"io/ioutil"
-
"os"
-
"time"
-
)
-
-
func Read1() string {
-
f, err := ioutil.ReadFile("/root/test")
-
if err != nil {
-
fmt.Println("read fail", err)
-
}
-
return string(f)
-
}
-
-
func Read2() string {
-
//获得一个file
-
f, err := os.Open("/root/test")
-
if err != nil {
-
fmt.Println("read fail")
-
return ""
-
}
-
-
//把file读取到缓冲区中
-
defer f.Close()
-
var chunk []byte
-
buf := make([]byte, 1024)
-
-
for {
-
//从file读取到buf中
-
n, err := f.Read(buf)
-
if err != nil && err != io.EOF {
-
fmt.Println("read buf fail", err)
-
return ""
-
}
-
//说明读取结束
-
if n == 0 {
-
break
-
}
-
//读取到最终的缓冲区中
-
chunk = append(chunk, buf[:n]...)
-
}
-
-
return string(chunk)
-
//fmt.Println(string(chunk))
-
}
-
-
func Read3() string {
-
fi, err := os.Open("/root/test")
-
if err != nil {
-
panic(err)
-
}
-
defer fi.Close()
-
-
r := bufio.NewReader(fi)
-
var chunks []byte
-
-
buf := make([]byte, 1024)
-
-
for {
-
n, err := r.Read(buf)
-
if err != nil && err != io.EOF {
-
panic(err)
-
}
-
if 0 == n {
-
break
-
}
-
//fmt.Println(string(buf))
-
chunks = append(chunks, buf...)
-
}
-
return string(chunks)
-
//fmt.Println(string(chunks))
-
}
-
-
func Read4() string {
-
f, err := os.Open("/root/test")
-
if err != nil {
-
fmt.Println("read file fail", err)
-
return ""
-
}
-
defer f.Close()
-
-
fd, err := ioutil.ReadAll(f)
-
if err != nil {
-
fmt.Println("read to fd fail", err)
-
return ""
-
}
-
-
return string(fd)
-
}
-
-
func main() {
-
start := time.Now().UnixNano() / 1e6
-
Read1()
-
end := time.Now().UnixNano() / 1e6
-
fmt.Printf("Read1=%d,\n", end-start)
-
}
分别测试 read2 read3 read4
-
func main() {
-
start := time.Now().UnixNano() / 1e6
-
Read2()
-
end := time.Now().UnixNano() / 1e6
-
fmt.Printf("Read2=%d,\n", end-start)
-
}
-
func main() {
-
start := time.Now().UnixNano() / 1e6
-
Read3()
-
end := time.Now().UnixNano() / 1e6
-
fmt.Printf("Read3=%d,\n", end-start)
-
}
-
func main() {
-
start := time.Now().UnixNano() / 1e6
-
Read4()
-
end := time.Now().UnixNano() / 1e6
-
fmt.Printf("Read4=%d,\n", end-start)
-
}
输出结果
-
[root@localhost src]# ll -h /root | grep test
-
-rwxr-xr-x. 1 root root 136M Nov 7 19:20 test
-
[root@localhost src]# go build
-
[root@localhost src]# ./test
-
Read1=625,
-
[root@localhost src]# go build
-
[root@localhost src]# ./test
-
Read2=1313,
-
[root@localhost src]# go build
-
[root@localhost src]# ./test
-
Read3=1724,
-
[root@localhost src]# go build
-
[root@localhost src]# ./test
-
Read4=1057,
经过测试,这四种方式读的速度排名是:前者为优
方式一 > 方式四 > 方式二 > 方式三
写文件
写文件方式一:使用 io.WriteString 写入文件
-
func Write0() {
-
fileName := "file/test1"
-
strTest := "测试测试"
-
-
var f *os.File
-
var err error
-
-
if CheckFileExist(fileName) { //文件存在
-
f, err = os.OpenFile(fileName, os.O_APPEND, 0666) //打开文件
-
if err != nil{
-
fmt.Println("file open fail", err)
-
return
-
}
-
}else { //文件不存在
-
f, err = os.Create(fileName) //创建文件
-
if err != nil {
-
fmt.Println("file create fail")
-
return
-
}
-
}
-
//将文件写进去
-
n, err1 := io.WriteString(f, strTest)
-
if err1 != nil {
-
fmt.Println("write error", err1)
-
return
-
}
-
fmt.Println("写入的字节数是:", n)
-
}
-
写文件方式二:使用 ioutil.WriteFile 写入文件
-
func Write1() {
-
fileName := "file/test2"
-
strTest := "测试测试"
-
var d = []byte(strTest)
-
err := ioutil.WriteFile(fileName, d, 0666)
-
if err != nil {
-
fmt.Println("write fail")
-
}
-
fmt.Println("write success")
-
}
-
写文件方式三:使用 File(Write,WriteString) 写入文件
-
func Write2() {
-
-
fileName := "file/test3"
-
strTest := "测试测试"
-
var d1 = []byte(strTest)
-
-
f, err3 := os.Create(fileName) //创建文件
-
if err3 != nil{
-
fmt.Println("create file fail")
-
}
-
defer f.Close()
-
n2, err3 := f.Write(d1) //写入文件(字节数组)
-
-
fmt.Printf("写入 %d 个字节n", n2)
-
n3, err3 := f.WriteString("writesn") //写入文件(字节数组)
-
fmt.Printf("写入 %d 个字节n", n3)
-
f.Sync()
-
}
-
写文件方式四:使用 bufio.NewWriter 写入文件
-
func Write3() {
-
fileName := "file/test3"
-
f, err3 := os.Create(fileName) //创建文件
-
if err3 != nil{
-
fmt.Println("create file fail")
-
}
-
w := bufio.NewWriter(f) //创建新的 Writer 对象
-
n4, err3 := w.WriteString("bufferedn")
-
fmt.Printf("写入 %d 个字节n", n4)
-
w.Flush()
-
f.Close()
-
}
-
检查文件是否存在:
-
func CheckFileExist(fileName string) bool {
-
_, err := os.Stat(fileName)
-
if os.IsNotExist(err) {
-
return false
-
}
-
return true
-
}
-
技术链接
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
2019-03-10 (转)[Python 网络编程] makefile (三)