GoLang OS包及File类型源码分析


这篇文章主要介绍“GoLangOS包及File类型源码分析”,在日常操作中,相信很多人在GoLangOS包及File类型源码分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”GoLangOS包及File类型源码分析”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!os包中的API主要可以帮助我们使用操作系统中的文件系统、权限系统、环境变量、系统进程,以及系统信号。对于类Unix的操作系统,其中的一切都可以被看作文件。因此可以利用os.File类型操作的东西很多。本篇文章把os.File 类型应用于常规的文件。os.File拥有的都是指针方法,所以除了空接口以外,它本身没有实现任何接口。而它的指针类型则实现了很多io代码包中的接口。*os.File实现了io包中三个最核心的简单接口:io.Readerio.Writerio.Closer*os.File还实现了另外三个简单接口:io.ReaderAtio.Seekerio.WriterAt;由于*os.File实现了上面六个简单接口,所以它顺便实现了io包中9个扩展接口中的7个:io.ReadWriterio.ReadCloserio.ReadSeekerio.ReadWriteCloserio.ReadWriteSeekerio.WriteCloserio.WriteSeeker。由于*os.File没有实现简单接口io.ByteReaderio.RuneReader,所以它没有实现它没有实现作为它两者的扩展接口:io.ByteScannerio.RuneScanner。所以,os.File可以读写文件,并读取和设定下一次读写的起始索引位置。还可以对文件进行关闭。但是,并不能专门地读取文件的下一个字节,或者写一个Unicode字符,也不能进行任何的读回退操作。在os包中,有这样几个函数:Create、NewFile、Open和OpenFile。os.Create函数用于根据指定的路径创建一个新的文件。使用这个函数创建的文件,对于操作系统中的所有用户来说,都是可以读和写的。如果在我们给予os.Create函数的路径之上,已经存在一个文件,那么该函数会清空现有文件中的全部内容,然后再把它作为第一个结果值返回;如果给定的路径的某一级父目录并不存在,该函数就会返回一个*os.PathError类型的错误值,以表示“不存在的文件或目录“。该函数在被调用的时候,需要接受一个代表文件描述符的uintptr类型的值,以及一个用于表示文件名的字符值。如果给定的文件描述符不是有效的,那么函数将返回nil。否则,它将会返回一个代表了相应文件的File值;这个函数的功能并不是创建一个新的文件,而是依据一个已经存在的文件描述符,来新建一个包装了该文件的File值。os.Open函数会打开一个文件并返回包装了该文件的File值。然而,该函数只能以只读模式打开文件。换句话说,我们只能从该函数返回的File值中读取内容,而不能向它写入任何内容。如果调用它的任何一个写入方法,都会得到一个表示“坏的文件描述符”的错误值。os.File类型有一个指针方法Fd,它在被调用之后将会返回一个uintptr 类免费云主机域名型的值,这个值就代表了当前的File值所持有的那个文件描述符。os.OpenFile其实是os.Openos.Create函数的底层支持,它最为灵活。这个函数有3个参数:name:文件路径;flag:需要施加在文件描述符之上的模式;比如,只读模式(由os.O_RDONLY)。操作模式perm:代表的也是模式,类型是os.FileMode,是一个基于uint32类型的再定义类型。权限模式。操作模式限定了文件的方式,权限模式控制文件的访问权限。针对File值的操作模式主要有:只读模式、只写模式和读写模式。只读模式:os.O_RDONLY只写模式:os.O_WRONLY读写模式:os.O_RDWR更多的操作模式:os.O_APPEDN :写内容是,追加在现有内容的后面;os.O_CREATE :当给定路径上的文件不存在时,创建一个新文件;os.O_EXCL:需要和os.O_CREATE一同使用,表示给定的路径上不能有存在的文件。os.O_SYNC :在打开文件之上实施同步I/O。它会保证读写的内容总会与硬盘上的数据保持同步。os.O_TRUNC:如果文件已存在,并且是常规的文件,那么就先清空其中已存在的任何内容。多个操作模式是通过按位操作符|组合起来的。os.OpenFile函数的第三个参数perm代表的是权限模式,它的类型是os.FileMode。实际上,os.FileMode能够代表的不仅是权限模式,还可以代表文件模式(也可以称为文件种类)。os.FileMode是基于uint32类型的再定义类型,包含23个比特位,在这23个比特位,每个比特位都有特定的含义。如果在最高比特位的二进制数是1,该文件模式就等同于os.ModeDir,也就是说相应的文件是一个目录。如果在第26位比特位的二进制数是1,该文件模式就等同于os.ModeNamedPipe,也就是说该文件是一个命名管道。os.FileMode只有最低9个比特位才用于表示文件的权限。拿os.FileMode类型的值与os.ModePerm常量(值为0777)做按位与操作,得到的值就表示对应的权限模式。这9个比特位,3个为一组,共3组。从高到低,分别表示:文件所有者(创建文件的那个用户)、文件所属的用户组、用户对该文件的访问权限。而对于每个组,其中的3个比特位从高到低分别表示:读权限、写权限、执行权限。某个比特位上是1,表示相应的权限开启,否则,就表示相应的权限关闭。八进制整数0777就表示:操作系统中的所有用户都对当前的文件有读、写和执行的权限;而八进制整数0666则表示:所有用户都对当前文件有读和写的权限,但都没有执行的权限。但要注意,只有在新建文件的时候,这里的第三个参数值才是有效的。在其他情况下,即使我们设置了此参数,也不会对目标文件产生任何的影响。到此,关于“GoLangOS包及File类型源码分析”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注百云主机网站,小编会继续努力为大家带来更多实用的文章!

相关推荐: jquer基础事件方法实例分析

这篇文章主要介绍“jquer基础事件方法实例分析”,在日常操作中,相信很多人在jquer基础事件方法实例分析免费云主机域名问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”jquer基础事件方法实例分析”的疑惑有所帮助!接下来,请跟…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 05/24 16:47
Next 05/24 16:47

相关推荐