Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
tcp
分享一种很简单的不阻塞TCP发送方法
发布于 2023-03-30 11:25:51 浏览:1336
订阅该版
[tocm] ## 背景介绍 最近在做一个功能的时候,要求将采集到的数据发送到TCP Server上,TCP Server有时候可能会出问题连接不上,这时候如果使用普通的TCP编程,就会造成数据采集的代码被阻塞了。 为了解决这个问题,我将TCP发送的代码使用一个单独的线程实现,数据采集的代码在另外一个线程实现,两个线程之间使用消息队列进行通信,这样既不会破坏TCP编程的基础模型,又可以实现应用代码非阻塞发送TCP数据。 ## 代码实现 代码实现如下,当采集到数据的时候,只需要调用`tcp_client_no_block_send`函数发送数据即可。 ```c #include
#include
#include
#include
#include
#include
#include
#define DBG_TAG "tcp_client" #define DBG_LVL DBG_INFO #include
typedef struct { uint8_t data[512]; uint32_t len; }S_MSG, *P_MSG; static rt_mq_t mq = RT_NULL; static void tcp_client_thread_entry(void* parameter) { int sockfd; struct sockaddr_in server_addr; S_MSG msg; SOCKET_INIT: sockfd = socket(AF_INET, SOCK_STREAM, 0); if( sockfd < 0 ) { LOG_E("create socket failed."); return; } rt_memset(&server_addr, 0, sizeof(server_addr)); server_addr.sin_family = AF_INET; server_addr.sin_addr.s_addr = inet_addr("192.168.1.100"); server_addr.sin_port = htons(10086); if( connect(sockfd, (struct sockaddr*)(&server_addr), sizeof(server_addr)) < 0 ) { LOG_E("connect failed"); closesocket(sockfd); goto SOCKET_INIT; } while(1) { if( rt_mq_recv(mq, &msg, sizeof(msg), RT_WAITING_FOREVER) != RT_EOK ) { continue; } if( send(sockfd, msg.data, msg.len, 0) <= 0 ) { closesocket(sockfd); goto SOCKET_INIT; } } } int tcp_client_no_block_send(const uint8_t *data, uint32_t len) { RT_ASSERT(mq!=RT_NULL); RT_ASSERT(data!=RT_NULL); S_MSG msg; if( len > sizeof(msg.data) ) { LOG_E("send len overflow"); return -1; } msg.len = len; rt_memcpy(msg.data, data, len); if( rt_mq_send(mq, &msg, sizeof(msg)) == -RT_EFULL ) { //LOG_E("tcp client msg overflow!"); } return 0; } static int tcp_client_init(void) { mq = rt_mq_create("tcp_mq", sizeof(S_MSG), 1, RT_IPC_FLAG_FIFO); if (mq == RT_NULL) { LOG_E("create message queue failed"); return -1; } rt_thread_t tcp_client_thread = rt_thread_create("tcp_client", tcp_client_thread_entry, RT_NULL, 2048, 10, 10); if (tcp_client_thread == RT_NULL) { LOG_E("create thread failed"); return -1; } rt_thread_startup(tcp_client_thread); return 0; } INIT_APP_EXPORT(tcp_client_init); ```
8
条评论
默认排序
按发布时间排序
登录
注册新账号
关于作者
BruceTan
这家伙很懒,什么也没写!
文章
5
回答
31
被采纳
1
关注TA
发私信
相关文章
1
freemodbus tcp
2
stm32f103 LWIP 2.0.2 TCP收发问题
3
AT_DEVICE TCP 接收大文件失败!
4
RT thread freemobus tcp通讯问题
5
hard fault on thread: tcpip
6
RT系统TCP收数据速度慢
7
TCP Client 断线重连
8
TCP数据包多包重合的问题
9
rtthread simulator中能够使用WIN10中得TCP/IP服务吗
10
lwip 跨网段ping不通的问题
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
编译报错
Debug
SFUD
msh
rt_mq_消息队列_msg_queue
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1443
个答案
289
次被采纳
张世争
805
个答案
174
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
148
次被采纳
本月文章贡献
出出啊
1
篇文章
4
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
1
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
投诉
建议
回到
底部