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 Exceptionprotocol指定协议,host指定地址,file指定资源

- InetAdress类

  • Internet上的主机有两种地址的表示:域名和IP地址
  • 获取地址
    • 获取Internet上主机的地址:可以使用InetAddress类的静态方法getByName(String s);
    • 获取本地机的地址:可以使用InetAddress类的静态方法getLocalHost()获得一个InetAddress对象,该对象含有本地机的域名和IP地址

套接字

  • 概述
    • 网络通信使用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的设计细节
    • 扩展Remote接口
    • 远程对象
    • 存根(Stub)与代理
    • 启动注册rimregistry
    • 启动远程对象服务
    • 运行客户端程序
posted @ 2019-05-11 23:10  2017532王陈峤宇  阅读(138)  评论(0编辑  收藏  举报