1.
#define ABC() do{...;...;}while(0)
#define ABC() do{...;...;}
在内核中经常见到第一种用法,第一种用法和第二种用法的区别在哪里呢?看下面的例子
例一:
if (a)
ABC();
else
...
例二:
ABC();
例一中如果我们将宏写成第二种形式,编译时会得到一个编译错误。例二中如果我们写成第二种形式,在编译时警告级别够高的情况下会得到一个编译警告。
2.
!!x, 比较简单,但比较巧妙的用法。
3.
#define XC(a, b) ({ __typeof__ ((a)) __t; __t = (a); (a) = (b); __t; })
该宏比较奇特之处在于该宏有返回值,为括号内最后一句话的返回值。例如:
c = XC(a, b)
执行完后c将是执行前a的值。
4.
#define list_entry(ptr, type, member) /
container_of(ptr, type, member)
#define container_of(ptr, type, member) ({ /
const typeof( ((type *)0)->member ) *__mptr = (ptr); /
(type *)( (char *)__mptr - offsetof(type,member) );})
举个例子说明这个宏的用法
typede struct
{
int a;
int b;
}struct_1;
int main()
{
struct_1 s1, *ptr;
ptr = list_entry(&s1.b, struct_1, b);
return 0;
}
可以通过s1.b的地址来找到s1的地址。
#define ABC() do{...;...;}while(0)
#define ABC() do{...;...;}
在内核中经常见到第一种用法,第一种用法和第二种用法的区别在哪里呢?看下面的例子
例一:
if (a)
ABC();
else
...
例二:
ABC();
例一中如果我们将宏写成第二种形式,编译时会得到一个编译错误。例二中如果我们写成第二种形式,在编译时警告级别够高的情况下会得到一个编译警告。
2.
!!x, 比较简单,但比较巧妙的用法。
3.
#define XC(a, b) ({ __typeof__ ((a)) __t; __t = (a); (a) = (b); __t; })
该宏比较奇特之处在于该宏有返回值,为括号内最后一句话的返回值。例如:
c = XC(a, b)
执行完后c将是执行前a的值。
4.
#define list_entry(ptr, type, member) /
container_of(ptr, type, member)
#define container_of(ptr, type, member) ({ /
const typeof( ((type *)0)->member ) *__mptr = (ptr); /
(type *)( (char *)__mptr - offsetof(type,member) );})
举个例子说明这个宏的用法
typede struct
{
int a;
int b;
}struct_1;
int main()
{
struct_1 s1, *ptr;
ptr = list_entry(&s1.b, struct_1, b);
return 0;
}
可以通过s1.b的地址来找到s1的地址。