为了简化常见的位图查找,我决定为它编写一个宏。此宏将接受参数数组、位置和每个条目的位数。后者总是1、2或3,在编译时确定。
每个条目一位和两位的宏非常简单:
#define 1BITLOOKUP(array, index) (array[index / CHAR_BIT] >> (index % CHAR_BIT)) & 1
#define 2BITLOOKUP(array, index) (array[2 * index / CHAR_BIT] >> (2 * index % CHAR_BIT)) & (0x11)
但是,三位位图将更加复杂,因为它将跨越字节边界。为了提高效率,当我只使用一位和两位查找时,我不希望包含该代码。所以我想用这样的宏
#define BITMAPLOOKUP(array, index, k) kBITLOOKUP(array, index)
但是,这不起作用。有解决办法吗?
注:根据多个评论者的请求,这已更新为非最小工作示例。
最佳答案
@疯狂物理学家建议如下:
#include <stdio.h>
static void func0(void) { printf("0\n"); }
static void func1(void) { printf("1\n"); }
static void func2(void) { printf("2\n"); }
static void func3(void) { printf("3\n"); }
static void (*func[])(void) = {func0, func1, func2, func3};
int main(void)
{
func[1]();
return 0;
}
这有一个优点:您不仅限于编译时文本:
for (int i = 0; i < 3; i++) {
FUNCTION(i); /* invalid */
func[i](); /* valid */
}
关于c - 您可以根据参数选择#define吗?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/44272447/