只有一个变量名的语句在C中输入(void)

Cha*_*Kim 7 c rtems

在RTEMS初始化例程中,我看到下面的代码.

void boot_card(const char *cmdline)
{
  rtems_interrupt_level  bsp_isr_level;

  /*
   * Special case for PowerPC: The interrupt disable mask is stored in SPRG0.
   * It must be valid before we can use rtems_interrupt_disable().
   */
  #ifdef PPC_INTERRUPT_DISABLE_MASK_DEFAULT
    ppc_interrupt_set_disable_mask( PPC_INTERRUPT_DISABLE_MASK_DEFAULT );
  #endif /* PPC_INTERRUPT_DISABLE_MASK_DEFAULT */

  /*
   *  Make sure interrupts are disabled.
   */
  (void) bsp_isr_level;      // <--- 
  rtems_interrupt_disable( bsp_isr_level );
  -- continues--
Run Code Online (Sandbox Code Playgroud)

在上面的代码中,在开头,bsp_isr_level被声明为rtems_interrupt_level类型(最终类型定义为unsigned int).
但是,线路(void) bsp_isr_level;在做什么?(标有// < - 上面).这不是传递作为函数参数作为一个变量这里.

编辑:我发现在我的情况下变量是由rtems_interrupt_disable函数分配的(实际上它是一个宏#defined)所以它不是'没有被使用'.但是虽然已分配,但似乎未使用指定的值.我不知道这种语法是否也用于这种情况(值已分配但未使用).顺便说一句,我发现在RTEMS源代码树中有一个函数(实函数,而不是#defined)rtems_interrupt_disable,如下所示具有void参数.(在cpukit/rtems/src/intrbody.c中).(#defined版本在cpukit/rtems/include/rtems/rtems/intr.h中)

rtems_interrupt_level rtems_interrupt_disable( void )
{       
  rtems_interrupt_level previous_level;

  _ISR_Disable( previous_level );

  return previous_level;
} 
Run Code Online (Sandbox Code Playgroud)

所以也许这个语法可能只是用于第二个定义(该值作为void传递给函数).我想因为存在第二个定义,可以在某些构建案例中使用.

unw*_*ind 10

它没有做任何事情.

将变量名称转换(void)为一种常见的方式来说"扔掉它",同时仍然引用命名变量.

它通常在函数内部完成,以"使用"参数,否则会触发未使用的参数或变量的警告.

在这种情况下,它看起来没必要,可能是重构的残留.

我在他们的公共Git中挖了一下(我也不知道RTEMS),但似乎不可能在blame没有做本地克隆的情况下运行.通过查看文件的头版本,似乎很清楚,有问题的代码没有预处理器技巧,它显示为引用.