百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

大数据编程入门:Java网络编程(大数据 编程)

ztj100 2025-07-08 00:26 6 浏览 0 评论

如果想要编写出一个可以运行在多个设备上的程序,应该怎么做呢?答案是网络编程,今天小编将为大家带来大数据编程入门:Java网络编程。

一、网络编程概念

网络编程是指编写在通过网络连接的多个设备(计算机)上运行的程序。

网络编程的主要工作是在发送端通过指定的协议组装信息包,在接收端根据指定的协议对信息包进行分析,从而提取相应的信息,达到通信目的。

java.net包中的J2SE的API包含提供低级通信细节的类和接口,可以直接使用这些类和接口来专注于解决问题,而不必关注通信细节。

java.net包支持两种常见的网络协议:

1、TCP:TCP(Transmission Control Protocol,传输控制协议)是一种面向连接、可靠且基于字节流的传输层通信协议。TCP层是IP层之上和应用层之下的中间层。TCP保证两个应用程序之间的可靠通信。它通常用于internet协议,称为TCP/IP。

2、UDP:UDP(User Datagram Protocol,用户数据报协议),位于OSI模型的传输层。一种无连接的协议。提供数据报以在应用程序之间发送数据。由于UDP缺乏可靠性,并且属于无连接协议,因此应用程序通常必须允许一些丢失、不正确或重复的数据包。

二、Socket编程

套接字使用TCP在两台计算机之间提供通信机制。客户端程序创建套接字并尝试连接到服务器的套接字。

建立连接后,服务器将创建一个Socket对象。客户端和服务器现在可以通过写入和读取Socket对象进行通信。

java.net.Socket类表示套接字,而java.net.ServerSocket类为服务器程序提供了一种机制,用于侦听客户端并与客户端建立连接。

使用套接字在两台计算机之间建立TCP连接时,将出现以下步骤:

① 服务器实例化ServerSocket对象以表示通过服务器上的端口进行的通信。

② 服务器调用ServerSocket类的accept()方法,该方法将等待客户端连接到服务器上的给定端口。

③ 当服务器等待时,客户端实例化Socket对象并指定服务器名称和端口号以请求连接。

④ Socket类的构造函数尝试将客户端连接到指定的服务器和端口号。如果建立了通信,则在客户端上创建一个Socket对象以与服务器通信。

⑤ 在服务器端,accept()方法在服务器上返回一个新的socket引用,该引用连接到客户端的socket。

建立连接后,I/O流用于通信。每个socket都有一个输出流和一个输入流。客户端的输出流连接到服务器的输入流,客户端的输入流连接到服务器的输出流。

TCP是一种双向通信协议,因此可以通过两个数据流同时发送数据。下面是一些类为实现socket提供的一整套有用方法。

三、ServerSocket 类的方法

服务器应用程序通过使用Java.net.ServerSocket类获取一个端口,并侦听客户端请求。

ServerSocket 类有四个构造方法,如下所示:

方法

描述

public ServerSocket(int port) throws IOException

创建绑定到特定端口的服务器套接字。

public ServerSocket(int port, int backlog) throws IOException

使用指定的backlog创建服务器套接字,并将其绑定到指定的本地端口号。

public ServerSocket(int port, int backlog, InetAddress address) throws IOException

创建具有指定端口、侦听backlog和要绑定到的本地IP地址的服务器。

public ServerSocket() throws IOException

创建非绑定服务器套接字。

创建未绑定的服务器套接字。如果ServerSocket构造函数未引发异常,则表示应用程序已成功绑定到指定端口并侦听客户端请求。

以下是一些 ServerSocket 类的常用方法:

方法

描述

public int getLocalPort()

返回此套接字在其上侦听的端口。

public Socket accept() throws IOException

侦听并接受到此套接字的连接。

public void setSoTimeout(int timeout)

通过指定超时值启用/禁用 SO_TIMEOUT,以毫秒为单位。

public void bind(SocketAddress host, int backlog)

将 ServerSocket 绑定到特定地址(IP 地址和端口号)。

四、Socket 类的方法

java.net.Socket类表示客户端和服务器用于相互通信的套接字。客户端通过实例化获得Socket对象,而服务器通过accept()方法的返回值获得Socket对象。

以下是Socket类的五个构造方法:

方法

描述

public Socket(String host, int port) throws UnknownHostException, IOException.

创建一个流套接字并将其连接到指定主机上的指定端口号。

public Socket(InetAddress host, int port) throws IOException

创建一个流套接字并将其连接到指定 IP 地址的指定端口号。

public Socket(String host, int port, InetAddress localAddress, int localPort) throws IOException.

创建一个套接字并将其连接到指定远程主机上的指定远程端口。

public Socket(InetAddress host, int port, InetAddress localAddress, int localPort) throws IOException.

创建一个套接字并将其连接到指定远程地址上的指定远程端口。

public Socket()

通过系统默认类型的 SocketImpl 创建未连接套接字

当套接字构造函数返回时,它将实际尝试连接到指定的服务器和端口,而不是简单地实例化Socket对象。

下面列出了一些有趣的方法,请注意,客户端和服务器都有一个Socket对象,因此客户端和服务器都可以调用这些方法。

方法

描述

public void connect(SocketAddress host, int timeout) throws IOException

将此套接字连接到服务器,并指定一个超时值。

