acl  3.5.3.0
acl_fhandle.h
浏览该文件的文档.
1 #ifndef ACL_FHANDLE_INCLUDE_H
2 #define ACL_FHANDLE_INCLUDE_H
3 
4 #ifdef __cplusplus
5 extern "C" {
6 #endif
7 
8 #include "acl_define.h"
9 #include "acl_vstream.h"
10 #include "acl_vstring.h"
11 #include "acl_ring.h"
12 #include "../thread/acl_thread.h"
13 #include <time.h>
14 
15 /**
16  * 通用的存储文件句柄对象类型定义
17  */
18 
19 typedef struct ACL_FHANDLE ACL_FHANDLE;
20 
21 struct ACL_FHANDLE {
22  ACL_VSTREAM *fp; /**< 存储文件句柄 */
23  acl_int64 fsize; /**< 存储文件大小 */
24  int nrefer; /**< 该存储句柄被引用的计数值 */
25  acl_pthread_mutex_t mutex; /**< 线程锁 */
26 #if defined(_WIN32) || defined(_WIN64)
27  unsigned long tid; /**< 打开该存储的线程号 */
28  unsigned long lock_mutex_tid; /**< 加线程锁的线程号 */
29 #else
30  acl_pthread_t tid; /**< 打开该存储的线程号 */
31  acl_pthread_t lock_mutex_tid; /**< 加线程锁的线程号 */
32 #endif
33  unsigned int oflags; /**< 打开时的标志位 */
34 #define ACL_FHANDLE_O_FLOCK (1 << 0) /**< 使用文件锁 */
35 #define ACL_FHANDLE_O_MLOCK (1 << 1) /**< 使用线程锁 */
36 #define ACL_FHANDLE_O_MKDIR (1 << 2) /**< 是否自动检查并创建不存在的目录 */
37 #define ACL_FHANDLE_O_NOATIME (1 << 3) /**< 打开文件时添加 O_NOATIME 标志位 */
38 #define ACL_FHANDLE_O_DIRECT (1 << 4) /**< 打开文件时添加 O_DIRECT 标志位 */
39 #define ACL_FHANDLE_O_SYNC (1 << 5) /**< 打开文件时添加 O_SYNC 标志位 */
40 #define ACL_FHANDLE_O_EXCL (1 << 6) /**< 打开文件时是否是自动加锁 */
41 
42  unsigned int status; /**< 该存储文件句柄的状态 */
43 #define ACL_FHANDLE_S_FLOCK_ON (1 << 0) /**< 该存储句柄已经加文件锁 */
44 #define ACL_FHANDLE_S_MUTEX_ON (1 << 1) /**< 该存储句柄已经加线程锁 */
45 
46  time_t when_free; /**< 在延迟关闭缓存队列中存活的时间截 */
47  ACL_RING ring; /**< 缓存数据结点 */
48  size_t size; /**< 该 ACL_FHANDLE 对象的实际大小 >= sizeof(ACL_FHANDLE) */
49  void (*on_close)(ACL_FHANDLE*); /**< 当该文件缓存句柄真正关闭时的回调函数,可以为空 */
50 };
51 
52 #define ACL_FHANDLE_PATH(x) (ACL_VSTREAM_PATH((x)->fp))
53 
54 /**
55  * 初始化文件句柄操作,该函数须在程序运行初始化时被调用且只能被调用一次
56  * @param cache_size {int} 内部被打开文件句柄的最大个数
57  * @param debug_section {int} 调试级别
58  * @param flags {unsigned int}
59  */
60 void acl_fhandle_init(int cache_size, int debug_section, unsigned int flags);
61 #define ACL_FHANDLE_F_LOCK (1 << 0)
62 
63 /**
64  * 当程序退出时需要调用此函数来释放系统资源
65  */
66 void acl_fhandle_end(void);
67 
68 /**
69  * 打开一个文件
70  * @param size {size_t} 分配结构 FS_HANDDLE 需要的空间大小
71  * @param oflags {unsigned int} 打开文件句柄时的标志位, ACL_FHANDLE_O_XXX
72  * @param file_path {const char*} 文件名(包含路径)
73  * @param on_open {int (*)(ACL_FHANDLE*, void*)} 如果不为空,
74  * 则当文件句柄被成功打开后便调用此函数
75  * @param open_arg {void *} on_open 的回调参数之一
76  * @param on_close {void (*)(ACL_FHANDLE*)} 如果不为空,
77  * 则当文件句柄被正直关闭时便调用此函数
78  */
79 ACL_FHANDLE *acl_fhandle_open(size_t size, unsigned int oflags,
80  const char *file_path,
81  int (*on_open)(ACL_FHANDLE*, void*), void *open_arg,
82  void (*on_close)(ACL_FHANDLE*));
83 
84 /**
85  * 关闭一个文件句柄
86  * @param fs {ACL_FHANDLE*}
87  * @param delay_timeout {int} 如果 > 0, 则延迟该时间后才真正关闭,
88  * 否则,其引用计数为 0 则立即关闭
89  */
90 void acl_fhandle_close(ACL_FHANDLE *fs, int delay_timeout);
91 
92 /**
93  * 对一个文件句柄加锁(先加线程锁后加文件锁)
94  * @param fs {ACL_FHANDLE*}
95  */
97 
98 /**
99  * 对一个文件句柄解锁(先解文件锁再解线程锁)
100  * @param fs {ACL_FHANDLE*}
101  */
103 
104 #ifdef __cplusplus
105 }
106 #endif
107 
108 #endif
ACL_RING ring
Definition: acl_fhandle.h:47
void acl_fhandle_lock(ACL_FHANDLE *fs)
acl_int64 fsize
Definition: acl_fhandle.h:23
void acl_fhandle_unlock(ACL_FHANDLE *fs)
acl_pthread_mutex_t mutex
Definition: acl_fhandle.h:25
ACL_VSTREAM * fp
Definition: acl_fhandle.h:22
size_t size
Definition: acl_fhandle.h:48
acl_pthread_t lock_mutex_tid
Definition: acl_fhandle.h:31
ACL_FHANDLE * acl_fhandle_open(size_t size, unsigned int oflags, const char *file_path, int(*on_open)(ACL_FHANDLE *, void *), void *open_arg, void(*on_close)(ACL_FHANDLE *))
unsigned int status
Definition: acl_fhandle.h:42
void(* on_close)(ACL_FHANDLE *)
Definition: acl_fhandle.h:49
acl_pthread_t tid
Definition: acl_fhandle.h:30
void acl_fhandle_init(int cache_size, int debug_section, unsigned int flags)
time_t when_free
Definition: acl_fhandle.h:46
unsigned int oflags
Definition: acl_fhandle.h:33
void acl_fhandle_close(ACL_FHANDLE *fs, int delay_timeout)
void acl_fhandle_end(void)