百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

大数据编程入门:Java网络编程_大数据 编程

yund56 2025-02-25 01:07 24 浏览

如果想要编写出一个可以运行在多个设备上的程序,应该怎么做呢?答案是网络编程,今天小编将为大家带来大数据编程入门: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网络编程的全部内容了,希望这篇文章可以帮助到大家~

相关推荐

SM小分队Girls on Top,女神战队少了f(x)?

这次由SM娱乐公司在冬季即将开演的smtown里,将公司的所有女团成员集结成了一个小分队project。第一位这是全面ACE的大姐成员权宝儿(BoA),出道二十年,在日本单人销量过千万,韩国国内200...

韩国女团 aespa 首场 VR 演唱会或暗示 Quest 3 将于 10 月推出

AmazeVR宣布将在十月份举办一场现场VR音乐会,观众将佩戴MetaQuest3进行体验。韩国女团aespa于2020年11月出道,此后在日本推出了三张金唱片,在韩国推出了...

韩网热议!女团aespa成员Giselle在长腿爱豆中真的是legend

身高163的Giselle,长腿傲人,身材比例绝了...

假唱而被骂爆的女团:IVE、NewJeans、aespa上榜

在韩国,其实K-pop偶像并不被认为是真正的歌手,因为偶像们必须兼备舞蹈能力、也经常透过对嘴来完成舞台。由于科技的日渐发达,也有许多网友会利用消音软体来验证K-pop偶像到底有没有开麦唱歌,导致假唱这...

新女团Aespa登时尚大片 四个少女四种style

来源:环球网

韩国女团aespa新歌MV曝光 画面梦幻造型超美

12月20日,韩国女团aespa翻唱曲《DreamsComeTrue》MV公开,视频中,她们的造型超美!WINTER背后长出一双梦幻般的翅膀。柳智敏笑容甜美。宁艺卓皮肤白皙。GISELLE五官精致...

女网友向拳头维权,自称是萨勒芬妮的原型?某韩国女团抄袭KDA

女英雄萨勒芬妮(Seraphine)是拳头在2020年推出的第五位新英雄,在还没有正式上线时就备受lsp玩家的关注,因为她实在是太可爱了。和其他新英雄不同的是,萨勒芬妮在没上线时就被拳头当成虚拟偶像来...

人气TOP女团是?INS粉丝数见分晓;TWICE成员为何在演唱会落泪?

现在的人气TOP女团是?INS粉丝数见分晓!现在爱豆和粉丝之间的交流方法变得多种多样,但是Instagram依然是主要的交流手段。很多粉丝根据粉丝数评价偶像的人气,拥有数百、数千万粉丝的组合作为全球偶...

韩国女团MVaespa Drama MV_韩国女团穿超短裙子跳舞

WelcometoDrama.Pleasefollow4ruleswhilewatchingtheDrama.·1)Lookbackimmediatelywhenyoufe...

aespa师妹团今年将出道! SM职员亲口曝「新女团风格、人数」

记者刘宛欣/综合报导南韩造星工厂SM娱乐曾打造出东方神起、SUPERJUNIOR、少女时代、SHINee、EXO等传奇团体,近年推出的aespa、RIIZE更是双双成为新生代一线团体,深受大众与粉丝...

南韩最活跃的女团aespa,新专辑《Girls》即将发布,盘点昔日经典

女团aespa歌曲盘点,新专辑《Girls》即将发布,期待大火。明天也就是2022年的7月8号,aespa新专辑《Girls》即将发行。这是继首张专辑《Savage》之后,时隔19个月的第二张专辑,这...

章泽天女团aespa出席戛纳晚宴 宋康昊携新片亮相

搜狐娱乐讯(山今/文玄反影/图科明/视频)法国时间5月23日晚,女团aespa、宋康昊、章泽天等明星亮相戛纳晚宴。章泽天身姿优越。章泽天肩颈线优越。章泽天双臂纤细。章泽天仪态端正。女团aespa亮...

Aespa舞台暴露身高比例,宁艺卓脸大,柳智敏有“TOP”相

作为SM公司最新女团aespa,初舞台《BlackMamba》公开,在初舞台里,看得出来SM公司是下了大功夫的,虽然之前SM公司新出的女团都有很长的先导片,但是aespa显然是有“特殊待遇”。运用了...

AESPA女团成员柳智敏karina大美女

真队内速度最快最火达成队内首个且唯一两百万点赞五代男女团中输断层第一(图转自微博)...

对来学校演出的女团成员语言性骚扰?韩国这所男高的学生恶心透了

哕了……本月4日,景福男子高中相关人士称已经找到了在SNS中上传对aespa成员进行性骚扰文章的学生,并开始着手调查。2日,SM娱乐创始人李秀满的母校——景福高中迎来了建校101周年庆典活动。当天,S...