UDP网络通信反复发&收

java 复制代码
package UDP2;


import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.util.Scanner;

/*
*    完成UDP 通信快速入门    实现发1收1*/
public class Client {
    public static void main(String[] args) throws Exception{
        // 1创建客户端对象
       DatagramSocket socket= new DatagramSocket();

       //2创建数据包对象封装要发出去的数据
      /*    public DatagramPacket(byte buf[], int length,
        InetAddress address, int port)
        参数一 封装要发出去的数据
        参数二 我要发的参数大小
        参数三 服务端IP地址
        参数四 服务端端口

        */

        Scanner sc=new Scanner(System.in);

        while (true) {
            System.out.println("请说:");
           String msg= sc.nextLine();
          byte[] bytes= msg.getBytes();
          // 用户输入exit命令 退出客户端
            if ("exit".equals(msg)){
                System.out.println("欢迎下次光临! 退出成功!");
                socket.close(); //释放资源
                break; //跳出去循环
            }
            DatagramPacket packet =new DatagramPacket(bytes,bytes.length,
                    InetAddress.getLocalHost(),6666);


            // 3:开始正式发送数据包的数据发出去
            socket.send(packet);
        }

    }
}
java 复制代码
package UDP2;

      //完成UDP通信服务端

import java.net.DatagramPacket;
import java.net.DatagramSocket;

public class Server {
    public static void main(String[] args) throws Exception{
        //1创建一个服务端对象
        System.out.println("---------服务端启动---------");
       DatagramSocket socket= new DatagramSocket(6666);

       //2 创建数据对象用接收数据
        byte [] buffer=new byte[1024*64]; //1KB * 64=  64KB
        DatagramPacket packet=new DatagramPacket(buffer,buffer.length);

        while (true) {
            //3:开始正式设用数据包接收客户端发来的数据
            socket.receive(packet);

            //4:字节数组中的数据打印出来
            //接收多少倒出多少
            int lin= packet.getLength();
            String rs=new String(buffer,0,lin);
            System.out.println(rs);


            System.out.println(packet.getAddress().getHostAddress());
            System.out.println(packet.getPort());
            System.out.println("============================================");


        }

    }
}
相关推荐
一叶飘零_sweeeet12 分钟前
从繁琐到优雅:Java Lambda 表达式全解析与实战指南
java·lambda·java8
艾伦~耶格尔40 分钟前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
一只叫煤球的猫1 小时前
🕰 一个案例带你彻底搞懂延迟双删
java·后端·面试
最初的↘那颗心1 小时前
Flink Stream API 源码走读 - print()
java·大数据·hadoop·flink·实时计算
JH30732 小时前
Maven的三种项目打包方式——pom,jar,war的区别
java·maven·jar
带刺的坐椅3 小时前
轻量级流程编排框架,Solon Flow v3.5.0 发布
java·solon·workflow·flow·solon-flow
David爱编程3 小时前
线程调度策略详解:时间片轮转 vs 优先级机制,面试常考!
java·后端
阿冲Runner4 小时前
创建一个生产可用的线程池
java·后端
写bug写bug4 小时前
你真的会用枚举吗
java·后端·设计模式
喵手5 小时前
如何利用Java的Stream API提高代码的简洁度和效率?
java·后端·java ee