void(*set_message_handler( void(*f)() ))() 解析

  1. 首先需要了解c++操作符的优先级
    “()”的优先级高于”*“的优先级,“()”的结合性从左到右。

  2. 函数指针和指针函数的区别
    函数指针:本质上是指针,只不过这个指针指向了一个函数。
    void (*pFunc)(int);
    “()”操作符结合性是从左到右,先分析(*pFunc),这表明pFunc本质上是指针,后边的(int)表示这个指针指向的是一个函数,函数返回值为void,入参为int。

    指针函数:本质上是函数,只不过返回值为指针类型的数据。
    void* Func();
    根据优先级,先分析 Func(),这表明Func本质上是一个没有入参的函数
    再结合 void* 分析可知,返回类型为void*。

  3. 首先借助函数void(* set_message_handler(int a) )() 来熟悉函数返回类型为函数指针的情况

  • 根据优先级和结合性,首先分析(* set_message_handler(int a)) ,又由于 “()”的优先级 高于 “*” 的 优先级, 所以先分析set_message_handler(int a),很明显set_message_handler是个函数,入参为int,再结合*分析(* set_message_handler(int a) )表明set_message_handler函数的返回类型是指针,最后结合右侧()整体分析(* set_message_handler(int a) )()表明返回的指针是指向函数的(也就是函数指针),结合void可知返回的函数指针指向的函数是个没有入参且返回类型为void的函数。
#include<iostream>
using namespace std;

void ReturnFunc()
{
	std::cout << "ReturnFunc" << endl;
}

void(*set_message_handler(int a) )()
{
	std::cout << "a = " << a << std::endl;  //输出: a = 123
	return ReturnFunc;
}

int main()
{
	auto var = set_message_handler(123);
	var();  //调用ReturnFunc函数 输出: ReturnFunc
		
	return 0;
}

  1. 分析void(*set_message_handler( void(*f)() ))()
    void(*f)() 表示f是一个指向函数的指针,类似于我们定义了一个类型:
    typedef void (*funcPtr)();
    void(*f)() ==== funcPtr f
    void(*set_message_handler( void(*f)() ))() ==== void(*set_message_handler( funcPtr f ))()
    和第3节分析的是一致的 只不过入参由int变成了一个函数指针类型(funcPtr)。
#include<iostream>
using namespace std;

void paramFunc()
{
	std::cout << "paramFunc" << endl;
}

void ReturnFunc()
{
	std::cout << "ReturnFunc" << endl;
}

void(*set_message_handler(void(*f)()))()
{
	f(); //输出: paramFunc
	return ReturnFunc;
}

int main()
{
	auto var = set_message_handler(paramFunc);
	var();  //调用ReturnFunc函数 输出: ReturnFunc
		
	return 0;
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,我无法提供完整的 `mqtt_client.h` 程序,因为这取决于你使用的 MQTT 客户端库和你的代码实现。但是,下面是一个简单的 `mqtt_client.h` 文件示例,其中定义了一些可能需要的常量和函数: ```c #ifndef MQTT_CLIENT_H #define MQTT_CLIENT_H #include <stdint.h> #define MQTT_QOS_0 0 #define MQTT_QOS_1 1 #define MQTT_QOS_2 2 typedef struct mqtt_client_t mqtt_client_t; typedef struct { const char* host; uint16_t port; const char* client_id; const char* username; const char* password; } mqtt_client_config_t; typedef void (*mqtt_message_handler_t)(const char* topic, const char* payload, size_t len); mqtt_client_t* mqtt_client_new(const mqtt_client_config_t* config); void mqtt_client_free(mqtt_client_t* client); int mqtt_client_connect(mqtt_client_t* client); void mqtt_client_disconnect(mqtt_client_t* client); int mqtt_client_subscribe(mqtt_client_t* client, const char* topic, int qos); int mqtt_client_unsubscribe(mqtt_client_t* client, const char* topic); int mqtt_client_publish(mqtt_client_t* client, const char* topic, const char* payload, size_t len, int qos); void mqtt_client_set_message_handler(mqtt_client_t* client, mqtt_message_handler_t handler); #endif /* MQTT_CLIENT_H */ ``` 这个简单的头文件声明了一个 `mqtt_client_t` 类型,包含一个 MQTT 客户端的实例。它还定义了用于配置客户端的 `mqtt_client_config_t` 结构体,并声明了用于连接、订阅、发布和断开连接的函数。此外,它还声明了一个 `mqtt_message_handler_t` 函数指针类型,该类型用于处理接收到的 MQTT 消息。 请注意,这只是一个简单的示例,实际使用中可能需要根据使用的 MQTT 客户端库和需求进行修改和定制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值