第9章 Java高级编程.ppt
学习导读学习导读 本本章章将将介介绍绍Java语语言言中中的的一一些些高高级级特特性性:异异常常处处理理、多多线线程程机机制制、流流式式IO以以及及网网络络通通信信,其其中中每每个个部部分分都都能能扩扩展展成成一一个个专专题题。读读者者在在本本章章学学习习到到的的只只是是其其中中很很小小的的一一部部分分,但但是是能能够够从从中中了了解解一一些些基基本本概概念念和和基基本本操操作作,为为今今后后的的深深入入学学习习打打下下基基础础。异异常常处处理理提提供供对对错错误误的的捕捕捉捉和和处处理理机机制制;多多线线程程机机制制使使得得程程序序的的多多个个子子任任务务能能够够“同同时时”执执行行;流流式式IO提提供供了了对对输输入入输输出出的的读读写写机机制制;网网络络通通信信特特性性允允许许Java程程序序通通过过Socket实实现现底底层层通通信信,并并利利用用Java提提供供的的扩展组件实现高层服务。扩展组件实现高层服务。第九章 Java高级编程 教学重点与难点教学重点与难点:v异常处理、多线程机制、流式异常处理、多线程机制、流式IO以及网络通以及网络通信的基本概念和模型信的基本概念和模型v异常的捕获和处理异常的捕获和处理v多线程的实现及多线程的实现及Runnable接口的应用接口的应用v流式输入输出的操作、文件读写及随机访问流式输入输出的操作、文件读写及随机访问v基于基于Socket的面向连接的网络底层通信及高的面向连接的网络底层通信及高层服务层服务9.1 异常处理在Java中,提供了错误捕捉和处理机制,即异常处理机制。在程序运行过程中发生错误时,Java允许其不按照正常路径完成任务,由发现错误的方法抛出封装了错误信息的对象(异常)到其调用程序,发出已经发生问题的信号,然后立即退出;而且,程序并不在调用该方法的代码处继续执行,而是由异常处理机制开始搜索一个能够处理这种特定错误情况的异常处理器。9.1.1 异常分类 Throwable类派生出两个分支:Error和Exception。Error类被认为是不能恢复的严重错误,如系统内部错误和资源耗尽错误等。不应该抛出这种类型的错误,而是让程序中断。Exception类定义可能遇到的轻微错误,分为派生自RuntimeException类的异常和非派生自RuntimeException类的异常。这时,可以写代码来处理异常并继续程序执行,而不是让程序中断。区分RuntimeException和非RuntimeException的规则是:编程错误导致RuntimeException,如被零除、数组越界访问、空指针访问等;而其他异常则是由于意外情况而发生的,如试图读取文件结尾以后的数据、试图打开错误的URL、试图根据并不代表已存在类的字符串来查找Class对象等。9.1.2 方法如何抛出异常 /本方法从长度为2048字节的某文件中读入数据到字符串对象中。String readFile(BufferedReader in)throws EOFException.while(.)/ch为当前读入的字符。if(ch=-1)/文件尾;/当nlen,意味着还未将文件全部读入字符串,就遇到文件结束标志,视为异常情况。if(n len)throw new EOFException();/或者采用下面的方法:/if(n java FileDirectory运行结果如下:显示指定目录的内容1.Ppt2.Xls3.DocFileDirectory.javaFileDirectory.classE:demotemptemp1.txttemp2.txt更改文件名后,显示temp子目录的内容temp.txttemp2.txt删除文件后,显示temp子目录的内容temp.txt9.4 Java网络通信传统的网络编程是一项非常细节化的工作,程序员必须处理和网络有关的大量细节,如各种协议,甚至要理解网络相关的硬件知识。而Java则将底层的网络通信细节予以屏蔽,使得使用的编程模型是一个文件模型,也就是说,可以象操作流一样来操作网络数据传输。另外,由于在网络连接中,通常都需要一个服务器同时为多个客户端服务,因此Java的多线程机制也大派用场。9.4.1网络基础知识及Java网络模型Java网络模型图 9.4.2面向连接的流式套接字【例9.14】具有“回显”功能的服务器端和客户端程序。服务器端的程序将等待客户端的输入,然后将客户端的输入回显给客户端,同时在服务器端的控制台输出。而客户端从控制台接收输入后,向服务器端发送输入,并接收服务器端的回显数据,然后显示在控制台。程序代码见EchoServer.java和EchoClient.java。服务器端程序运行结果如下:Started:ServerSocketaddr=0.0.0.0/0.0.0.0,port=0,localport=9999Connection accepted:Socketaddr=/127.0.0.1,port=1623,localport=9999Hello!Enter BYE to exit.Echo:abcEcho:cdeEcho:efgThe client entered BYE!Connection will be closed!客户端程序运行结果如下:socket=Socketaddr=localhost/127.0.0.1,port=9999,localport=1623Enter a string,Enter BYE to exit!AbcEcho:abcCdeEcho:cdeEfgEcho:efgBYE【例9.15】支持多客户端的“回显”服务器端程序。程序代码见EchoServerThread.java。我们先启动服务器端,然后启动两个客户端。服务器端程序运行结果如下:Started:ServerSocketaddr=0.0.0.0/0.0.0.0,port=0,localport=9999Connection 1 accepted:Socketaddr=/127.0.0.1,port=1656,localport=9999Hello!Enter BYE to exit.Connection 2 accepted:Socketaddr=/127.0.0.1,port=1657,localport=9999Hello!Enter BYE to exit.Echo 1:abcEcho 2:ABCEcho 2:CDEEcho 1:cdeEcho 2:EFGThe client 2 entered BYE!Connection 2 will be closed!Echo 1:efgEcho 1:hijkThe client 1 entered BYE!Connection 1 will be closed!第一个客户端运行结果如下:socket=Socketaddr=localhost/127.0.0.1,port=9999,localport=1656Enter a string,Enter BYE to exit!abcEcho 1:abccdeEcho 1:cdeefgEcho 1:efghijkEcho 1:hijkBYE第二个客户端运行结果如下:socket=Socketaddr=localhost/127.0.0.1,port=9999,localport=1657Enter a string,Enter BYE to exit!ABCEcho 2:ABCCDEEcho 2:CDEEFGEcho 2:EFGBYE9.4.3无连接的数据报 对于类似传输速度更重要的应用,使用无连接的数据报协议UDP,即“用户数据报协议”。UDP并不刻意追求数据包会完全发送出去,也不能担保它们抵达的顺序与它们发出时一样,因此,这是一种“不可靠协议”。由于其速度比TCP快得多,所以还是能够在很多应用中使用。Java对数据报的支持与它对TCP套接字的支持大致相同,使用DatagramSocket类来表示无连接的socket,接收和发送数据报。接收和要发送的数据报内容保存在DatagramPacket对象中。UDP也有自己的端口,和TCP端口是相互独立的。也就是说,可以在端口8080同时运行一个TCP和UDP服务程序,两者之间不会产生冲突。9.4.4 Java访问网络资源 在因特网上,已经开发了许多服务,如WWW浏览、Email等,而Java也提供了相应的扩展组件,如对于Email应用,Java提供了JavaMail API,使用时只需要调用其提供的方法就可以完成如发送邮件的操作:Transport.send(message);在因特网上,我们使用通用资源定位符URL(Uniform Resource Locator)来查找资源。URL包含了用于查找某个资源的信息,如一张图片、一个文件等。URL资源可以包括很多种,如HTTP资源、FTP资源等。下面就是一个图像资源的URL,属于HTTP资源。http:/ 通过本章的学习,了解了Java异常处理、多线程机制、流式IO以及网络通信的基本概念和模型。在异常处理中,通过Java语言提供的先进的错误纠正与恢复机制,可以有效地增强代码的健壮程度,并使用尽可能精简的代码创建大型、可靠的应用程序,同时排除程序里那些不能控制的错误。Java强迫遵守违例所有方面的问题,所以无论库设计者还是客户程序员,都能够连续一致地使用它。使用多线程机制的主要目的是对大量任务进行有序的管理,从而可以通过“轻度”切换来更有效地利用计算机资源,或者对用户来说使用界面更加友好,相比进程之间的“重度”切换,效率得到很大提高。有效利用计算机资源的典型应用是在IO等候期间如何利用CPU;用户方面的界面友好性的典型体现是如何在一个长时间的数据下载过程中灵敏地对“停止”(stop)操作进行反应。在流式输入输出中,Java提供了通过控制台、文件、内存块甚至因特网等多种不同数据源或目的进行不同方式访问的流库。通过对流过滤器的正确使用,将提供灵活的I/O操作。Java不仅提供了对文件的流式访问,而且提供了随机访问和文件管理。在网络通信中,Java不仅提供了面向连接和无连接数据报的底层通信,而且还提供了高层服务,如Email和WWW服务等。通过Java提供的网络功能,可以以流的方式来进行网络数据的传输,而且不需要关注连网的细节问题。