我的编程空间,编程开发者的网络收藏夹
学习永远不晚

java如何使用UDP实现点对点通信

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

java如何使用UDP实现点对点通信

本文小编为大家详细介绍“java如何使用UDP实现点对点通信”,内容详细,步骤清晰,细节处理妥当,希望这篇“java如何使用UDP实现点对点通信”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

整体的结构思路:

Stu和Tea是收发消息的两端;

Stu和Tea类都是通过启动两个线程完成通信的,这两个线程分别是发消息线程和收消息线程;

Stu类中启动的两个线程分别写在两个类里,Tea也是这样做。

Stu端及其收发消息代码:

import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.net.DatagramPacket;import java.net.DatagramSocket;import java.net.InetAddress;import java.net.SocketException;import java.net.UnknownHostException; public class Stu {     public static void main(String[] args) throws IOException {        new Thread(new StuSendThread("127.0.0.1", 8888)).start();        new Thread(new StuReceiverThread(8889)).start();    }}
import java.io.IOException;import java.net.DatagramPacket;import java.net.DatagramSocket;import java.net.SocketException;  public class StuReceiverThread implements Runnable{     private int port;     public StuReceiverThread(int port) {        this.port = port;    }        @Override    public void run() {        // 创建接收方        DatagramSocket socket;        try {            socket = new DatagramSocket(port);            while(true) {                // 准备容器                byte[] buf = new byte[1024];                DatagramPacket dPacket = new DatagramPacket(buf, buf.length);                // 阻塞式接受数据                try {                    socket.receive(dPacket);                } catch (IOException e) {                    e.printStackTrace();                }                // 分析数据                System.out.println(new String(buf));                if (new String(buf).equals("exit")) {                    break;                }            }            // 释放资源            socket.close();        } catch (SocketException e1) {            e1.printStackTrace();        }            }    }
import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.net.DatagramPacket;import java.net.DatagramSocket;import java.net.InetAddress;import java.net.SocketException; public class StuSendThread implements Runnable{     private DatagramSocket socket;    private BufferedReader br;    String IP;    int port;        public StuSendThread(String IP, int port) throws SocketException {        socket = new DatagramSocket();        br = new BufferedReader(new InputStreamReader(System.in));        this.IP = IP;        this.port = port;    }        @Override    public void run() {                while(true) {            // 准备数据            br = new BufferedReader(new InputStreamReader(System.in));            String msg;            try {                msg = br.readLine();                byte[] data = msg.getBytes();                // 封装数据                DatagramPacket dPacket = new DatagramPacket(data, data.length, InetAddress.getByName(IP), port);                // 发送数据                socket.send(dPacket);                if(msg.equals("exit")) {                    break;                }            } catch (IOException e) {                e.printStackTrace();            }                    }                // 关闭资源        try {            br.close();            socket.close();        } catch (IOException e) {            e.printStackTrace();        }            } }

Tea端及其收发消息代码:

import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.net.DatagramPacket;import java.net.DatagramSocket;import java.net.InetAddress;import java.net.SocketException; public class TeaSendThread implements Runnable{    private DatagramSocket socket;    private BufferedReader br;    String IP;    int port;     public TeaSendThread(String IP, int port) throws SocketException {        socket = new DatagramSocket();        br = new BufferedReader(new InputStreamReader(System.in));        this.IP = IP;        this.port = port;    }     @Override    public void run() {        while (true) {            // 准备数据            br = new BufferedReader(new InputStreamReader(System.in));            String msg;            try {                msg = br.readLine();                byte[] data = msg.getBytes();                // 封装数据                DatagramPacket dPacket = new DatagramPacket(data, data.length, InetAddress.getByName(IP), port);                // 发送数据                socket.send(dPacket);                if (msg.equals("exit")) {                    break;                }            } catch (IOException e) {                e.printStackTrace();            }         }         // 关闭资源        try {            br.close();            socket.close();        } catch (IOException e) {            e.printStackTrace();        }     } }
import java.io.IOException;import java.net.DatagramPacket;import java.net.DatagramSocket;import java.net.SocketException; public class TeaReceiverTread implements Runnable{    private int port;     public TeaReceiverTread(int port) {        this.port = port;    }        @Override    public void run() {        // 创建接收方        DatagramSocket socket;        try {            socket = new DatagramSocket(port);            while(true) {                // 准备容器                byte[] buf = new byte[1024];                DatagramPacket dPacket = new DatagramPacket(buf, buf.length);                // 阻塞式接受数据                try {                    socket.receive(dPacket);                } catch (IOException e) {                    e.printStackTrace();                }                // 分析数据                System.out.println(new String(buf));                if (new String(buf).equals("exit")) {                    break;                }            }            // 释放资源            socket.close();        } catch (SocketException e1) {            e1.printStackTrace();        }            }    }
import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.net.DatagramPacket;import java.net.DatagramSocket;import java.net.InetAddress;import java.net.SocketException; public class TeaSendThread implements Runnable{    private DatagramSocket socket;    private BufferedReader br;    String IP;    int port;     public TeaSendThread(String IP, int port) throws SocketException {        socket = new DatagramSocket();        br = new BufferedReader(new InputStreamReader(System.in));        this.IP = IP;        this.port = port;    }     @Override    public void run() {        while (true) {            // 准备数据            br = new BufferedReader(new InputStreamReader(System.in));            String msg;            try {                msg = br.readLine();                byte[] data = msg.getBytes();                // 封装数据                DatagramPacket dPacket = new DatagramPacket(data, data.length, InetAddress.getByName(IP), port);                // 发送数据                socket.send(dPacket);                if (msg.equals("exit")) {                    break;                }            } catch (IOException e) {                e.printStackTrace();            }         }         // 关闭资源        try {            br.close();            socket.close();        } catch (IOException e) {            e.printStackTrace();        }     } }

读到这里,这篇“java如何使用UDP实现点对点通信”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

java如何使用UDP实现点对点通信

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

java如何使用UDP实现点对点通信

本文小编为大家详细介绍“java如何使用UDP实现点对点通信”,内容详细,步骤清晰,细节处理妥当,希望这篇“java如何使用UDP实现点对点通信”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。整体的结构思路:Stu
2023-07-02

C#如何实现TCP和UDP通信

本篇内容主要讲解“C#如何实现TCP和UDP通信”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#如何实现TCP和UDP通信”吧!C#在命名空间System.Net.Sockets中对伯克利套接
2023-07-05

C语言如何实现UDP通信

这篇文章主要介绍了C语言如何实现UDP通信的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言如何实现UDP通信文章都会有所收获,下面我们一起来看看吧。UDP通信UDP是一种无连接的尽最大努力交付的不可靠连接,
2023-07-02

SpringBoot如何使用WebSocket实现点对点消息

这篇文章主要介绍“SpringBoot如何使用WebSocket实现点对点消息”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“SpringBoot如何使用WebSocket实现点对点消息”文章能帮助大
2023-07-06

C#如何实现局域网点对点

这篇文章主要介绍“C#如何实现局域网点对点”,在日常操作中,相信很多人在C#如何实现局域网点对点问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#如何实现局域网点对点”的疑惑有所帮助!接下来,请跟着小编一起来
2023-06-17

C#如何利用RabbitMQ实现点对点消息传输

这篇文章主要介绍C#如何利用RabbitMQ实现点对点消息传输,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!消息队列模型所有 MQ 产品从模型抽象上来说都是一样的过程:消费者(consumer)订阅某个队列。生产者(
2023-06-15

如何使用Java实现简单点餐系统

小编给大家分享一下如何使用Java实现简单点餐系统,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!程序控制分析:1、欢迎页循环:do-while2、Scanner
2023-06-29

如何使用Redis实现点赞取消点赞

这篇文章将为大家详细讲解有关如何使用Redis实现点赞取消点赞,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。代码实现:/** * * @param userId 点赞的人 * @p
2023-06-29

Java如何使用wait/notify实现线程间通信

本文小编为大家详细介绍“Java如何使用wait/notify实现线程间通信”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java如何使用wait/notify实现线程间通信”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习
2023-07-04

SpringBoot中怎么使用WebSocket实现点对点消息

本篇内容介绍了“SpringBoot中怎么使用WebSocket实现点对点消息”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、添加依赖,配
2023-06-08

如何使用Java SSM实现在线点餐系统

小编给大家分享一下如何使用Java SSM实现在线点餐系统,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!介绍项目编号:BS-PT-022本项目基于SSM框架实现在
2023-06-29

java如何利用socket通信实现Modbus-RTU通信协议

小编给大家分享一下java如何利用socket通信实现Modbus-RTU通信协议,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!ModbusModbus是一种串行
2023-06-14

Java如何实现线程通信

今天小编给大家分享一下Java如何实现线程通信的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。什么是线程通信、如何实现?所谓线
2023-06-30

python如何使用UDP实现客户端和服务器对话

这篇文章主要介绍“python如何使用UDP实现客户端和服务器对话”,在日常操作中,相信很多人在python如何使用UDP实现客户端和服务器对话问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”python如何使
2023-07-05

利用java如何实现一个短信通信功能

本篇文章为大家展示了利用java如何实现一个短信通信功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。短信信息的发送目前已经是项目中必不可少的部分,我们怎么通过web页面来实现把信息推送到别人手机上
2023-05-31

C++如何实现成对交换节点

这篇文章主要讲解了“C++如何实现成对交换节点”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++如何实现成对交换节点”吧!Swap Nodes in Pairs 成对交换节点Given a
2023-06-19

如何使用PHP和WebSocket实现实时通信

随着互联网技术的不断发展,实时通信已经成为了日常生活中不可缺少的一部分。利用WebSockets技术可以实现高效、低延迟的实时通信,而PHP作为互联网领域使用最广泛的开发语言之一,也提供了相应的WebSocket支持。本文将为大家介绍如何使
如何使用PHP和WebSocket实现实时通信
2023-12-17

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录