TCP、UDP客户端

TCP客户端

#include <mystdio.h>

#define CLI_PORT 6666
#define CLI_IP "192.168.124.210"

int main(int argc, const char *argv[])//argv[1] IP  argv[2] 端口号
{
    if(argc <3)
    {
        printf("请在命令传参端口号和IP地址\n");
        return -1;
    }
    //创建流式套接字文件
    int cfd = socket(AF_INET,SOCK_STREAM,0);
    if(cfd < 0)
    {
        perror("socket");
        return -1;
    }
    printf("socket seccuss cfd = %d  __%d__\n",cfd,__LINE__);
    //允许端口号重复使用
    int reuse = 1;
    if(setsockopt(cfd,SOL_SOCKET,SO_REUSEADDR,&reuse,sizeof(reuse))<0)
    {
        perror("setsockopt");
        return -1;
    }
    
    //填充客户端自身的地址信息,给bind函数绑定使用;
    struct sockaddr_in cin;
    cin.sin_family = AF_INET;
    cin.sin_port   = htons(CLI_PORT);
    cin.sin_addr.s_addr   = inet_addr(CLI_IP);
    

    //填充服务器的地址信息,给connet函数使用
    struct sockaddr_in sin;
    sin.sin_family = AF_INET;
    sin.sin_port = htons(atoi(argv[1]));
    sin.sin_addr.s_addr = inet_addr(argv[2]);
    
    //连接指定的服务器
    if(connect(cfd,(struct sockaddr*)&sin,sizeof(sin))<0)
    {
        perror("connect");
        return -1;
    }
    printf("connet seccuss __%d__\n",__LINE__);
    
    
    char buf[128]="";
    ssize_t res;
    while(1)
    {
        //从终端输入数据
        printf("请输入数据>>>\n");
        fgets(buf,sizeof(buf),stdin);
        buf[strlen(buf)-1] = '\0';
        //发送数据
        res = send(cfd,buf,sizeof(buf),0);
        if(res < 0)
        {
            perror("send");
            return -1;
        }
    
        //接收
        bzero(buf,sizeof(buf));
        res = recv(cfd,buf,sizeof(buf),0);
        if(res < 0)
        {
            perror("recv");
            return -1;
        }
        else if(0 == res)
        {
            printf("服务器下线 __%d__\n",__LINE__);
            break;
        }
        printf("%s __%d__",buf,__LINE__);
        
    
    }

    close(cfd);

    return 0;
}

UDP客户端

#include <mystdio.h>

#define PORT 8888
#define IP "192.168.124.210"

int main(int argc, const char *argv[])
{
    int cfd = socket(AF_INET,SOCK_DGRAM,0);
    if(cfd < 0)
    {
        fprintf(stderr,"line:%d",__LINE__);
        perror("sockaddr");
        return -1;
    }
    printf("创建报式套接字成功 cfd=%d __%d__\n",cfd,__LINE__);
    //允许端口被重复使用
    int reuse = 1;
    if(setsockopt(cfd,SOL_SOCKET,SO_REUSEADDR,&reuse,sizeof(reuse))<0)
    {    
        fprintf(stderr,"line:%d",__LINE__);
        perror("setsockopt");
        return -1;
    }
    //填充服务器的地址信息
    struct sockaddr_in sin;
    sin.sin_family         = AF_INET;
    sin.sin_port         = htons(PORT);
    sin.sin_addr.s_addr = inet_addr(IP);


    char buf[128] = "";
    struct sockaddr_in rcv;
    socklen_t addrlen = sizeof(rcv);
    while(1)
    {
        bzero(buf,sizeof(buf));
        printf("请输入信息>>>\n");
        fgets(buf,sizeof(buf),stdin);
        buf[strlen(buf)-1] = '\0';
        if(sendto(cfd,buf,sizeof(buf),0,(struct sockaddr*)&sin,sizeof(sin))<0)
        {
            fprintf(stderr,"line:%d",__LINE__);
            perror("sendto");
            return -1;
        }
        if(strcmp(buf,"quit") == 0)
        {
            break;
        }
        printf("发送成功\n");

        bzero(buf,sizeof(buf));
        if(recvfrom(cfd,buf,sizeof(buf),0,(struct sockaddr*)&rcv,&addrlen)<0)
        {
            fprintf(stderr,"line:%d",__LINE__);
            perror("recvfrom");
            return -1;
        }
        if(strcmp(buf,"quit") == 0)
        {
            break;
        }
        printf("[%s:%d]  %s  __%d__\n",\
                inet_ntoa(rcv.sin_addr),ntohs(rcv.sin_port),buf,__LINE__);
        }

    close(cfd);
    return 0;
}

机械臂

#include <mystdio.h>

#define CLI_PORT 6666
#define CLI_IP "192.168.124.210"

