有人可以解释这个问题发生了什么吗?
什么是理论或可能的低级解释
void(*ptr[2])() = {blah, blah2};
我是 C 新手,我想知道这里发生了什么;)
提前致谢。
PS:我搜索了一下,但不幸的是找不到任何东西。
有人可以解释这个问题发生了什么吗?
什么是理论或可能的低级解释
void(*ptr[2])() = {blah, blah2};
我是 C 新手,我想知道这里发生了什么;)
提前致谢。
PS:我搜索了一下,但不幸的是找不到任何东西。
它只是一个包含两个元素的函数指针数组——ptr[0]
指向函数blah()
和ptr[1]
指向函数blah2()
。
您可以像这样调用每个函数:
(ptr[0])(); // call blah()
(ptr[1])(); // call blah2()
你的意思是我怎么读这个?
您从原始答案中丢弃了一些有用的上下文,所以让我们修复它:
void print();
void exitme();
int main() {
void (*p[2])()={print,exitme};
所以现在很明显print
andexitme
指的是functions。具体来说,它们都返回 void 并且不带参数,因此它们共享函数指针类型
void (*)()
(即,该类型的函数指针可以指向或 )。例如,print
exitme
void (*print_or_exit)() = (rand() % 2) ? print : exitme;
print_or_exit(); // who knows what it will do!
现在,其中两个函数指针组成的数组如下所示:
void (*ptr[2])()
并且可以初始化为:
void (*ptr[2])() = { print, exitme };
所以现在我们可以将我们愚蠢的例子重写为:
void (*print_or_exit)() = ptr[rand() % 2];
void(*ptr[2])()
声明一个函数指针数组,其中blah
和blah2
是指向的函数。在这种情况下,指向的函数必须具有void
“返回类型”(即它们不能返回任何内容)并且不能有任何参数(由于()
声明末尾的)。
您链接到的示例代码使用这些函数指针来打印i
或退出应用程序的值(当i
= 100 并i/100
导致 1,这是第二个数组元素)
如示例所示,您可以使用以下函数调用函数:
i = 0; // or 1 (as your array has a size of 2)
(ptr[i])();
注意:这个例子可能被认为是(非常)不好的做法,所以请不要使用它来代替简单的for
循环!:)
即声明ptr
为两个函数指针的数组,并将它们初始化为分别指向两个函数blah()
和blah2()
。
需要括号来保护它不成为void *
(void pointers)的声明,这将是别的东西。
这是一个数组function-pointers
。您正在使用两个函数的地址blah
和blah2
.
ptr
是指向不返回任何值且没有参数的函数的指针数组。
通常,ptr[1]
调用exitme
函数,它调用exit(1)
并ptr[0]
调用处理打印的函数。该变量i
是静态的,因此当程序退出时它的使用结束。
在第一次迭代中,为指向exitme
和print
函数的两个指针的数组分配了一个新的内存块(实际上在每次迭代中,这都完成了,不像使用i
)。然后,声明一个静态变量i
并将其初始化为零(肯定在ansi-c
),稍后调用第一个函数(print
),因为i++/100
is0.001
但它等于0
(因为既没有进行强制转换,也没有进行float
)并且同时i
正在增加. 在调用print
并打印 的值之后i
,我们再次调用main
并不断迭代,直到i
达到 100。
请注意,有两个静态整数i
,但每个都有不同的范围,因此它们具有不同的值。
因此您打印 1...100 而不使用循环。