f, err := os.Create(filenme)
defer f.Close()
if err != nil {
fmr.Println(err.Error())
}else{
_, err = f.Write([]byte("要写入的文本内容"))
checkErr(err)
}
f, err := os.Openfile(filename, os.O_RDONLY, 0600)
defer f.Close()
if err != nil {
fmt.Println(err.Error())
}else{
contentByte, err = ioutil.ReadAll(f)
checkErr(err)
fmt.Println(string(contentByte))
}
// 打开方式
const(
// 只读模式
O_RDONLY int = syscall.O_RDONLY // open the file read-only
// 只写模式
O_WRONLY int - syscall.O_WRONLY // open the file write-only
// 可写可读
O_RDWR int = syscall.0_RDWR // open the file read-write
// 追加内容
O_APPEND int = syscall.O_APPEND
//创建文件,如果文件不存在
O_CREATE int = syscall.O_CREAT // create a new file if none exists
// 与创建文件一同使用。文件必须存在
O_EXCL int = syscall.O_EXCL
// 打开一个同步的文件流
O_SYNC int = syscall.O_SYNC // open for synchronous i/o
// 如果可能
O_TRUNC int = syscall.O_TRUNC
)
// 打开模式
const (
ModeDir FileMode = 1 << (32 - 1 - iota)
ModeAppend // a: append-only 追加模式
ModeExclusive //
ModeTemporary // T: temporary file (not backed up) 临时文件
ModeSymlink // L: symbolic link 象征性的关联
ModeDevice // D: device file 设备文件
ModeNamedPipe // p: named pipe (FIFO) 命名管道
ModeSocket // S: Unix domain socket Unix 主机 socket
ModeSetuid // u: setuid 设置uid
ModeSetgid // g: setgid 设置gid
ModeCharDevice // c: Unix character device, when ModeDevice is set Unix 字符设备,当设备模式是设置Unix
ModeSticky // t: sticky 粘性的
// Mask for the type bits. For regular files, none will be set. bit位遮盖.不变的文件设置为none
ModeType = ModeDir | ModeSymlink | ModeNamedPipe | ModeSocket | ModeDevice
ModePerm FileMode = 0777 // Unix permission bits 权限位.
)
f, err := os.OpenFile(filename, os.O_WINLY|OS.O_TRUNC, 0600)
defer f.Close()
if err != nil {
fme.Println(err.Error())
}else{
_, err = f.Write([]Byte("要写入的文本文件"))
checkErr(err)
}
posted on 2020-03-23 22:11 海纳百川_有容乃大 阅读(1621) 评论(0) 编辑 收藏 举报