20175324第十一周学习总结
本周学习《Java程序设计》第十三章java网络编程:
- URL类
- URL类是java.net包中的一个重要的类,使用URL创建对象的应用程序称作客户端程序。
- 客户利用URL对象可以获取URL中的资源。
- 一个URL对象通常包含最基本的三部分信息
- 协议
- 地址
- 资源
- 构造方法:
public URL (String spec) throws MalformedURLException
所包含的资源位默认的资源(主页)public URL(String protocol, String host,String file) throws Exception
protocol指定协议,host指定地址,file指定资源
- InetAdress类
- Internet上的主机有两种地址的表示:域名和IP地址
- 获取地址
- 获取Internet上主机的地址:可以使用
InetAddress
类的静态方法getByName(String s);
- 获取本地机的地址:可以使用
InetAddress
类的静态方法getLocalHost()
获得一个InetAddress对象,该对象含有本地机的域名和IP地址
- 获取Internet上主机的地址:可以使用
套接字
- 概述
- 网络通信使用IP地址标识Internet上的计算机,使用端口号标识服务器上的进程(程序)。
- 当两个程序需要通信时,它们可以通过使用Socket类建立套接字对象并连接在一起(端口号与IP地址的组合得出一个网络套接字)。
- 客户端套接字
- 客户端的程序使用
Socket
类建立负责连接到服务器的套接字对象,Socket类的构造方法:Socket(String host, int port)
- 使用
getInputStream()
获得一个输入流,getOutputStream()
获得一个输出流
- 客户端的程序使用
- ·ServerSocket
对象与服务器端套接字 -
ServerSocket的构造方法:
ServerSocket(int port),port 是一个端口号。 - 使用方法
accept()将客户端的套接字和服务器端的套接字连接起来: ``` try{ Socket sc= serverForClient .accept(); } catch(IOException e){} ``` - 所谓“接收”客户的套接字连接就是
accept()方法会返回一个和客户端
Socket对象相连接的
Socket`对象 - 使用多线程技术
- 为了防止堵塞线程,服务器端收到一个客户的套接字后,就应该启动一个专门为该客户服务的线程。
- 客户使用
Socket
类不带参数的构造方法Socket()
创建一个套接字对象,该对象需调用public void connect(SocketAddress endpoint) throws IOException
请求和参数SocketAddress
指定地址的套接字建立连接。 - 为了使用
connect
方法,可以使用SocketAddress
的子类InetSocketAddress
创建一个对象,InetSocketAddress
的构造方法是InetSocketAddress(InetAddress addr, int port)
UDP数据报
- 套接字是基于TCP协议的网络通信。
- UDP的信息传递更快,但不提供可靠性保障,即无法知道数据能否正确到达目的地,也不能确定数据到达目的地的顺序是否和发送的顺序相同。
- 基于UDP通信的基本模式:
- 将数据打包,称为数据包(好比将信件装入信封一样),然后将数据包发往目的地。
- 接受别人发来的数据包(好比接收信封一样),然后查看数据包中的内容。
- 发送数据包
- 用
DatagramPacket
类将数据打包,即用DatagramPacket
类创建一个对象,称为数据包 - 构造方法
DatagramPacket(byte data[],int length,InetAddtress address,int port)
DatagramPack(byte data[],int offset,int length,InetAddtress address,int port)
- 用
DatagramSocket
类的不带参数的构造方法DatagramSocket()
创建一个对象,该对象负责发送数据包
- 用
- 接收数据包
- 首先用
DatagramSocket
的另一个构造方法DatagramSocket(int port)
创建一个对象,其中的参数必须和待接收的数据包的端口号相同 - 然后该对象使用方法
receive(DatagramPacket pack)
接受数据包 - 用
DatagramPack
类的另外一个构造方法DatagramPack(byte data[],int length)
创建一个数据包,用于接收数据包
- 首先用
广播数据报
- A类地址:a<128,则b.c.d表示主机。
- B类地址:128<=a<192,则a.b表示网络地址,c.d表示主机地址。
- C类地址:a>=192,a.b.c表示网络地址,d表示主机地址。
- D类地址:224.0.0.0~224.255.255.255是保留地址,要广播或接收广播的主机都必须加入到同一个D类地址。
Java远程调用
- Java远程调用RMI是一种分布式技术,使用RMI可以让一个虚拟机(JVM)上的应用程序请求调用位于网络上另一处的JVM上的对象方法。习惯上称发出调用请求的JVM为(本地)客户机,称接受并执行请求的虚拟机(JVM)为(远程)服务器
- 远程对象及其代理
- 远程对象:驻留在(远程)服务器上的对象是客户要请求的对象
- 代理与存根(Stub)
- 代理的特点是它与远程对象实现了相同的接口
- 存根(Stub)是一种特殊的字节码,并让这个存根产生的对象为作为远程对象的代理,其字节码后缀为"_Stub"。
Remote
接口- RMI为了标识一个对象是远程对象,即可以被客户请求的对象,要求远程对象必须实现
java.rmi
包中的Remote
接口,也就是说只有实现该接口的类的实例才被RMI认为是一个远程对象
- RMI为了标识一个对象是远程对象,即可以被客户请求的对象,要求远程对象必须实现
- RMI的设计细节
- 扩展
Remote
接口 - 远程对象
- 存根(Stub)与代理
- 启动注册
rimregistry
- 启动远程对象服务
- 运行客户端程序
- 扩展