int main(int argc, const char *argv[])//argv[1] IP  argv[2] 端口号
{
    if(argc <3)
    {
        printf("请在命令传参端口号和IP地址\n");
        return -1;
    }
    //创建流式套接字文件
    int cfd = socket(AF_INET,SOCK_STREAM,0);
    if(cfd < 0)
    {
        perror("socket");
        return -1;
    }
    printf("socket seccuss cfd = %d  __%d__\n",cfd,__LINE__);
    //允许端口号重复使用
    int reuse = 1;
    if(setsockopt(cfd,SOL_SOCKET,SO_REUSEADDR,&reuse,sizeof(reuse))<0)
    {
        perror("setsockopt");
        return -1;
    }

    //填充服务器的地址信息,给connet函数使用
    struct sockaddr_in sin;
    sin.sin_family = AF_INET;
    sin.sin_port = htons(atoi(argv[1]));
    sin.sin_addr.s_addr = inet_addr(argv[2]);
    
    //连接指定的服务器
    if(connect(cfd,(struct sockaddr*)&sin,sizeof(sin))<0)
    {
        perror("connect");
        return -1;
    }
    printf("connet seccuss __%d__\n",__LINE__);
    
    int fd = open("/dev/input/event1",O_RDONLY);
    if(fd<0)
    {
        perror("open");
        return -1;
    }
        
    struct input_event ev;
    
    char buf[5]={0xff,0x02,0x00,30,0xff};
    unsigned char str[5] = {0xff,0x02,0x01,20,0xff};
    if(send(cfd,buf,sizeof(buf),0)< 0)
    {
        perror("send");
        return -1;
    }
    if(send(cfd,str,sizeof(str),0)< 0)
    {
        perror("send");
        return -1;
    }

    while(1)
    {
        if(read(fd,&ev,sizeof(ev))<0)
        {
            perror("read");
            return -1;
        }

        switch(ev.code*ev.value)
        {
        case 17:
            buf[3] += 5;
            if(buf[3]>90)
                buf[3] = 90;
            break;
        case 31:
            buf[3] -= 5;
            if(buf[3] < -90)
                buf[3] = -90;
            break;
        case 30:
            str[3] -= 5;
            if(str[3] < 0)
                str[3] = 0;
            break;
        case 32:
            str[3] += 5;
            if(str[3] >180 )
                str[3] = 180;
            break;
        default:
            continue;
        }
        
        if(send(cfd,buf,sizeof(buf),0)<0)
        {
            perror("send");
            return -1;
        }
        if(send(cfd,str,sizeof(str),0)<0)
        {
            perror("send");
            return -1;
        }

    }
    close(cfd);

    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/827658.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

windows和linux服务器等保测评加固方法

服务器加固是通过各种方法增强服务器安全性的过程。保护操作系统免受黑客、破解者和攻击者的侵害。网络安全防护的目标是保密性、完整性、可用性、可控制性、不可否认性。 一、window服务器等保加固 以win2012和win2008 为例&#xff1a; &#xff08;win2008&#xff09; …

【UML建模】用例图

1 参与者 参与者的概念&#xff1a; 指系统以外的、需要使用系统或与系统交互的外部实体 可以分为&#xff1a;人、外部设备、外部系统 参与者的图形符号&#xff1a; 例 3.1 在一个银行业务系统中&#xff0c;可能会有以下参与者 客户 &#xff1a;在银行业务系统中办理…

React【Day2】

React表单控制 受控绑定 概念&#xff1a;使用React组件的状态&#xff08;useState&#xff09;控制表单的状态 双向绑定 MVVM 报错记录&#xff1a; 错误代码&#xff1a; import { useState } from "react";const App () > {const [value, setValue] useS…

TLV61048非同步升压BOOST转换器输入电压2.6-5.5V输出电流4A输出电压最高15V

推荐原因&#xff1a; 输入电压较低&#xff0c;输出电流可达3.5A SOT23-6封装 批量价格约0.70元 TLV61048引脚 TLV61048引脚功能 7 详细说明 7.1 概述 TLV61048是一款非同步升压转换器&#xff0c;支持高达 15 V 的输出电压和输入范围从 2.61 V 到 5.5 V。该TLV61048集成了…

LlamaIndex 加 Ollama 实现 Agent

AI Agent 是 AIGC 落地实现的场景之一&#xff0c;与 RAG 不同&#xff0c;RAG 是对数据的扩充&#xff0c;是模型可以学习到新数据或者本地私有数据。AI Agent 是自己推理&#xff0c;自己做&#xff0c;例如你对 AI Agent 说我要知道今天上海的天气怎么样&#xff0c;由于 AI…

serverLess

第一步 安装依赖 npm install serverless-devs/s g 第二步 配置秘钥&#xff1a; 第三步 执行终端 执行命令 s config add 选择 alibaba cloud &#xff08;alibaba&#xff09; 把对应的ID secret填写&#xff0c;第三个别名可以随便写&#xff1a; serverLess 查看是…

Kettle的安装及简单使用

Kettle的安装及简单使用 文章目录 Kettle的安装及简单使用一、kettle概述二、kettle安装部署和使用Windows下安装&#xff08; 1 &#xff09;概述 案例 1 &#xff1a;MySQL to MySQL主界面&#xff1a;**在kettle中新建转换--->输入--->表输入-->表输入双击**建立连…

js进行数据移除性能比较(splice,map)

当使用 splice() 方法处理大量数据时&#xff0c;确实会遇到性能问题&#xff0c;因为它涉及到移动数组中的元素&#xff0c;导致操作的时间复杂度为 O(n)。对于大量数据&#xff0c;频繁的插入和删除可能会导致性能下降。 1、设置数组数据为10000&#xff0c;使用splice移除数…

软件项目经理需要具备这 11 个能力

当前软件开发技术更新换代越来越快&#xff0c;各种项目实施管理思想也日新月异&#xff0c;作为一个软件项目经理&#xff0c;需要具备这 11 种能力&#xff1a; 1. 项目管理能力 了解项目管理的基本原则和方法&#xff0c;包括制定项目计划、资源分配、风险管理、问题解决和…

Python练习03

题目 解题思路 Demo58 通过字符串切片来进行反转操作 def _reverse():"""这是一个反转整数的函数"""num input("请输入想要反转的整数")print(num[::-1]) 运行结果 Demo61 首先制作一个判断边长的函数&#xff0c;通过三角形两边…

4.23学习总结

一.NIO(一) (一).简介: NIO 是 Java SE 1.4 引入的一组新的 I/O 相关的 API&#xff0c;它提供了非阻塞式 I/O、选择器、通道、缓冲区等新的概念和机制。相比与传统的 I/O 多出的 N 不是单纯的 New&#xff0c;更多的是代表了 Non-blocking 非阻塞&#xff0c;NIO具有更高的并…

【Linux高性能服务器编程】两种高性能并发模式剖析——半同步/半异步模式

hello &#xff01;大家好呀&#xff01; 欢迎大家来到我的Linux高性能服务器编程系列之两种高性能并发模式介绍&#xff0c;在这篇文章中&#xff0c;你将会学习到高效的创建自己的高性能服务器&#xff0c;并且我会给出源码进行剖析&#xff0c;以及手绘UML图来帮助大家来理解…

《HCIP-openEuler实验指导手册》1.4 Apache MPM工作模式调整

MPM介绍 二、配置步骤 查看MPM当前工作模式 方法一&#xff1a; httpd -M | grep mpm方法二&#xff1a; 浏览器访问&#xff1a;http://IP:端口/server-status 方法三&#xff1a; cat /etc/httpd/conf.modules.d/00-mpm.conf查看 LoadModule mpm_event_module modules/mo…

Iterator 迭代器

意图 提供一个方法顺序访问一个聚合对象中的各个元素&#xff0c;且不需要暴漏该对象的内部表示。 结构 Iterator&#xff08;迭代器&#xff09;定义访问和遍历元素的接口。ConcreteIterator&#xff08;具体迭代器&#xff09;实现迭代器接口&#xff1b;对该聚合遍历是跟踪…

DSSM 模型技术介绍

转自&#xff1a;git 本文属于新闻推荐实战-召回阶段-DSSM召回模型。区别于策略召回&#xff0c;基于向量召回也是目前工业界常用的一种召回方法。这里我们将介绍一个比较经典的召回模型DSSM&#xff0c;希望读者可以快速掌握模型原理以及细节&#xff0c;同时可以了解具体的实…

Nacos原理简单介绍

注册中心原理 官网&#xff1a;Nacos 注册中心的设计原理 | Nacos nacos注册中心采用了 &#xff1a;pull &#xff08;客户端的轮询&#xff09;和push &#xff08;服务端主动push&#xff09;策略 客户端启动时会将当前服务的信息包含ip、端口号、服务名、集群名等信息封装…

电脑问题快速判断

电脑开机没有任何反应 检查电源 检查电源是否有问题或损坏&#xff0c;可以短接方法检测 板电源卡口对自己接第四或第五根线&#xff0c;若风扇匀速转动&#xff0c;电源无问题&#xff0c;若不转动或转一下停一下&#xff0c;电源有问题 检查内部连线 确保主板上的线插的…

2024新算法角蜥优化算法(HLOA)和经典灰狼优化器(GWO)进行无人机三维路径规划设计实验

简介&#xff1a; 2024新算法角蜥优化算法&#xff08;HLOA&#xff09;和经典灰狼优化器&#xff08;GWO&#xff09;进行无人机三维路径规划设计实验。 无人机三维路径规划的重要意义在于确保飞行安全、优化飞行路线以节省时间和能源消耗&#xff0c;并使无人机能够适应复杂…

手把手教你搭建鲜花团购小程序

随着互联网的快速发展&#xff0c;线上小程序商城已经成为了一种流行的电商模式。对于花店来说&#xff0c;开发线上小程序商城不仅可以扩大销售渠道&#xff0c;提高销售效率&#xff0c;还可以增加客户粘性&#xff0c;提升品牌形象。下面就以花店为例&#xff0c;教你怎么开…

OceanBase V4.2特性解析:用 Show Trace 快速定位数据库性能瓶颈

在数据库日常运维中&#xff0c;当遇到慢SQL问题时&#xff0c;若无法迅速查明原因&#xff0c;将极大地影响用户的使用感受&#xff0c;甚至可能引发业务或服务的中断。相较于单机数据库&#xff0c;分布式数据库系统因其涉及多个节点和多组件的协同工作&#xff0c;集群规模可…