当前位置: 首页 > news >正文

竭诚网络网站建设公司网站建设的三要素

竭诚网络网站建设公司,网站建设的三要素,ai智能写作一键生成,网站开发入门看什么ESP-C3入门10. 创建TCP Client一、创建 tcp client的一般步骤1. 创建 tcp 套接字2. 配置服务器地址3. 连接服务器4. 发送数据5. 接收数据6. 关闭套接字二、创建tcp_client任务三、示例代码1. tcpClient.h2. tcpClient.c3. main.c一、创建 tcp client的一般步骤 本文示例使用的… ESP-C3入门10. 创建TCP Client一、创建 tcp client的一般步骤1. 创建 tcp 套接字2. 配置服务器地址3. 连接服务器4. 发送数据5. 接收数据6. 关闭套接字二、创建tcp_client任务三、示例代码1. tcpClient.h2. tcpClient.c3. main.c一、创建 tcp client的一般步骤 本文示例使用的是阻塞IO进行网络通讯。 在高性能的网络编程中可能会使用非阻塞IO或异步IO进行网络通讯。 1. 创建 tcp 套接字 使用 socket函数 int sock socket(AF_INET, SOCK_STREAM, IPPROTO_IP);2. 配置服务器地址 struct sockaddr_in server_addr; server_addr.sin_family AF_INET; server_addr.sin_port htons(server_port); inet_pton(AF_INET, server_ip, server_addr.sin_addr); 3. 连接服务器 int ret connect(sock, (struct sockaddr *)server_addr, sizeof(server_addr)); if (ret ! 0) {ESP_LOGE(TAG, Failed to connect to server, errno%d, errno);close(sock);return; } 4. 发送数据 int bytes_sent send(sock, send_buf, send_len, 0); if (bytes_sent 0) {ESP_LOGE(TAG, Failed to send data to server, errno%d, errno);close(sock);return; }5. 接收数据 // 接收数据 int bytes_recv recv(sock, recv_buf, recv_buf_size, 0); if (bytes_recv 0) {ESP_LOGE(TAG, Failed to receive data from server, errno%d, errno);close(sock);return; }6. 关闭套接字 close(sock);二、创建tcp_client任务 由于网络通信涉及到阻塞IO操作如果在主线程中直接调用网络API会导致主线程被阻塞无法处理其他任务。为了避免这种情况发生可以将网络通信放在RTOS任务中处理使得主线程可以继续运行。 另外使用RTOS任务的好处还在于可以方便地控制任务的优先级、堆栈大小等参数以及在需要的时候暂停、恢复、删除任务等操作。这样可以更加灵活地管理程序中的各个任务实现复杂的多任务协作。 示例使用 xTaskCreate函数创建freeRTOS的任务 xTaskCreate(tcp_client_task, tcp_client_task, 4096, NULL, 5, NULL);任务优先级是5栈大小是4096 定义连接tcp 的任务时注意需要保留参数 void tcp_client_task(void* pvParameters);三、示例代码 本示例会接前面章节连接WIFI的部分帮wifi.c wifi.h部分代码不重复编写 。 下面示例中tcpClient连接上服务器后会发送ping消息并等待服务器回应。如果服务器回应pong则握手成功 客户端继续发送10个报文 然后关闭连接重新请求连接服务端。 参考项目目录结构如下 1. tcpClient.h // // Created by hs26661 on 2023/2/16. //#ifndef ESP32_LEARN_TCPCLIENT_H #define ESP32_LEARN_TCPCLIENT_H#include string.h #include sys/socket.h #include netdb.h #include unistd.h void tcp_client_task(void* pvParameters);#endif //ESP32_LEARN_TCPCLIENT_H 2. tcpClient.c // // Created by hs26661 on 2023/2/16. // #include lwip/sockets.h #include esp_log.h#define SERVER_HOST 192.18.200.28 #define SERVER_PORT 3000 #define MESSAGE ping #define MAX_RETRY 5 // 最大重试次数 #define DATA_SIZE 256 // 数据包大小static const char *TAG TCP_CLIENT;/*** 创建 freeRtos任务 这里的参数注意不能删除* param pvParameters*/ void tcp_client_task(void* pvParameters){// 重试次数int retry_count 0;// 接收缓冲区char rx_buffer[DATA_SIZE];// 发送缓冲区char tx_buffer[DATA_SIZE];while(1){// 创建套接字struct sockaddr_in dest_addr;dest_addr.sin_addr.s_addr inet_addr(SERVER_HOST);dest_addr.sin_family AF_INET;dest_addr.sin_port htons(SERVER_PORT);int sock socket(AF_INET, SOCK_STREAM, IPPROTO_IP);// 连接服务端int err connect(sock, (struct sockaddr*) dest_addr, sizeof(dest_addr));if(err ! 0){if(retry_count MAX_RETRY){ESP_LOGE(TAG, connect failure retry limit);break;}ESP_LOGW(TAG, connect failure, retry count%d, retry_count);vTaskDelay(2000 / portTICK_PERIOD_MS);continue;}ESP_LOGI(TAG, connect to server success);retry_count 0;// 发送pingint tx_len sprintf(tx_buffer, MESSAGE);err send(sock, tx_buffer, tx_len, 0);if(err 0){ESP_LOGE(TAG, send ping failure);close(sock);continue;}// 接收pongint rx_len recv(sock,rx_buffer, sizeof(rx_buffer) -1, 0);if(rx_len0){ESP_LOGE(TAG, receive pong failure);close(sock);continue;}rx_buffer[rx_len] 0;if(strcmp(rx_buffer, pong) !0){ESP_LOGE(TAG, handshake failure);close(sock);continue;}ESP_LOGI(TAG, handshake success);// 发送数据包for(int i 0;i10;i){// 获取当前时间字符串time_t now time(NULL);struct tm timeinfo;localtime_r(now, timeinfo);char strftime_buf[64];strftime(strftime_buf , sizeof(strftime_buf), %c, timeinfo);// 发送数据包tx_len sprintf(tx_buffer, time:%s, strftime_buf);err send(sock, tx_buffer, tx_len, 0);if(err 0){ESP_LOGE(TAG, send data error);close(sock);break;}ESP_LOGI(TAG, send data %d success, i1);// 5秒后再发送vTaskDelay(5000 / portTICK_PERIOD_MS);}// 发送byetx_len sprintf(tx_buffer, bye);err send(sock, tx_buffer, tx_len, 0);if(err0){ESP_LOGE(TAG, send bye error);close(sock);continue;}// 关闭连接close(sock);ESP_LOGI(TAG, connection closed);// 重建 连接ESP_LOGI(TAG, reconnect);vTaskDelay(2000/ portTICK_PERIOD_MS);}vTaskDelete(NULL); }3. main.c #include string.h#include freertos/FreeRTOS.h #include freertos/task.h#include nvs_flash.h #include network/include/wifi.h #include network/include/tcpClient.hstatic const char *TAG wifi connection;void app_main() {int i 0;ESP_LOGE(TAG, app_main);// 初始化NVS存储区esp_err_t ret nvs_flash_init();if (ret ESP_ERR_NVS_NO_FREE_PAGES || ret ESP_ERR_NVS_NEW_VERSION_FOUND) {ESP_ERROR_CHECK(nvs_flash_erase());ret nvs_flash_init();}ESP_ERROR_CHECK(ret);// Wi-Fi初始化ESP_LOGI(TAG, Wi-Fi initialization);wifi_initialize();// Wi-Fi Station初始化wifi_station_initialize();// 创建 tcp client任务,优先级为5栈大小为4096xTaskCreate(tcp_client_task, tcp_client_task, 4096, NULL, 5, NULL);while (1) {vTaskDelay(pdMS_TO_TICKS(500));} } 运行结果 示例中使用阻塞IO通讯也可以将收发放在不同的任务中执行这样提高程序并发性在这种情况下可以创建两个套接字并使用同一服务器地址和端口号。在发送和接收数据时将不同的套接字分别用于不同的任务从而实现并发的发送和接收。 具体来说在两个任务中需要使用不同的套接字句柄socket handle来访问相同的服务器地址和端口。在每个任务中可以通过调用 socket()、connect() 和 close() 等函数来创建和管理套接字。发送和接收数据时需要在每个任务中使用不同的套接字句柄来分别发送和接收数据。 需要注意的是如果两个任务共用同一套接字句柄来进行发送和接收那么就可能会出现竞争条件导致数据错误或不完整。因此为了避免这种情况最好在每个任务中分别使用独立的套接字来进行通信。 本文不演示上述方案。
http://www.dnsts.com.cn/news/242502.html

