注:需要根据电脑上安装的cmake和vs版本进行填写,如有些低版本的cmake不支持Visual Studio 2022(升级cmake版本),有的电脑上没有安装Visual Studio 2022(安装Visual Studio 2022,或者选择电脑上有的版本)
vs版本对应
Visual Studio 17 2022 | = Generates Visual Studio 2022 project files. |
Use -A option to specify architecture. | |
Visual Studio 16 2019 | = Generates Visual Studio 2019 project files. |
Use -A option to specify architecture. | |
Visual Studio 15 2017 [arch] | = Generates Visual Studio 2017 project files. |
Optional [arch] can be “Win64” or “ARM”. | |
Visual Studio 14 2015 [arch] | = Generates Visual Studio 2015 project files. |
Optional [arch] can be “Win64” or “ARM”. | |
Visual Studio 12 2013 [arch] | = Generates Visual Studio 2013 project files. |
Optional [arch] can be “Win64” or “ARM”. | |
Visual Studio 11 2012 [arch] | = Generates Visual Studio 2012 project files. |
Optional [arch] can be “Win64” or “ARM”. | |
Visual Studio 10 2010 [arch] | = Deprecated. Generates Visual Studio 2010 project files. |
Optional [arch] can be “Win64” or “IA64”. | |
Visual Studio 9 2008 [arch] | = Generates Visual Studio 2008 project files. |
Optional [arch] can be “Win64” or “IA64”. |
编译成功之后,在build文件夹下会生成Eclipse Paho C.sln
c.用Visual Studio2022打开build文件夹下的Eclipse Paho C.sln
d.根据实际使用场景选择合适的版本(Debug或Release),然后选择生成->重新生成解决方案,等待一段时间,可以看到0失败
e.此时可以在build文件夹下看到src文件夹下有个Debug或Release文件夹,里面有编译后生成的文件:paho-mqtt3a.dll、paho-mqtt3a.lib、paho-mqtt3c.dll、paho-mqtt3c.lib。
paho-mqtt3a : 一般实际开发中就是使用这个,a表示的是异步消息推送(asynchronous)。
paho-mqtt3as : as表示的是 异步+加密(asynchronous+OpenSSL)(本文步骤无法生成)。
paho-mqtt3c : c 表示的应该是同步(Synchronize),一般性能较差,是发送+等待模式。
paho-mqtt3cs : 同上,增加了一个OpenSSL而已(本文步骤无法生成)。
**3.**使用示例
3.1 新建C语言工程
具体操作过程可以参考文件【VS2022 和 VS2010 C语言控制台输出 Hello World】(https://blog.csdn.net/xijinno1/article/details/127826231)
3.2 在demo.cpp文件的同文件夹下新建一个文件夹,命名为【pahoC】
3.3 将源代码src文件夹下所有**.h的文件和build\src\Debug(或Release)文件夹下的4个文件(paho-mqtt3a.dll、paho-mqtt3a.lib、paho-mqtt3c.dll、paho-mqtt3c.lib)粘贴到pahoC****文件夹下**
注意:后续3步的操作,一定要在与编译pahoC的配置一样,否则程序将不可使用paho-mqtt3a.lib、paho-mqtt3c.lib。
3.4 在demo工程属性中添加包含目录
$(LocalDebuggerWorkingDirectory)pahoC
3.5 在demo工程属性中添加附加库目录
$(LocalDebuggerWorkingDirectory)pahoC
3.6 在demo工程属性中添加附加依赖项
paho-mqtt3a.lib;paho-mqtt3c.lib;
3.7 将下述示例代码覆盖demo.cpp中的所有内容
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "MQTTClient.h"
#define ADDRESS "tcp://localhost:1883"
#define CLIENTID "ExampleClientPub"
#define TOPIC "MQTT Examples"
#define PAYLOAD "Hello World!"
#define QOS 111
#define TIMEOUT 10000L
int main(int argc, char* argv[]) {
MQTTClient client;
MQTTClient_connectOptions conn_opts = MQTTClient_connectOptions_initializer;
MQTTClient_message pubmsg = MQTTClient_message_initializer;
MQTTClient_deliveryToken token;
int rc;
MQTTClient_create(&client, ADDRESS, CLIENTID,
MQTTCLIENT_PERSISTENCE_NONE, NULL);
conn_opts.keepAliveInterval = 20;
conn_opts.cleansession = 1;
if ((rc = MQTTClient_connect(client, &conn_opts)) != MQTTCLIENT_SUCCESS) {
printf("Failed to connect, return code %d\n", rc);
exit(EXIT_FAILURE);
}
pubmsg.payload = (void*)PAYLOAD;
pubmsg.payloadlen = strlen(PAYLOAD);
pubmsg.qos = QOS;
pubmsg.retained = 0;
MQTTClient_publishMessage(client, TOPIC, &pubmsg, &token);
printf("Waiting for up to %d seconds for publication of %s\n"
"on topic %s for client with ClientID: %s\n",
(int)(TIMEOUT / 1000), PAYLOAD, TOPIC, CLIENTID);
rc = MQTTClient_waitForCompletion(client, token, TIMEOUT);
printf("Message with delivery token %d delivered\n", token);
MQTTClient_disconnect(client, 10000);
MQTTClient_destroy(&client);
return rc;
}
3.8 运行测试程序
程序正常运行,将有如下输出,是正常现象:
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年嵌入式&物联网开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!
升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!**
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!