public InetAddress getInetAddress()

返回套接字连接的地址。

public int getPort()

返回此套接字连接到的远程端口。

public int getLocalPort()

返回此套接字绑定到的本地端口。

public SocketAddress getRemoteSocketAddress()

返回此套接字连接的端点的地址,如果未连接则返回 null。

public InputStream getInputStream() throws IOException

返回此套接字的输入流。

public OutputStream getOutputStream() throws IOException

返回此套接字的输出流。

public void close() throws IOException

关闭此套接字。

五、InetAddress 类的方法

InetAddress类表示互联网协议(IP)地址。下面列出了 Socket 编程时比较有用的方法:

方法

描述

static InetAddress getByAddress(byte[] addr)

在给定原始 IP 地址的情况下,返回 InetAddress 对象。

static InetAddress getByAddress(String host, byte[] addr)

根据提供的主机名和 IP 地址创建 InetAddress。

static InetAddress getByName(String host)

在给定主机名的情况下确定主机的 IP 地址。

String getHostAddress()

返回 IP 地址字符串(以文本表现形式)。

String getHostName()

获取此 IP 地址的主机名。

static InetAddress getLocalHost()

返回本地主机。

String toString()

将此 IP 地址转换为 String。

六、Socket 客户端实例

以下实例中的 GreetingClient 是一个客户端程序,该程序通过 socket 连接到服务器并发送一个请求,然后等待一个响应。

七、Socket 服务端实例

以下实例中的GreetingServer 程序是一个服务器端应用程序,使用 Socket 来监听一个指定的端口。

编译以上两个Java文件代码,运行结果是:

新开一个命令窗口,执行以上命令来开启客户端:

以上就是关于大数据编程入门:Java网络编程的全部内容了,希望这篇文章可以帮助到大家~

相关推荐

能量空间物质相互转化途径(能量与空间转换相对论公式)

代码实现<!DOCTYPEhtml><htmllang="zh"><head>...

从零开始的Flex布局掌握(flex布局实战)

前言在现代网页设计中,布局是一个至关重要的环节,在过去的一段时间里,页面的布局还都是通过table...

flex布局在css中的使用,一看就会!

1.认识flex布局我们在写前端页面的时候可能会遇到这样的问题:同样的一个页面在1920x1080的大屏幕中显示正常,但是在1366x768的小屏幕中却显示的非常凌乱。...

前端入门——弹性布局(Flex)(web前端弹性布局)

前言在css3Flex技术出现之前制作网页大多使用浮动(float)、定位(position)以及显示(display)来布局页面,随着互联网快速发展,移动互联网的到来,已无法满足需求,它对于那些...

CSS Flex 容器完整指南(css flex-shrink)

概述CSSFlexbox是现代网页布局的强大工具。本文详细介绍用于flex容器的CSS属性:...

Centos 7 network.service 启动失败

执行systemctlrestartnetwork重启网络报如下错误:Jobfornetwork.servicefailedbecausethecontrolprocessex...

CentOS7 执行systemctl start iptables 报错:...: Unit not found.

#CentOS7执行systemctlstartiptables报错:Failedtostartiptables.service:Unitnotfound.在CentOS7中...

systemd入门6:journalctl的详细介绍

该来的总会来的,逃是逃不掉的。话不多说,man起来:manjournalctl洋洋洒洒几百字的描述,是说journalctl是用来查询systemd日志的,这些日志都是systemd-journa...

Linux上的Systemctl命令(systemctl命令详解)

LinuxSystemctl是一个系统管理守护进程、工具和库的集合,用于取代SystemV、service和chkconfig命令,初始进程主要负责控制systemd系统和服务管理器。通过Syste...

如何使用 systemctl 管理服务(systemctl添加服务)

systemd是一个服务管理器,目前已经成为Linux发行版的新标准。它使管理服务器变得更加容易。了解并利用组成systemd的工具将有助于我们更好地理解它提供的便利性。systemctl的由来...

内蒙古2024一分一段表(文理)(内蒙古考生2020一分一段表)

分数位次省份...

2016四川高考本科分数段人数统计,看看你有多少竞争对手

昨天,四川高考成绩出炉,全省共220,196人上线本科,相信每个考生都查到了自己的成绩。而我们都清楚多考1分就能多赶超数百人,那你是否知道,和你的分数一样的人全省有几个人?你知道挡在你前面的有多少人?...

难怪最近电脑卡爆了,微软确认Win11资源管理器严重BUG

近期,Win11操作系统的用户普遍遭遇到了一个令人头大的问题:电脑卡顿,CPU占用率异常增高。而出现该现象的原因竟然与微软最近的一次补丁更新有关。据报道,微软已经确认,问题源于Win11资源管...

微软推送Win11正式版22621.1702(KB5026372)更新

IT之家5月10日消息,微软今天推送了最新的Win11系统更新,21H2正式版通道推送了KB5026368补丁,版本号升至22000.1936,22H2版本推送了KB50263...

骗子AI换脸冒充亲戚,女子转账10万元后才发现异常……

“今天全靠你们,不然我这被骗的10万元肯定就石沉大海了。”7月19日,家住石马河的唐女士遭遇了“AI”换脸诈骗,幸好她报警及时,民警对其转账给骗子的钱成功进行止付。当天13时许,唐女士收到一条自称是亲...

取消回复欢迎 发表评论: