Lustre可靠性增强系统MTFS:第6篇 编程风格

本文详细介绍了MTFS文件系统的编程风格和函数返回值约定。强调了使用HENTRY、HRETURN和断言的重要性,并讨论了goto语句在系统软件中的合理应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

遵循约定总会使得多人协作的成本降低,对于软件开发来说也是这样。

6.1 编程风格

MTFS的编程风格基本与内核的风格基本保持一致。可以用indent命令查看是否有较大出入。一段代码如下所示:

int mtfs_setxattr(struct dentry *dentry, const char *name,const void *value, size_t size, int flags)
{
	int ret = 0;
	int undo_ret = 0;
	mtfs_bindex_t bindex = 0;
	HENTRY();
  
	HASSERT(mtfs_d2bnum(dentry));
	for (bindex = 0; bindex < mtfs_d2bnum(dentry); bindex++) {
		ret = mtfs_setxattr_branch(dentry, name, value, size, flags, bindex);
		if (ret) {
			bindex --;
			goto undo;
		}
	}
	goto out;
undo:
	for (; bindex >= 0; bindex--) {
		undo_ret = mtfs_undo_setxattr_branch(dentry, name, bindex);
		if (undo_ret) {
			report_undo_error();
		}
	}
out:
	HRETURN(ret);
}

以上述代码为例,需要注意:

1. 在重要函数的起始处加上HENTRY,结尾处用HRETURN或_HRETURN返回。这样可以通过内核日志机制跟踪函数调用过程。

2. 整个函数按流程顺序往下,如果出现意外,使用goto语句跳出,所做前面工作撤销或直接返回错误。虽然goto语句遭到了很多质疑,但是在系统软件中goto语句因其来得直接,仍不乏用武之地。例如在下面的情况下使用goto语句十分方便:函数依次地申请内存空间,如果某次申请失败,则goto到指定位置,逆序将所申请的内存释放。使用这种函数的流程控制方法的另一个好处,是使得函数只有一个HRETURN的返回点,流程清晰。

3. 多用HASSERT进行断言。断言好处多多,应当大加提倡,所以D语言之间将对断言的支持作为契约编程的一部分,加入到语言中。对输入参数进行断言,可以及早杜绝不规范参数的输入。对计算结果进行断言,可以及时发现程序BUG。更重要的是,它可以发现知识:在对系统理解的不全面时、不确定时,对重要的假设和判断进行断言,可以帮助验证这些理解的正确性。断言是意外情况的杀手,而意料之外则是BUG之源。健壮的源码总会有很大篇幅在处理常规情况之外的意外。

6.2 函数返回值

函数如果专用来申请内存,则函数名通常包含alloc。如果该函数申请内存失败,则返回NULL,否则返回指针。

如果函数不仅需要申请内存,还需要进行创建对象等初始化操作,则函数名通常包含new。申请内存失败,应返回 PTR_ERR(-ENOMEM),初始化失败应返回PTR_ERR(-errno),否则返回指针。

错误值参考posix对各错误值的含义定义,另外还要遵循一些约定。


本文章欢迎转载,请保留原始博客链接http://blog.youkuaiyun.com/fsdev/article

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值