linux内核中结构体包含宏定义的解释

本文探讨了在Linux内核代码中结构体内部包含宏定义的现象,解释了这种做法不会导致宏重复定义的问题,并阐述了其潜在的好处。通过实例展示了宏定义如何在预编译过程中发挥作用,确保代码的正确性和灵活性。
  1.   在看linux内核代码时会看到一些结构体中包含宏定义:

    点击(此处)折叠或打开

    1. struct i2c_msg {
    2.     __u16 addr;    /* slave address            */
    3.     __u16 flags;
    4. #define I2C_M_TEN        0x0010    /* this is a ten bit chip address */
    5. #define I2C_M_RD        0x0001    /* read data, from slave to master */
    6. #define I2C_M_NOSTART        0x4000    /* if I2C_FUNC_PROTOCOL_MANGLING */
    7. #define I2C_M_REV_DIR_ADDR    0x2000    /* if I2C_FUNC_PROTOCOL_MANGLING */
    8. #define I2C_M_IGNORE_NAK    0x1000    /* if I2C_FUNC_PROTOCOL_MANGLING */
    9. #define I2C_M_NO_RD_ACK        0x0800    /* if I2C_FUNC_PROTOCOL_MANGLING */
    10. #define I2C_M_RECV_LEN        0x0400    /* length will be first received byte */
    11.     __u16 len;        /* msg length                */
    12.     __u8 *buf;        /* pointer to msg data            */
    13. };
    第一次看到觉得怪怪的,虽然我知道宏定义作用于开始定义处,结束于#undef。网上也看到一些人的疑问,比如:

             a) 如果去定义这样的结构体变量,会不会导致一个宏重复定义。

             b) 既然这样没错误,那么有什么好处。

2.    通过看如下程序预编译后的结果:

点击(此处)折叠或打开

  1. struct mystruct {
  2.         #define XPOS 1 
  3.         #define YPOS 2 
  4.         int a;
  5.         char b;
  6. }; 

  7. int main(void)
  8. {
  9.         struct mystruct ex1 = {2, 'a'};
  10.         struct mystruct ex2 = {3, 'b'};
  11.         ex1.a=XPOS;
  12.         ex2.a=YPOS;
  13.         
  14.         return 0;
  15. }
gcc main.c -E > main.E预编译后:

点击(此处)折叠或打开

  1. # 1 "main.c"
  2. # 1 ""
  3. # 1 ""
  4. # 1 "main.c"


  5. struct mystruct {


  6.  int a;
  7.  char b;
  8. };

  9. int main(void)
  10. {
  11.  struct mystruct ex1 = {2, 'a'};
  12.  struct mystruct ex2 = {3, 'b'};
  13.  ex1.a=1; 
  14.  ex2.a=2; 
  15.         
  16.         
  17.        
  18.  return 0;
  19. }

      由此可见,我和存在上述2点疑问的人都忘记预编译和编译的作用时间不同。预编译时,宏被展开,宏定义处被拿掉了,所以接下来再用struct mystruct 来定义变量时,里面的宏已经不存在了,所以并不会导致一个宏重复被定义。至于这样编写代码的好处,有人说是增加代码的可阅读性,让人知道这些宏只会用于这个结构体中,还有就是便于对这个结构体进行扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值