1、 对于编译时报redeclaration of enumerator "…"重复定义枚举类型或结构体的问题,一般是#include头文件存在嵌套的问题,比较实用的方法是,在结构体声明的XXX.h文件首部加上#ifndef XXX #
#ifndef _XXX_
#define _XXX_
/*实际代码内容*/
#endif
2、 判断一个指针是否有效IS_ERR()
(一般用在创建进程、线程时做判断)
在写设备驱动程序的过程中,涉及到的任何一个指针,必然有三种情况:
1. 有效指针;
2. NULL,空指针;
3. 错误指针,或者说无效指针
比如对于32bit的系统来说,内核空间最高地址0xffffffff,那么最后一个page就是指的0xfffff000~0xffffffff(假设4k一个page),这段地址是被保留的,留出一个page出来就可以让我们把内核空间的指针来记录错误。
而IS_ERR()就是来判断指针是不是错误指针。
struct task_struct *pstTask;
pstTask = kthread_create();
if(0 != IS_ERR(pstTask))
{
return -1;//返回失败
}
3、断言assert()
assert 的作用是先计算表达式 expression ,如果其值为假(即为0),那么它先向 stderr 打印一条出错信息,然后通过调用 abort 来终止程序运行。
1)在函数开始处检验传入参数的合法性
2)每个assert只检验一个条件,因为同时检验多个条件时,如果断言失败,无法直观的判断是哪个条件失败
3)不能使用改变环境的语句,因为assert只在DEBUG生效,如果这么做,会使用程序在真正运行时遇到问题
错误: assert(i++ < 100)
4)assert和后面的语句应空一行,以形成逻辑和视觉上的一致感
使用 assert 的缺点是,频繁的调用会极大的影响程序的性能,增加额外的开销。
在调试结束后,可以通过在包含 #include 的语句之前插入 #define NDEBUG 来禁用 assert 调用,示例代码如下:
#include
#define NDEBUG
#include
4、 #ifdef __cplusplus
extern “C” {
#endif
//c语法的一段代码
#ifdef __cplusplus
}
#endif
https://www.cnblogs.com/TurboLemon/p/6364241.html