日期:2023年3月11日
作者:Commas
签名:(ง •_•)ง 积跬步以致千里,积小流以成江海……
注释:如果您觉得有所帮助,帮忙点个赞,也可以关注我,我们一起成长;如果有不对的地方,还望各位大佬不吝赐教,谢谢^ - ^
1.01365 = 37.7834;0.99365 = 0.0255
1.02365 = 1377.4083;0.98365 = 0.0006

一、前言
要在Go中将文件设置只读属性(set the read-only attribute)或取消只读属性(remove the read-only attribute),我们可以使用Chmod()(即Change mode的缩写,意思是改变权限)函数。
二、语法与示例
os和syscall两个库均提供Chmod()函数,分别是:
func Chmod(name string, mode FileMode) error
func Chmod(path string, mode uint32) (err error)
path:需指定要更改权限的文件或目录的路径;mode:权限代码,由三个八进制数字(octat)组成。如0o444或0444表示只读的权限,0o666或0666表示“读写”的权限,0o777表示读写以及执行的权限等等。
知识加油站:
- 八进制:
0或者0o开头,例如011表示9的八进制表示,前者更为常见。- 二进制:
0b或0B开头,例如0b101表示5的二进制表示。- 十六进制:
0x或0X开头,例如0x1F表示31的十六进制表示。
设置只读示例:
package main
import (
"fmt"
"os"
"syscall"
)
func main() {
file := "test.txt"
// NO1:Set file permission to read-only
// 4 = read(4),所有者、组和其他用户的权限均为4
err := syscall.Chmod(file, 0444)
if err != nil {
fmt.Println(err)
return
}
// NO2:Set file mode to read-only
// 4 = read(4),所有者、组和其他用户的权限
err = os.Chmod(file, 0444)
if err != nil {
fmt.Println(err)
return
}
}
取消只读示例:
package main
import (
"fmt"
"os"
"syscall"
)
func main() {
file := "test.txt"
// NO1:Set file permission to read-write
// # 6 = read(4) + write(2),所有者、组和其他用户的权限均为6
err := syscall.Chmod(file, 0666)
if err != nil {
fmt.Println(err)
return
}
// NO2:Set file mode to read-write
// # 6 = read(4) + write(2),所有者、组和其他用户的权限均为6
err = os.Chmod(file, 0666)
if err != nil {
fmt.Println(err)
return
}
}
二、解读权限代码mode

根据UNIX系统的权限模型,文件或目录的权限模式由三个数字表示,分别代表 所有者(Owner) 、组(Group) 和 其他用户(Other) 的权限。每个数字由三个比特位组成,分别代表读、写和执行权限。因此,对于一个mode参数值,它的每一个数字都是一个八进制数字,代表三个比特位的权限组合。
符号含义:
R:读,Read的缩写,八进制值为4;W:写,Write的缩写,八进制值为2;X:执行,Execute的缩写,八进制值为1;
示例如下:
0444表示三者均为只读的权限;0666表示三者均为“读写”的权限;0777表示三者均为读写执行的权限;0764表示所有者有读写执行(7=4+2+1)的权限,组有读写(6=4+2)的权限,其他用户则为只读(4=4);
我的微信公众号【会飞的小猴子】,等你来关注哦 ^ - ^
版权声明:本文为博主原创文章,如需转载,请给出:
原文链接:https://blog.csdn.net/qq_35844043/article/details/129380567

被折叠的 条评论
为什么被折叠?



