(f *File).Name()这个函数是返回文件的名称,函数原型func (f *File) Name() string要文件的指针操作,返回字符串,感觉比较鸡助的方法底层实现
复制代码 代码如下:
func (f *File) Name() string { return f.name }
import (
"fmt"
"os"
)
func main() {
f, _ := os.Open("1.go")
fmt.Println(f.Name()) //输出1.go
}
(f *File).Read()这个是函数的指针来操作的,属于*FIlE的method,函数原型func (f *File) Read(b []byte) (n int, err error)输入读取的字节数,返回字节的长度和error信息
复制代码 代码如下:
import (
"fmt"
"os"
)
func main() {
b := make([]byte, 100) //设置读取的字节数
f, _ := os.Open("11.go")
n, _ := f.Read(b)
fmt.Println(n)
fmt.Println(string(b[:n])) //输出内容 为什么是n而不直接输入100呢?底层这样实现的
/*
n, e := f.read(b)
if n < 0 {
n = 0
}
if n == 0 && len(b) > 0 && e == nil {
return 0, io.EOF
}
*/
//所以字节不足100就读取n
}
(f *File).ReadAt()这个函数的原型是func (f *File) ReadAt(b []byte, off int64) (n int, err error)加入了下标,可以自定义读取多少
复制代码 代码如下:
import (
"fmt"
"os"
)
func main() {
f, _ := os.Open("11.go")
b := make([]byte, 20)
n, _ := f.ReadAt(b, 15)
fmt.Println(n)
fmt.Println(string(b[:n]))
}
(f *File).Readdir()函数原型func (f *File) Readdir(n int) (fi []FileInfo, err error),我们要打开一个文件夹,然后设置读取文件夹文件的个数,返回的是文件的fileinfo信息
复制代码 代码如下:
import (
"fmt"
"os"
)
func main() {
f, err := os.Open("src") //打开一个目录
if err != nil {
fmt.Println(err)
}
defer f.Close()
ff, _ := f.Readdir(10) //设置读取的数量 <=0是读取所有的文件 返回的[]fileinfo
for i, fi := range ff {
fmt.Printf("filename %d: %+v\n", i, fi.Name()) //我们输出文件的名称
}
}
(f *File).Readdirnames这个函数的作用是读取目录内的文件名,其实上一个函数我们已经实现了这个函数的功能,函数的原型func (f *File) Readdirnames(n int) (names []string, err error),跟上边一下只不过返回的是文件名 []string的slice
复制代码 代码如下:
import (
"fmt"
"os"
)
func main() {
f, _ := os.Open("bin")
names, err := f.Readdirnames(0)
if err != nil {
fmt.Println(err)
}
for i, name := range names {
fmt.Printf("filename %d: %s\n", i, name)
}
}
(f *File).Seek()这个函数大家一看就懂了,就是偏移指针的地址,函数的原型是func (f *File) Seek(offset int64, whence int) (ret int64, err error) 其中offset是文件指针的位置 whence为0时代表相对文件开始的位置,1代表相对当前位置,2代表相对文件结尾的位置 ret返回的是现在指针的位置
复制代码 代码如下:
import (
"fmt"
"os"
)
func main() {
b := make([]byte, 10)
f, _ := os.Open("1.go")
defer f.Close()
f.Seek(1, 0) //相当于开始位置偏移1
n, _ := f.Read(b)
fmt.Println(string(b[:n])) //原字符package 输出ackage
}
(f *File) Write像文件中写入内容,函数原型func (f *File) Write(b []byte) (n int, err error)返回的是n写入的字节数
复制代码 代码如下:
import (
"fmt"
"os"
)
func main() {
f, _ := os.OpenFile("1.go", os.O_RDWR|os.O_APPEND, 0755) //以追加和读写的方式去打开文件
n, _ := f.Write([]byte("helloword")) //我们写入hellword
fmt.Println(n) //打印写入的字节数
b := make([]byte, 20)
f.Seek(0, 0) //指针返回到0
data, _ := f.Read(b)
fmt.Println(string(b[:data])) //输出了packagehelloword
}
(f *File) WriteAt()在偏移位置多少的地方写入,函数原型是func (f *File) WriteAt(b []byte, off int64) (n int, err error)返回值是一样的
复制代码 代码如下:
import (
"fmt"
"os"
)
func main() {
f, _ := os.OpenFile("1.go", os.O_RDWR, os.ModePerm)
f.WriteAt([]byte("widuu"), 10) //在偏移10的地方写入
b := make([]byte, 20)
d, _ := f.ReadAt(b, 10) //偏移10的地方开始读取
fmt.Println(string(b[:d])) //widuudhellowordhello
}
(f *File).WriteString()这个很简单了,写入字符串函数原型func (f *File) WriteString(s string) (ret int, err error)返回值一样的了
复制代码 代码如下:
import (
"fmt"
"os"
)
func main() {
f, _ := os.OpenFile("2.go", os.O_RDWR, os.ModePerm)
n, _ := f.WriteString("hello word widuu") //写入字符串
fmt.Println(n)
b := make([]byte, n)
f.Seek(0, 0) //一定要把偏移地址归0否则就一直在写入的结尾处
c, _ := f.Read(b)
fmt.Println(string(b[:c])) //返回hello word widuu
}
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。