20165228 2017-2018-2 《Java程序设计》第9周学习总结
20165228 2017-2018-2 《Java程序设计》第9周学习总结
教材学习内容总结
- URL类是java.net包中的一个重要的类,URL的实例封装着一个统一资源定位符(Uniform Resource Locator),使用URL创建对象的应用程序称作客户端程序
- URL对象最基本的信息:协议、地址、资源
- 创建一个URL对象
public URL(String spec) throws MalformedURLException
public URL(String protocol, String host,String file) throws MalformedURLException
- 读取URL中的资源:
URL对象调用
InputStream openStream()
返回一个输入流,该输入流指向URL对象所包含的资源
- Internet上的主机的两种方式表示地址:域名、IP地址
- 获取地址
- Internet上主机的地址:
1.InetAddress类的静态方法getByName(String s);
2.获得一个InetAddress对象,该对象含有主机地址的域名和IP地址 - 获取本地机的地址:通过InetAddress类的静态方法getLocalHost()
- Internet上主机的地址:
- 套接字:IP地址标识Internet上的计算机,端口号标识正在计算机上运行的进程(程序)。端口号被规定为一个16位的0~65535之间的整数,端口号与IP地址的组合得出一个网络套接字。当两个程序需要通信时,它们可以通过使用Socket类建立套接字对象并连接在一起。
- 建立连接到服务器的套接字对象:
try{ Socket mysocket=new Socket(“http://192.168.0.78”,1880);
}
catch(IOException e) {
}
- mysocket相关的方法
- getInputStream()获得一个输入流
- getOutputStream()获得一个输出流
- 用getInputStream()得到的输入流接到另一个DataInputStream数据流上
- 用getOutputStream()得到的输出流接到另一个DataOutputStream数据流上
- 服务器必须建立一个ServerSocket对象,该对象通过将客户端的套接字对象和服务器端的一个套接字对象连接起来,从而达到连接的目的
try{ ServerSocket serverForClient =new ServerSocket(2010);
}
catch(IOException e){
}
- 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通信的基本模式是:
1.将数据打包,称为数据包(好比将信件装入信封一样),然后将数据包发往目的地。
2.接受别人发来的数据包(好比接收信封一样),然后查看数据包中的内容。 - 用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 mail_out=new DatagramSocket();
mail_out.send(data_pack);
- 接受数据包:
- DatagramSocket的另一个构造方法DatagramSocket(int port) 创建一个对象,其中的参数必须和待接收的数据包的端口号相同
DatagramSocket mail_in=new DatagramSocket(端口号);
- 然后对象mail_in使用方法receive(DatagramPacket pack)接受数据包。
- 用 DatagramPack类的另外一个构造方法: DatagramPack(byte data[],int length)创建一个数据包,用于接收数据包
byte data[]=new byte[100];
int length=90;
DatagramPacket pack=new DatagramPacket(data,length);
mail_in.receive(pack);
- 远程对象:
驻留在(远程)服务器上的对象是客户要请求的对象,称作远程对象。 - 代理的特点是它与远程对象实现了相同的接口。
- 存根(Stub):一种特殊的字节码,并让这个存根产生的对象为作为远程对象的代理
- Remote接口:RMI为了标识一个对象是远程对象,即可以被客户请求的对象,要求远程对象必须实现java.rmi包中的Remote接口
教材学习中的问题和解决过程
- 问题1:基于UDP的通信和基于TCP的通信不同点是什么?
- 问题1解决方案:基于UDP的信息传递更快,但不提供可靠性保证
代码调试中的问题和解决过程
- 问题1:敲代码的时候出现了这样的差错,在没仔细看程序的情况下,没能根据错误提示排除原因
- 问题1解决方案:仔细阅读代码后,发现这是一句输出语句,system中间误输了一个空格
代码托管
这周好像修改了部分之前的代码,所以算到这周的代码量了。实际上代码量为516
(statistics.sh脚本的运行结果截图)
上周考试错题总结
- 错题1:对于下列程序,哪个叙述是正确的? A
A.JVM认为这个应用程序共有两个线程。
B.JVM认为这个应用程序只有一个主线程。
C.JVM认为这个应用程序只有一个thread线程。
D.程序有编译错误,无法运行。 - 错题2:进程的基本状态有:新建、运行、阻塞、死亡。 A
A.true
B.false
其他(感悟、思考等,可选)
本周学习的知识让我认识到java不限于本地的应用,除了数据库外,还可以通过网络传输和接受数据包并且实现一些操作。
学习进度条
代码行数(新增/累积) | 博客量(新增/累积) | 学习时间(新增/累积) | 重要成长 | |
---|---|---|---|---|
目标 | 5000行 | 25篇 | 400小时 | |
第一周 | 235/235 | 1/1 | 15/15 | |
第二周 | 224/459 | 2/3 | 15/30 | |
第三周 | 443/902 | 1/4 | 15/73 | |
第四周 | 577/1479 | 2/6 | 17/90 | |
第五周 | 1222/2360 | 1/7 | 14/104 | |
第六周 | 1527/3294 | 1/8 | 14/118 | |
第七周 | 591/3883 | 1/9 | 14/132 | |
第八周 | 1705/5158 | 1/10 | 12/144 | |
第九周 | 516/5674 | 1/11 | 14/158 |