加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java 网络编程-UDP基本步骤

发布时间:2020-12-15 07:56:54 所属栏目:Java 来源:网络整理
导读:UDP: 需要datagramSocket来进行中间的运输 无连接的传输层协议,提供面向事务的简单不可靠信息传输服务、可能丢失、非常简单、开销小 一切以包为中心 数据传输不用IO流 接收端 Address already in use: Cannot bind同一个协议下端口不允许冲突 1、使用Datag
UDP:
需要datagramSocket来进行中间的运输
无连接的传输层协议,提供面向事务的简单不可靠信息传输服务、可能丢失、非常简单、开销小
一切以包为中心
数据传输不用IO流

接收端
Address already in use: Cannot bind同一个协议下端口不允许冲突
1、使用DatagramSocket指定端口 创建接收端
2、准备容器封装成DatagramPacket 包裹
3、阻塞式接受包裹receive(DatagramPacket p);
4、分析数据getData()返回类型为字节数组,getLength()返回数据长度,类型为int
5、释放资源

public class http {

public static void main(String[]args) throws  Exception
{
    System.out.println("接收方启动中...");
    //1、使用DatagramSocket指定端口 创建接收端
    DatagramSocket server=new DatagramSocket(9999);//同一台电脑上端口不要冲突
    //2、准备容器封装成DatagramPacket 包裹
    byte[] container=new byte[1024*60];
    DatagramPacket packet=new DatagramPacket(container,container.length);
    //3、阻塞式接受包裹receive(DatagramPacket p);
    server.receive(packet);//阻塞式,有等待时间
    //4、分析数据getData()返回类型为字节数组,getLength()返回数据长度,类型为int
    byte[] datas=packet.getData();
    int len=packet.getLength();
    System.out.println(new String(datas,datas.length));
    //5、释放资源
    server.close();
}
}

发送端
1、使用DatagramSocket指定端口 创建发送端
2、准备数据,一定要转成字节数组
3、准备容器封装成DatagramPacket 包裹,需要指定目的地(ip地址和端口)
4、发送包裹send(DatagramPacket p);
5、释放资源

public class client {

public static void main(String[]args) throws IOException
{
    System.out.println("发送启动中...");
    //1、使用DatagramSocket指定端口 创建发送端
    DatagramSocket client =new DatagramSocket(8888);
    //2、准备数据,一定要转成字节数组
    String data="我最帅";
    byte[] datas=data.getBytes();
    //3、准备容器封装成DatagramPacket 包裹,需要指定目的地(ip地址和端口)
    DatagramPacket packet=new DatagramPacket(datas,datas.length,new InetSocketAddress("localhost",9999));
    //4、发送包裹send(DatagramPacket p);
    client.send(packet);
    //5、释放资源
    client.close();
}
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读