C编程位表示

时间:2012-01-27 22:56:26

标签: c binary permutation bit indicator

例如,我有3个计数器(我基本上想要表示为真值(计数器> 0为真;否则为false)。这导致我的真值的2 ^ 3 = 8个排列如下所示:

000 001 010 011 100 101 110 111

然后每个排列映射到一个状态。如何将这些计数器转换为位级别的二进制表示,然后如何在开关结构中使用二进制表示来映射到状态? (例如,001映射到“包含x”,010映射到“包含y”,011将映射到“包含x和y”。这一切都可以移植到其他操作系统吗?

1 个答案:

答案 0 :(得分:7)

一种可能性是使用每个计数器对应的每个位的值定义常量:

#define CTR1_BIT 0x01
#define CTR2_BIT 0x02
#define CTR3_BIT 0x04

然后根据计数器值(零或非零)设置位。 |运算符执行按位逻辑OR运算(请参阅this for more information)。如果ctr1非零,则只设置变量state中的最低位。如果ctr2非零,则将state中的第二位设置为1并保持其他位不变。等

   int state = 0;

   if ( ctr1 )
      state |= CTR1_BIT;
   if ( ctr2 )
      state |= CTR2_BIT;
   if ( ctr3 )
      state |= CTR3_BIT;

然后打开可能的状态值:

   switch ( state )
      {
      case 0x00:
         printf( "state 0\n" );
         break;
      case 0x01:
         printf( "state 1\n" );
         break;
      case 0x02:

         ...

      case 0x07:
         printf( "state 7\n" );
         break;
      default:
         printf( "Invalid state\n" );
         assert(0);
      }