/*
 达内学习 UC day06 2013-10-10
*/

回忆过去:
 系统调用 - UNIX操作系统提供的一些列函数皆苦,用于访问内核空间,遵循posix规范
 文件操作:open()\read()\write()\close() 函数的使用

lseek() - 移动文件内指针,设置偏移量
dup()/dup2() - 文件描述符的复制
fcntl() - 文件控制函数,提供很多功能 文件相关函数

lseek() 用法和fseek() 基本一致,第一个参数是文件描述符,第二个参数是偏移量,第三个参数是偏移的参照位置,包括SEEK_SET(头)SEEK_CUR(当前) SEEK_END(文件结尾)

dup()和dup2()都可以复制文件描述符,但是不会复制文件表
dup() 复制描述符时候,新的描述符由系统选定
dup2()复制时,描述符由程序传入,如果改值被占用,关闭后使用传入的值

int fcntl(int fd,int cmd,...)
 通过不同的cmd 执行不同的操作,常见的cmd
 1 F_DUPFD 复制文件描述符 需要第三个参数传入新描述符的值,但返回描述符的值大于等于传入的值的最小值(不像dup2强制关闭)
 2 F_GETF 取文件的权限和状态,取不到创建标记,不需要第三个参数
 3 F_SETFL 设置文件的状态标记,支队O_APPEND 有效
 4 文件锁的操作和使用。

当多个进程同时访问同一个文件时,有可能引发数据访问错误,因此为了保证数据有效,需要用文件锁 控制多个进程对同一个文件读写操作p。
 文件锁:在一个进程操作文件时,锁定其他进程对文件的操作,直到结束对文件的操作。
 目前文件锁都采用读写锁,分为读锁和写锁
读锁:共享锁,允许多个进程对文件的某个区域加读锁
写锁:互斥锁,排他锁,只能有一个进程加锁。
加了读锁的区域,不能再加写锁
结论:如果一个进程对文件的某个区域加了读锁,其它进程可以对该区域加读锁,但不能加写锁,如果一个进程对文件的某个区域加了写锁,其他进程对该区域不能加任何锁

文件锁锁定文件的某部分
fcntl()对文件加锁解锁 int fcntl(int fd, int cmd, ... /* arg */ );
cmd可以是
F_SETLK  加锁/解锁 如果加不上锁,返回-1  F_SETLK (struct flock *)
F_SETLKW 加锁/解锁,如果加不上锁 等待  出错返回-1
F_GETLK  测试某个锁能某加上,但不真正加锁
文件锁用  struct flock 代表
struct flock
{
 short l_type; //锁的类型 F_RDLCK F_WRLCK,F_UNLCK
 short l_whence;//锁的起始点参照
 int l_start; //锁的起始点的偏移量
 int l_len; //锁的长度
 pid_t l_pid;F_GETLK专用,SET时不用,-1即可
}
锁定起始点  由l_where 和 l_start联合决定
注:1 加读锁/写锁fd要有对应权限
 2 进程结束会释放锁,但程序员应该读写完毕就主动释放锁,fcnl(fd,F_SETLK,&lock)其中lock的l_type设置为F_UNLCK即可

文件锁起始不是对read()/write()等读写函数的锁定,而是阻止其他进程对文件的莫个区域进行加锁,文件锁正确的使用方法是:
 在调用read()之前加读锁,调用write()之前加写锁

F_GETLK测试一个锁能否被加上,如果能加上,会把锁的类型改成G_UNLCK,其他不变,不能加会把锁的成员改成当前正在锁定的那个锁(不能锁的原因),并且把l_pid改成加锁的进程,一般用pid是否等于-1判断是否能加锁。

C语言描述时间的方式
time_t -秒差(和1970年1月1日0点0分0秒的秒差)
struct tm - 结构体 成员包括 年,月,日,小时,分,秒

内存地址表示变量在内存中的位置,i节点表示文件/目录在硬盘中的位置
文件表中存储的数据:1 文件偏移量;2 文件描述符的状态(内存中);3 文件自身的属性(硬盘中文件信息)

