Linux设备驱动程序中的静态函数?
问题描述:
为什么linux代码中设备驱动程序中大多数函数定义被定义为静态的原因是什么?是否有一个原因?Linux设备驱动程序中的静态函数?
我被告知这是为了确定范围并防止命名空间污染,任何人都可以详细解释为什么静态定义在此上下文中使用?
答
声明为静态的函数在它们定义的翻译单元之外不可见(翻译单元基本上是一个.c文件)。如果函数不需要从文件外部调用,那么它应该是静态的,以免污染全局名称空间。这使得相同的名称之间的冲突不太可能发生。导出的符号通常用某种子系统标签来识别,这进一步减少了冲突的范围。
通常,指向这些函数的指针最终会出现在结构体中,所以它们实际上是从它们定义的文件外部调用的,而不是它们的函数名称。
答
出于同样的原因,您在任何代码中都使用static。你只应该“发布”你的API调用,其他任何事情都会打开你的滥用行为,比如能够从驱动之外调用内部函数,这些几乎肯定会是灾难性的。
这是一个良好的编程习惯,只有让外界能够看到什么是必要的。这就是封装的全部内容。
答
我同意。这是任何C代码中的常见和明智的做法 - 不仅仅是内核代码!不要以为这只适用于低级别的东西,任何延伸过一个.c文件的C代码都应该考虑到这一点。