函数调用不添加括号代表什么?

函数调用不添加括号代表什么?

今天在查看别人的项目代码时,发现了一些奇怪的写法,具体代码如下所示:

//返回值类型 (*指针名)(参数列表)
returnType (*pointerName)(param list);

本以为又是神奇的知识点,急忙搜索相关知识,却发现这就是传说中的函数指针

函数指针

一个函数总是占据一段连续的内存区域,函数名在表达式中有时也会被转换为函数所在内存区域的首地址,这概念和数组十分相似
如果把函数的入口地址赋予指针变量,使得这个指针变量指向函数所在的内存区域,然后通过这个指针变量就能调用该函数,这个指针就是函数指针(信息来源:C语言中文网)

注意:在(*pointName)中,括号改变了指针变量中星号的优先级,因此括号不能省略

函数指针使用实例
#include <stdio.h>

int max(int a, int b)
{
    if(a > b)
     return a;
    else if(a < b)
     return b;
}

int main()
{
    int x, y, max_val;
    int (*res)(int , int) = max;

    x = 2;
    y = 3;

    max_val = (*res)(x,y);

    printf("The res is: %d\n",max_val);
    return 0;
}

程序运行结果:The res is: 3

但是为什么使用函数指针呢?它的优势又体现在哪里呢?答案是回调函数

回调函数

回调函数的具体定义比较拗口,比较难以理解,因此比较生动的例子就是:小明到小红店里去购物,但是小红家恰好没货,因此小明留下了联系方式,等进货之后联系小明来购物

更加清晰的解释为:如果将函数指针作为参数被传递到函数中,当这个函数指针被用于调用其指向的函数时,我们就称这个函数为回调函数

回调函数的主要优势是解耦,即调用者和被调用者被分开,调用者无需了解谁是被调用者,它只需知道如果满足某条件之后,函数将被调用

回调函数使用实例

//代码参考自菜鸟教程

#include<stdio.h>

int call_back_1()
{
    printf("Hello, this is Callback_1 \n");
    return 0;
}

int call_back_2()
{
    printf("Hello, this is Callback_2 \n");
    return 0;
}

int call_back_3()
{
    printf("Hello, this is Callback_3 \n");
    return 0;
}

int Handle(int (*Callback)())
{
    Callback();
}

int main()
{
    Handle(call_back_1);
    Handle(call_back_2);
    Handle(call_back_3);
    return 0;
}

函数运行结果如下:

Hello, this is Callback_1 
Hello, this is Callback_2 
Hello, this is Callback_3 
### JavaScript 中函数调用时加括号不加括号的区别 在 JavaScript 中,函数是一种特殊的对象类型。当我们在代码中书写函数名时,如果不加括号,则表示这是一个指向函数的引用;而如果加上括号,则会尝试执行该函数并获取其返回值。 #### 1. **加括号的情况** 当函数名后跟随一对括号 `()` 时,这表明我们要立即执行此函数。括号可以为空(表示无参数),也可以包含实际参数列表。例如: ```javascript function greet(name) { console.log(`Hello, ${name}!`); } greet("Alice"); // 输出: Hello, Alice! ``` 上述例子展示了如何通过加括号来调用带有参数的函数[^2]。需要注意的是,在某些场景下,比如设置定时器时,`setTimeout(greet(), 1000)` 和 `setTimeout(greet, 1000)` 的行为完全同。前者会在当前上下文中立刻执行 `greet` 函数并将结果作为回调传递给 `setTimeout`,后者则是将未被执行的函数本身作为一个回调延迟执行[^3]。 #### 2. **不加括号的情况** 如果没有括号紧跟在函数名之后,那么它仅仅代表对该函数的一个引用而非真正的调用操作。这种情况下通常用于需要传递函数本身而是它的执行结果的情形之下。例如绑定事件处理程序或创建高阶函数等场合非常常见: ```javascript document.getElementById('myButton').addEventListener('click', greet); ``` 在这里并没有直接调用 `greet` 方法而是将其赋给了点击监听器以便稍后由浏览器引擎自动触发执行[^4]。 另外值得注意的一点是在 HTML 属性定义中的情况也类似——像 `<button onclick="sayHi()">Click Me</button>` 这样写法意味着每当按钮被按下就会马上运行 sayHi 函数; 如果改为 `<button onclick="sayHi">Click Me Again</button>`, 则会有任何效果发生因为这里只是简单声明了一个变量/表达式而已并未真正启动任何动作序列. 综上所述,理解何时应该以及应该附加圆括弧对于编写有效率且可维护性强的应用至关重要. ```javascript // 正确示范 - 使用匿名函数包裹已知逻辑以避免即时求值错误 setTimeout(function() { alert("World!"); }, 3000); // 错误示范 - 导致即刻弹窗显示 "Hello" setTimeout(alert("Hello"), 5000); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值