(f *File).Name()这个函数是返回文件的名称,函数原型func (f *File) Name() string要文件的指针操作,返回字符串,感觉比较鸡助的方法底层实现
func main() {
f, _ := os.Open("1.go")
fmt.Println(f.Name()) //输出1.go
}
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
}
func main() {
f, _ := os.Open("11.go")
b := make([]byte, 20)
n, _ := f.ReadAt(b, 15)
fmt.Println(n)
fmt.Println(string(b[:n]))
}
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()) //我们输出文件的名称
}
}
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)
}
}
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
}
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
}
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
}
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
}
新闻热点
疑难解答