java基础总结:(3)TCP和UDP通信

2024-06-22 18:18
文章标签 java 基础 总结 udp 通信 tcp

本文主要是介绍java基础总结:(3)TCP和UDP通信,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

网络:一组相互连接的计算机,多台计算机组成,使用物理线路进行连接

网络编程的三要素:

    【1】IP地址:唯一标识网络上的每一台计算机,两台计算机之间通信的必备有素
    【2】端口号:计算机中应用的标号(代表一个应用程序)  0-1024系统使用或保留端口 ,  有效端口0-65536
    【3】通信协议:通信的规则 TCP,UDP
网络模型一
    OSI参考模式:开放系统互连参考模型(Open System Interconnect)
网络模型二
    TCP/IP参考模型:传输控制/网际协议  Transfer Controln Protocol/Internet Protocol

 OSI参考模型    TCP/IP
 应用层  应用层
 表示层 
 会话层 
 传输层传输层
网络层     网络层
 数据链路层   网络接口
 物理层   

IP地址的表示方法:

    IP 地址:32位,由4个8位二进制数组成
    IP表示方法:点分十进制
    IP地址 = 网络ID +主机ID
    网络ID:标识计算机或网络设备所在的网段
    主机ID:标识特定主机或网络设备

IP地址的分类

    地址类用于指定网络 ID 并在网络 ID 和主机 ID 之间提供分隔方法
    IANA负责分配A、B、C类网络地址,具体主机地址由机构组织自行分配

IP地址所对应的对象InetAddress

    方法         描述
 public static InetAddress getLocalHost() 获得主机名和IP地址
 public String getHostAddress()  获取IP地址
 public String getHostName()   获取主机名
 public static InetAddress getByName(String host)根据主机名获得IP地址 

   eg: 获得百度的主机名:

        InetAddress ia2=InetAddress.getByName("www.baidu.com");System.out.println("其它主机名称:"+ia2.getHostAddress());

        注意:有可能返回的主机ip有很多,只是显示了中的一个

 端口:port

    端口是虚拟的概念,并不是说在主机上真的有若干个端口。通过端口,可以在一个主机上运行多个网络应用程序。
     传输协议:
         UDP:相当于发短信(有字数限制),不需要建立连接,数据报的大小限制在64k内, 效率较高,不安全,容易丢包
        TCP:相当于打电话,需要建立连接, 效率相对比较低,数据传输安全,三次握手完成。 (点名+答到+确认)

    TCP,UDP,Datagram
        TCP:可靠,传输大小无限制,但是需要时间来建立连接,差错控制开发大;主要用于文本、程序等可靠性高的数据传输。
        UDP:不可靠,传输大小限制在64K以下,不需要建立连接,差错控制开销小;主要用于类似图像、声音、网络游戏、
            视频会议等等对可靠性要求没有那么高的业务进行传输。
        Datagram(数据报):是分组交换的一种形式,就是把所传递的数据分段打成“包”,再传送出去。与传统的“连接型”分组交换不同,
            它属于“无连接型”,是把打包成的每个“包”(分组)都作为一个“独立的报文”传送出去,所以叫做“数据报”。
            在开始通信之前不需要先连接好一条线路,各个数据报不一定都通过同一条路径传输。
     Socket套接字:
         网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket。    
         Java中使用Socket完成TCP程序的开发,使用此类可以方便的建立可靠的、双向的、持续性的、点对点的通讯连接
         在Socket的程序开发中,服务器端使用ServerSocket等待客户端的连接,
         对于java的网络程序来讲,每一个客户端都使用一个Socket对象表示
     基于TCP协议的Socket编程
         进行网络通信时,Socket需要借助数据流来完成数据的传递工作

 UDP通信
     在java.net包中提供了两个类DatagramSocket和DatagramPacket来支持数据报通信
    DatagramSocket:用于在程序之间建立传送数据报的通信连接,客户端与服务器端都需要建立
    DatagramPacket:用来表示一个数据报作为通信载体
    DatagramSocket的构造方法
    DatagramSocket( )
    DatagramSocket( int port)
    DatagramSocket( int port , InetAddress laddr)
    Port指明通信所使用的端口号,如果未指明端口号,则把socket连接到本地主机上一个可用的端口,给出的端口不能冲突
    Laddr:指明一个可用的本地地址
     UDP通讯服务器:

 public class UDP2 {public static void main(String[] args) {try {DatagramSocket ds=new DatagramSocket(4321);byte[] data=new byte[1024];//定义接受地缓冲区DatagramPacket dp=new DatagramPacket(data,data.length);ds.receive(dp);//接收数据包//以下是将接收到的字节数组转换为字符串并输出显示String mes=new String(dp.getData(),0,dp.getLength());System.out.println(mes);} catch (Exception e) {e.printStackTrace();}}}

    UDP通讯客户端:

     public class UDP1 {public static void main(String[] args) {try {DatagramSocket ds=new DatagramSocket(1234);String mes="你好,UDP2.";byte[] data=mes.getBytes();//将字符串转换为byte数组InetAddress ip=InetAddress.getByName("127.0.0.1");DatagramPacket dp=new DatagramPacket(data,data.length,ip,4321);ds.send(dp);//发送数据包} catch (Exception e) {e.printStackTrace();}}} 

    TCP与UDP的比较
    使用UDP时,每个数据报中都给出了完整的地址信息,因此无需要建立发送方和接收方的连接。
    对于TCP协议,由于它是一个面向连接的协议,在socket之间进行数据传输之前必然要建立连接,所以在TCP中多了一个连接建立的时间。
    使用UDP传输数据时是有大小限制的,每个被传输的数据报必须限定在64KB之内。
    而TCP没有这方面的限制,一旦连接建立起来,双方的socket就可以按统一的格式传输大量的数据。
    UDP是一个不可靠的协议,发送方所发送的数据报并不一定以相同的次序到达接收方。
    而TCP是一个可靠的协议,它确保接收方完全正确地获取发送方所发送的全部数据。 

这篇关于java基础总结:(3)TCP和UDP通信的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1085048

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件