17,UC(06)的更多相关文章

  1. jjava Date格式是 May 07 17:44:06 CST 2018,怎么插入数据库中的timestamp格式中

    首先 我来记录下错误 死在时间格式转换错误手里了 大致就是时间格式转化失败 java代码中的May 07 17:44:06 CST 2018  是这个格式转换为 数据库的 yyyy-MM-dd HH: ...

  2. 2017年5月11日17:43:06 rabbitmq 消费者队列

    从昨天开始发现个问题,一个接口在本地调用时大部分正常,一旦在生成者打一个断点调试,并且在promotion也打断点的时候会出现没有返回channel的异常,然后消费者就再也消费不了了 16:57:45 ...

  3. cdh中hdfs非ha环境迁移Namenode与secondaryNamenode,从uc机器到阿里;

    1.停掉外部接入服务: 2 NameNode Metadata备份: 2.1 备份fsimage数据,(该操作适用HA和非HA的NameNode),使用如下命令进行备份: [root@cdh01 df ...

  4. 转--python 编码规范

    编程规范 1.1. 命名规范 1.1.1. [强制] 命名不能以下划线或美元符号开始和结尾 反例: name / __name / $Object / name / name$ / Object$ 1 ...

  5. hadoop 2.7.3本地环境运行官方wordcount

    hadoop 2.7.3本地环境运行官方wordcount 基本环境: 系统:win7 虚机环境:virtualBox 虚机:centos 7 hadoop版本:2.7.3 本次先以独立模式(本地模式 ...

  6. android 事件分发机制详解(OnTouchListener,OnClick)

    昨天做东西做到触摸事件冲突,以前也经常碰到事件冲突,想到要研究一下Android的事件冲突机制,于是从昨天开始到今天整整一天时间都要了解这方面的知识,这才懂了安卓的触摸和点击事件的机制.探究如下: 首 ...

  7. sql server 取文件名函数 转载

    /****** Object: UserDefinedFunction [dbo].[GetDirectoryPath] Script Date: 2016-12-16 16:54:05 ****** ...

  8. Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(上)

    <Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(上)> <Oracle简单常用的数据泵导出导入(expdp/impdp)命令举例(下)> 目的:指导项 ...

  9. 跨域之jsonp

    我们都知道使用<script>标签可以引入外部的JS文件,即使这个JS文件来自于其他的网站,比如我们引用存放在网络服务器上的jQuery框架.在这个过程中,我们已经实现跨域访问.像< ...

随机推荐

  1. Java并发(零)教程目录

    上网看博客的时候无意中发现了有一个Java并发的教程还不错,有20多篇讲并发的,一天翻译1篇似乎也不太难.Let's go! 原文地址:http://tutorials.jenkov.com/java ...

  2. System类及其getProterties( )和getProperty( )

    System这个类来源: public final class System extends Object System类包含若干个有用的类字段和方法,而且不能被实例化.System类提供的工具包括标 ...

  3. eclipse安装中文补丁包

    第一步:打开http://www.eclipse.org/babel/ 第二步:找到downloads. 第三步:点击Oxygen. 第四步:找到简体中文的zip插件并兵下载. 第五步:解压. 第六步 ...

  4. js学习笔记11----表单操作

    1.复选框选中 var aInput = document.getElementsByTagname('input'); aInput[0].checked=true;

  5. easyui datagrid列拖拽

    <script type="text/javascript"> var cols = [{ field: 'testName', title: '<span cl ...

  6. 关于VS2013常用到的快捷键

    版本一 VS2013常用快捷键: 1.回到上一个光标位置/前进到下一个光标位置 1)回到上一个光标位置:使用组合键“Ctrl + -”: 2)前进到下一个光标位置:“Ctrl + Shift + - ...

  7. [ACM] POJ 3349 Snowflake Snow Snowflakes(哈希查找,链式解决冲突)

    Snowflake Snow Snowflakes Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 30512   Accep ...

  8. Storm On YARN带来的优点

    1)弹性计算资源     将storm执行在yarn上后,Storm能够与其它计算框架(如mapreduce)共享整个集群的资源.这样当Storm负载骤增时,可动态为它添加计算资源. 负载减小时,能够 ...

  9. 统计 fastq 文件 q20 , GC 含量的软件

    二代测序的分析过程中,经常需要统计原始下机数据的数据量,看数据量是否符合要求:另外还需要统计q20,q30,GC含量等反应测序质量的指标: 在kseq.h 的基础上稍加改造,就可以实现从fastq 文 ...

  10. Dll 使用 PChar 参数的小例子 - 回复 "linximf" 的问题

    本例效果图: Dll 文件: library Lib; uses   SysUtils, Classes; {$R *.res} procedure Test(p: PChar); const   T ...