相关文章:

  • 苏州网站关键词推广接广告的平台推荐
  • 企业网站建设不要空间可以吗东莞建设银行
  • 综合商城网站建设灰色行业推广引流
  • 邯郸网站建设 安联网络公司企业网站seo怎么做
  • 怎么做赌钱网站代理上海移动云网站建设
  • 网站响应速度验收wordpress采集淘宝客
  • 天津创思佳网络网站制作公司sem推广方案
  • 免费网站源码大全下载可以注销的网站
  • 济南正规企业站seo做旅游网站的首页的图片
  • 个人建设视频网站最专业 汽车网站建设
  • 怎么样做网站管理员国外字体设计网站
  • 重庆微网站开发公司wordpress邮箱插件漏洞
  • 网站起域名原则智能建造论文
  • 做网站的调查问卷工业企业解决方案
  • 品牌建设的思路视频网站seo怎么做
  • 贵港网站建设wordpress手机怎么分享链接
  • 做自媒体哪家网站好如何查看网站是谁建设的
  • 太原建站的模板什么叫营销模式
  • 做asp网站的实验收获wordpress wp_post
  • 企业网站维护无锡网站优化
  • 企业网站建设大概的费用社交媒体营销案例
  • 深圳网站公司排名网站开发流程图 最
  • 网站的绝对路径怎么做陆良县住房和城乡建设局网站
  • 门户网站推广介绍方案wordpress 图片模板
  • 找公司做网站需要注意百度投放广告平台
  • 网站主题颜色国外军事新闻最新消息
  • 网站建站要多少钱阿里云虚拟主机多个网站吗
  • 360元网站建设 网络服务什么是网络营销的红海
  • 海口快速建站公司推荐上海3d网站建设
  • wordpress网站专题信誉好的东莞网站推广