QT接收Linux内核,QT界面程序经过网路与普通的linux应用程序进行数据传送的情况...
有时候会遇到QT界面程序经过网路与普通的linux应用程序进行数据传送的情况:(UDP协议,非TCP协议)
个人感觉比管道、共享内存、信号量、消息队列好用
Qt udp_client
1.我们新建Qt4 GuiApplication,工程名为“udpSender”,选中QtNetwork模块,Base class选择QWidget。
2.我们在widget.ui文件中,往界面上添加一个Push Button,进入其单击事件槽函数。
3.我们在widget.h文件中更改。
添加头文件:#include
添加private私有对象:QUdpSocket *sender;
4.我们在widget.cpp中进行更改。
在构造函数中添加:sender = new QUdpSocket(this);
void Widget::on_pushButton_clicked() {
QByteArray datagram = “hello world!”;
sender->writeDatagram(datagram.data(),datagram.size(),
QHostAddress("192.168.1.10"),8888); //ip为目标机ip
}
这里我们定义了一个QByteArray类型的数据报datagram,其内容为“hello world!”。然后我们使用QUdpSocket类的writeDatagram()函数来发送数据报,这个函数有四个参数,分别是数据报的内容,数据报的大小,主机地址和端口号。对于数据报的大小,它根据平台的不同而不同,但是这里建议不要超过512字节。对于端口号,它是可以随意指定的,但是一般1024以下的端口号通常属于保留端口号,所以我们最好使用大于1024的端口,最大为65535。我们这里使用了8888这个端口号,一定要注意,在下面要讲的服务器程序中,也要使用相同的端口号。
应用程序:udp_server.c
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define SERVER_PORT 8888
#define MAX_MSG_SIZE 1024
void udps_respon(int sockfd)
{
struct sockaddr_in addr;
int addrlen,n;
char msg[MAX_MSG_SIZE];
while(1)
{ /* 从网络上读,并写到网络上 */
bzero(msg,sizeof(msg)); // 初始化,清零
addrlen = sizeof(struct sockaddr);
n=recvfrom(sockfd,msg,MAX_MSG_SIZE,0,(struct sockaddr*)&addr,&addrlen); // 从客户端接收消息
msg[n]=0;//将收到的字符串尾端添加上字符串结束标志
/* 显示服务端已经收到了信息 */
fprintf(stdout,"Server have received %s",msg); // 显示消息
}
}
int main(void)
{
int sockfd;
struct sockaddr_in addr;
/* 服务器端开始建立socket描述符 */
sockfd=socket(AF_INET,SOCK_DGRAM,0);
if(sockfd<0)
{
fprintf(stderr,"Socket Error:%s\n",strerror(errno));
exit(1);
}
/* 服务器端填充 sockaddr结构 */
bzero(&addr,sizeof(struct sockaddr_in));
addr.sin_family=AF_INET;
addr.sin_addr.s_addr=htonl(INADDR_ANY);
addr.sin_port=htons(SERVER_PORT);
/* 捆绑sockfd描述符 */
if(bind(sockfd,(struct sockaddr *)&addr,sizeof(struct sockaddr_in))<0)
{
fprintf(stderr,"Bind Error:%s\n",strerror(errno));
exit(1);
}
udps_respon(sockfd); // 进行读写操作
close(sockfd);
}
QT接收Linux内核,QT界面程序经过网路与普通的linux应用程序进行数据传送的情况...相关推荐
- 优化Linux内核参数/etc/sysctl.conf sysctl 《高性能Linux服务器构建实战:运维监控、性能调优与集群应用》...
优化Linux内核参数/etc/sysctl.conf sysctl <高性能Linux服务器构建实战:运维监控.性能调优与集群应用> http://book.51cto.com/ar ...
- win10支持linux内核,Win10将允许您加载自定义Linux内核
微软正在为Win10添加一个Linux内核,以支持Linux的Windows子系统.但是,猜测一下:你不必使用微软的Linux内核.您可以构建自己的自定义Linux内核供Windows使用. 此功能是 ...
- debian 编译linux内核源码,安装debian总结以及编译linux内核
1. 安装debian 使用unetbootin(http://unetbootin.sourceforge.net/)来创建启动盘,并且下载debian的基本包. 将磁盘进行压缩操作,并且保留出一个 ...
- 修改linux内核启动动画,Android 开机界面及Linux内核启动界面的修改(tiny6410)
第一开机界面替换,即内核bootloader启动小企鹅界面更换 1.首先找一个自定义120*120的png图像,这里名称linux.png,但是后面的ppm名称必须是图中所示 在linux下执行下面代 ...
- Linux内核分析(一)通过汇编代码,理解程序在计算机中是如何运行的
作者:于波 声明:原创作品转载请注明出处 来源:<Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 首 ...
- linux内核做界面,基于linux内核制作linux系统
作者:哈尔滨师范大学 计算机学院 2013级 学生 刘聘婷 环境和工具: 编译环境: Ubuntu 15.04 工具:Buildroot-2015.08.1 (http://buildroot.uc ...
- 如何进行linux内核开发,2. 开发流程如何工作 — The Linux Kernel documentation
2.1.总览¶ 内核开发人员使用一个松散的基于时间的发布过程,每两到三个月发布一次新的主要 内核版本.最近的发布历史记录如下: 4.11 四月 30, 2017 4.12 七月 2, 2017 4.1 ...
- 【嵌入式环境下linux内核及驱动学习笔记-(16)linux总线、设备、驱动模型之input框架】
目录 1.Linux内核输入子系统概念导入 1.1 输入设备工作机制 1.2 运行框架 1.3 分层思想 2.驱动开发步骤 2.1 在init()或probe()函数中 2.2 在exit()或rem ...
- linux内核对孤儿进程寻父,读薄「Linux 内核设计与实现」(2) - 进程管理和调度
这篇文章是<读薄「Linux 内核设计与实现」>系列文章的第 II 篇,本文主要讲了以下问题:进程管理的任务.进程管理与其他模块的依赖关系.进程描述符和任务队列.进程的创建.线程的实现.进 ...
最新文章
- 7.3.3 多路复用IO(IO multiplexing)
- Oracle ——如何确定性能差的 SQL
- tensorflow 各个版本的 CUDA 以及 Cudnn 版本对应关系
- 博弈-巴什博奕-P/N图
- 静态HTML网页设计作品 HTML5+CSS大作业——个人网页设计(7页)
- java 8 stream入门_跟上 Java 8 : Stream API 快速入门
- 美国诚实签经验——医生的预约单和赴美生子的费用明细表
- 从图片到dataframe——语义分割数据集制作全流程
- python播放url音频_从URL获取音频并播放i
- EAX、EBX、ECX、EDX
- 转换质量分数与摩尔分数
- 整车CAN网络介绍---CAN--PT CAN--Chassis CAN--Body CAN--Info CAN
- 阿里云科学家入选计算机顶会HPCA名人堂,他是什么来头?
- 阿里云OSS绑定自定义域名
- 20170909深度学习solar测试日志
- 红蓝对抗之邮件钓鱼攻击
- 教程:用强化学习玩转恐龙跳跳
- C语言编写程序火车出站,火车进出站问题
- bat文件打开cmd指向某个目录,并执行命令
- 01.git团队协作
热门文章
- 【Elasticsearch】Elasticsearch中数据是如何存储的
- 【Flink】Flink 使用 CopyOnWriteArrayList 进行数据缓存的时候 一个bug
- 【hortonworks/registry】registry源码主类该怎么运行
- 【Kafka】docker下kafka报错 IOException: Connection to xxx:19093 (id: 1002 rack: null) failed
- 95-136-041-源码-Operator-OneInputStreamOperator
- Spring : Spring 深入理解lombok
- spark学习-43-Spark的BlockManager
- java属于编译_《程序员修炼之道》-读书笔记一-Java到底属于编译型语言还是解释型语言?...
- 还在直接操作Redis?赶快来试试它....
- Java并发编程:从源码分析几道必问线程池的面试题?