版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、应聘Java笔试时可能出现问题Java基础方面: 1、作用域public,private,protected,以及不写时的区别 Public、Protected、Private是成员访问修饰符;final、abstract、transient、synchronized、native、strictfp是非访问成员修饰符。可见性PublicProtectedDefaultPrivate同一个类是是是是同一个包中的类是是是否同一个包中的子类是是是否同一包外的子类是是否否同一包外的非子类是否否否Java的基本包java.lang 其中包含有:接口:Comparable、Cloneable、Runabl
2、e等类:八个基本数据类型封装类、Math、Runtime、Object、String、StringBuffer、Thread、Exception等集合框架集合是将多个元素组成一个单元的对象。集合用于存储、检索和操纵数据。集合框架提供管理对象集合的接口和类。它包含几个组件,接口是表示集合的抽象数据类型,用于操纵集合;类是用于存储集合的实际数据对象;算法是用于操纵集合的。2、ArrayList和Vector的区别,HashMap和Hashtable的区别 答:就ArrayList与Vector主要从二方面来说. 一.同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程序不
3、安全的,不是同步的 二.数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半 ArrayList,Vector, LinkedList的存储性能和特性ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录
4、本项的前后项即可,所以插入速度较快。就HashMap与HashTable主要从三方面来说.一.历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一实现 二.同步性:Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步的 三.值:只有HashMap允许在一个集合中有一个null键和在一个集合中有多个null值Hashtable是HashMap的同步版本;HashMap允许有null值和一个null键,但是,Hashtable不允许有任何内容为nullHashtable类的对象必须覆盖Obje
5、ct类的hashCode()和equals()方法关于其他集合类型:一.ArrayList 提供快速遍历和快速访问。现在设计了新的 RandomAccess 接口,它指出这种列表支持快速随机访问。Vector也实现了RandomAccess 接口。二.遍历HashSet与HashMap时,其顺序是未知的(但添加删除快)。LinkedHashSet和LinkedHashSet是按照元素的插入的顺序遍历的(遍历快)。三TreeSet和TreeMap将保证元素按照元素的自然顺序进行排列。也可以使用一个用户自己实现的比较规则。四、HashSet有一个散列表支持它。它为基本操作提供固定时间性能。Tree
6、Set它确保了排序集将按元素升序,根据自然顺序排序。Dictionary类主要用于将关键字转换成值,该类接收一个关键字并返回一个值。Dictionary是一个抽象类,它是HHashtable的超类。Properties类扩展了Hashtable类,但Properties对象的关键字和值必须是String类型,并能将对象写入一个输出流并保存在一个文件中,然后可以把它读回一个输入流。如果需要维护和搜索一个部件列表,它们由唯一的字母数字序列号标示,其中的部件是Part类型,这时应该使用哪种集合?如果我们改变需求,你也需要能够按顺序、按它们的序列号打印出部件?1、应该选择HashMap2、应该选择Tr
7、eeMap3、char型变量中能不能存贮一个中文汉字?为什么? 答:是能够定义成为一个中文的,因为java中以unicode编码,一个char占16个字节,所以放一个中文是没问题的 4、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么? 答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口 同步的实现方面有两种,分别是synchronized,wait与notify GC是什么? 为什么要有GC? GC是垃圾收集的意思(Gabage Collection),内存处理是编程人员容易出现问题的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃,Java
8、提供的GC功能可以自动监测对象是否超过作用域从而达到自动回收内存的目的,Java语言没有提供释放已分配内存的显示操作方法。7、垃圾回收机制,如何优化程序? 当一个对象失去引用或者离开了作用域后,就成为垃圾而被Java运行环境自动清除,清除垃圾就是清除这些对象。Java垃圾回收机制的特点是:垃圾回收机制自动运行。系统提供一个低优先级的线程来跟踪内存的分配情况。如果发现某个内存单元不再使用,就清除它。何时清除垃圾是不可预期的。垃圾回收机制随JVM的不同而不同。Java的垃圾搜索器为内存管理器提供一种自动解决方案。缺点是不能完全控制它什么时候执行以及什么时候不执行。当垃圾搜集器运行时,其目的是查找和
9、删除不能被访问的对象。垃圾搜集器受JVM控制,JVM决定什么时候运行垃圾搜集器。从Java程序内可以请求JVM运行垃圾搜集器,但是,在任何情况下都无法保证JVM会答应你的请求。JVM通常会在它感到内存减少时运行垃圾搜集器。垃圾收集器运行时,当它发现一个对象不能被任何活线程访问时,它将认为该对象符合删除条件,它可能在某时删除该对象。垃圾收集器不能保证有足够的内存,它只能保证可以使用的内存将尽可能被有效的管理。使对象符合垃圾搜集器搜索条件的情况有:出现空引用、重新为引用变量赋值、隔离引用。强制执行垃圾搜集:Runtime对象为直接与虚拟机通信提供一种机制。System类可以调用与其相同的方法。请求
10、垃圾收集器的最简单的方法是:System.gc();Javac编译选项?G产生调试信息g:none不产生调试信息verbose输出编译器消息,可以知道程序编译时用到了哪些Java类Noware编译时不产生警告信息encoding指出原文件的编码方式D指定类文件产生的目录classPath指出用户class文件的路径sourcePath指出用户源文件路径9、介绍JAVA中的Collection FrameWork(包括如何写自己的数据结构)? 答:Collection FrameWork如下: 核心接口有:CollectionSetSorted SetListMapSorted MapSet接口
11、:不允许重复的元素。它对add、equals、hashCode方法增加了限制SortedSet接口:扩展了Set接口,此接口的元素按升序排序。List接口:一些集合具有顺序,即在一个项目后添加另一个项目。列表可以有重复元素。提供了ListIterator,允许向前或向后移动元素。Map接口:将键映射到值得对象。Map不能包含重复键,但可以包含重复值。每个键最多都只能映射到一个值。核心设计类:Map 设计Set 设计List 设计HashMapHashSetArrayListHashtableLinkedHashSetVectorTreeMapTreeSetLinkedLiskLinkedHas
12、Map散列表是最快的数据存储结构,它是一个数组。数据存储在数组中散列函数指定的特定下标。散列函数是一组输入数据和一组整数之间的映射。集合类和接口层次Collections是一个类,带有用于处理集合的静态实用方法Collection是一个接口,带有多数集合常用的方法声明,包括add、remove、contains、size、iteratorCollection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements) Map提供key到value的映射 集合框架的优点:提供一组可用的集合接口,可以方便地扩展或改写集合;接口和算法的可重用性提
13、高了软件的可重用性;提供了有效的数据结构和算法,减少了编程工作。10、Java中异常处理机制,事件机制? 事件代表了组件之间的交互。是一种在源对象和监听对象之间,某种状态发生变化的传递机制。通过事件处理机制,可以让一些组件作为事件源,发出可被组件环境或其它组件接收的事件。这样,不同的组件就可以组合在一起,组件之间通过事件传递进行通信,构成一个应用。在java中实现事件机制的事件模型由三个部分构成:一个事件对象用于描述事件源的状态变化;一个事件源将会产生事件,提供注册的事件监听器的方法,把事件发送到监听器;事件监听器接收事件通知,实现该事件的监听器接口。异常实际上是程序中错误导致中断了正常的指令
14、流的一种事件.Java异常处理用于在方法中能检查出错误但不能处理错误的情况,在这样的方法中将抛出一个异常。如果一个异常与某个catch程序块中的参数匹配,那么就执行该catch块中的代码。指出try catch finally的工作顺序。运行时异常与一般异常有何异同?异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。事件有哪些?什么是断言机制?断言从JDK1.4版开始引入,它让开发期间测试假设,而没有付出为异常编写异常处理程序方面
15、的代价,一旦程序完成开发,并全部部署,假设将从不会发生。主要作用:因为在开发时对自己的假设非常肯定,所以不想花费时间来编写异常处理代码。断言让在开发期间测试你的假设。private void method(int num)assert(num=0);/这里假定参数num是正数,如果不是真的将抛出一个AssertionError错误useNum(num+x);断言有两种形式:简单和非常简单。非常简单:private void doStuff()assert(yx);/其他代码简单:将通过表达式的值向错误跟踪栈中添加更多信息,提供了更多调式帮助信息。private void doStuff()as
16、sert(yx):”y is ”+y+” x is”+x;/其他代码运行时启用断言:java ea com.geeksanonymous.TestClass运行时禁用断言:java da com.geeksanonymous.TestClass11、JAVA中的多形与继承? 希望大家补上,谢谢 对象是定义了边界的、与要解决的问题有关的概念或事物。它们用于帮助理解现实世界。类是拥有相同特性、共同的行为和共同的关系的一组对象。封装是让开发者有选择地隐藏类中的特性和方法的过程继承是允许通过重用现有类来构建新类的特性。多态性使用同一函数在不同的类上具有不同的行为。Java中的多态性是通过方法的动态绑定
17、实现的。12、抽象类与接口? 答:抽象类与接口都用于抽象,但是抽象类(JAVA中)可以有自己的部分实现,而接口则完全是一个标识(同时有多重继承的功能)。 abstract的method是否可同时是static,是否可同时是native,是否可同时是synchronized? 都不能接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是否可继承实体类(concrete class)?接口可以继承接口。抽象类可以实现(implements)接口,抽象类可继承实体类,但前提是实体类必须有明确的构造函数。Anonymous Inner Class (匿名内部类) 是否可以ext
18、ends(继承)其它类,是否可以implements(实现)interface(接口)? 可以继承其他类或完成其他接口,在swing编程中常用此方式。IO流字节流:数据在存储时与传输时都是以字节为单位进行的。通常用于读写二进制数据,如图像和声音文件。字符流:数据在存储与传输时都是以字符为单位进行的。流:对数据源的一种抽象,其目的是想用统一的方式访问各种不同的数据源(文件、网络、内存的缓冲区)文件读写的基本类:File类提供定位本地文件系统,描述文件和目录的功能。管道流用于在线程之间通信:PipedInputStream、PipedOutputStream、PipedReader、PipedWr
19、iter线程1PipedOutputStreamPipedInputStream线程2键盘输入:tryBufferedReader br=new BufferedReader(new InputStreamReader(System.in);String s=br.readLine();System.out.println(s);catch(Exception e)文件输入输出:tryFile f=new File(test.txt);FileOutputStream fout=new FileOutputStream(f);fout.write(System.in.read();fout.c
20、lose();FileInputStream fin=new FileInputStream(f);int size=fin.available();for(int i=0;isize;i+)System.out.print(char)fin.read();fin.close();catch(Exception e)通过网络传输文件:客户端:File f=new File(bk.exe);FileInputStream fin=new FileInputStream(f);Socket st=new Socket(localhost,6000);BufferedOutputStream bou
21、t=new BufferedOutputStream(st.getOutputStream();int size=fin.available();for(int i=0;i 0)debug(NBTest: Number of keys after select operation: +nKeys);/Selector传回一组SelectionKeys/我们从这些key中的channel()方法中取得我们刚刚注册的channel。Set selectedKeys = selector.selectedKeys();Iterator i = selectedKeys.iterator();whil
22、e(i.hasNext()s = (SelectionKey) i.next();printKeyInfo(s);debug(NBTest: Nr Keys in selector: +selector.keys().size();/一个key被处理完成后,就都被从就绪关键字(ready keys)列表中除去i.remove();if(s.isAcceptable()/ 从channel()中取得我们刚刚注册的channel。Socket socket = (ServerSocketChannel)s.channel().accept().socket();SocketChannel sc =
23、 socket.getChannel();sc.configureBlocking(false);sc.register(selector, SelectionKey.OP_READ |SelectionKey.OP_WRITE);System.out.println(+channels);elsedebug(NBTest: Channel not acceptable);elsedebug(NBTest: Select finished without any keys.);private static void debug(String s)System.out.println(s);pr
24、ivate static void printKeyInfo(SelectionKey sk)String s = new String();s = Att: + (sk.attachment() = null ? no : yes);s += , Read: + sk.isReadable();s += , Acpt: + sk.isAcceptable();s += , Cnct: + sk.isConnectable();s += , Wrt: + sk.isWritable();s += , Valid: + sk.isValid();s += , Ops: + erestOps();
25、debug(s);public static void main (String args)NBTest nbTest = new NBTest();trynbTest.startServer();catch(Exception e)e.printStackTrace();Socket通信(TCP、UDP区别及Java实现方式)套接字是一种进程间的数据交换机制。客户端和服务器通过套接字建立连接和进行通信。套接字是由IP地址、传输协议和一个端口号三部分组成的。TCP/IP协议:其中TCP 为传输控制协议是传输层协议,功能TCPUDP数据传输连续的有序数据流消息传输多路功能接收主机根据端口号决定数
26、据流向那个应用相同可靠传输使用TCP头部的序列与确认字段进行数据确认无流量控制使用窗口机制的流量控制无连接使用3次握手建立连接;连接后一直保持连接直到终止连接无连接URL的组件:协议、IP地址或主机名、端口号和实际文件路径import .*;import java.io.*;public class DatagramServerpublic static DatagramSocket ds;public static int clientport=1089,serverport=1090;public static void main(String args) throws Exception
27、byte buffer=new byte1024;ds=new DatagramSocket(serverport);BufferedReader dis=new BufferedReader(new InputStreamReader(System.in);System.out.println(服务器正等待输入);InetAddress ia=InetAddress.getByName(localhost);while(true)String str=dis.readLine();if(str=null|str.equals(end)break;buffer=str.getBytes();d
28、s.send(new DatagramPacket(buffer,str.length(),ia,clientport);import .*;import java.io.*;public class DatagramClientpublic static DatagramSocket ds;public static byte buffer=new byte1024;public static int clientport=1089,serverport=1090;public static void main(String args) throws Exceptionds=new Data
29、gramSocket(clientport);System.out.println(客户端正在等待服务器发送数据);while(true)DatagramPacket p=new DatagramPacket(buffer,buffer.length);ds.receive(p);String psx=new String(p.getData(),0,p.getLength();System.out.println(psx);13、Java 的通信编程,编程题(或问答),用JAVA SOCKET编程,读服务器几个字符,再写入本地显示? 答:Server端程序: package test; im
30、port .*; import java.io.*; public class Server private ServerSocket ss; private Socket socket; private BufferedReader in; private PrintWriter out; public Server() try ss=new ServerSocket(10000); while(true) socket = ss.accept(); String RemoteIP = socket.getInetAddress().getHostAddress(); String Remo
31、tePort = :+socket.getLocalPort(); System.out.println(A client come in!IP:+RemoteIP+RemotePort); in = new BufferedReader(new InputStreamReader(socket.getInputStream(); String line = in.readLine(); System.out.println(Cleint send is : + line); out = new PrintWriter(socket.getOutputStream(),true); out.p
32、rintln(Your Message Received!); out.close(); in.close(); socket.close(); catch (IOException e) out.println(wrong); public static void main(String args) new Server(); ; Client端程序: package test; import java.io.*; import .*; public class Client Socket socket; BufferedReader in; PrintWriter out; public
33、Client() try System.out.println(Try to Connect to :10000); socket = new Socket(,10000); System.out.println(The Server Connected!); System.out.println(Please enter some Character:); BufferedReader line = new BufferedReader(new InputStreamReader(System.in); out = new PrintWriter(socket.getOutputStream
34、(),true); out.println(line.readLine(); in = new BufferedReader(new InputStreamReader(socket.getInputStream(); System.out.println(in.readLine(); out.close(); in.close(); socket.close(); catch(IOException e) out.println(Wrong); public static void main(String args) new Client(); ; 常见排序法:public class So
35、rtpublic static int count=0;public boolean LT(int num1,int num2)return num1num2;public void output(int array)System.out.print(第+count+次排序:);for(int i=0;iarray.length;i+)System.out.print(arrayi+ );System.out.println();/冒泡排序法public void BubbleSort(int array)boolean swap=true;int index=0;int i=0;while(
36、iarray.length-1)int temp=arrayi;for(int j=i;jarray.length;j+)if(!LT(arrayi,arrayj)int temp2=arrayi;arrayi=arrayj;arrayj=temp2;swap=true;index=j;elseswap=false;i+;if(swap)arrayi=arrayindex;arrayindex=temp;i+;output(array);/直接插入排序法public void InsertSort(int array)for(int i=1;i0;-j)if(LT(arrayj,arrayj-
37、1)arrayj=arrayj-1;arrayj-1=temp;elsebreak;output(array);/快速排序法private int Partition(int array,int low,int high)int temp=arraylow;int pivotkey=arraylow;while(lowhigh)while(lowpivotkey)-high;arraylow=arrayhigh;while(lowhigh&arraylow=pivotkey)+low;arrayhigh=arraylow;arraylow=temp;output(array);return l
38、ow;public void QSort(int array,int low,int high)if(lowhigh)int pivotloc=Partition(array,low,high);QSort(array,low,pivotloc-1);QSort(array,pivotloc+1,high);void QuickSort(int array)QSort(array,0,array.length-1);public static void main(String args)int array=49,38,65,97,76,13,27,49;Sort sort=new Sort()
39、;System.out.println(=);sort.output(array);System.out.println(优化冒泡排序法);sort.BubbleSort(array);System.out.println();System.out.println(=);array=new int49,38,65,97,76,13,27,49;sort.output(array);System.out.println(直接插入排序法);sort.InsertSort(array);System.out.println();System.out.println(=);array=new int4
40、9,38,65,97,76,13,27,49;sort.output(array);System.out.println(快速排序法);sort.QuickSort(array);14、如在COLLECTION框架中,实现比较要实现什么样的接口? Collection框架中实现比较要实现Comparable 接口和 Comparator 接口 什么是线程?线程与进程相似,是一段完成某个特定功能的代码,是程序中单个顺序的流控制;但与进程不同的是,同类的多个线程是共享一块内存空间和一组系统资源,而线程本身的数据通常只有微处理器的寄存器数据,以及一个供程序执行时使用的堆栈。所以系统在产生一个线程,或
41、者在各个线程之间切换时,负担要比进程小的多,正因如此,线程被称为轻负荷进程(light-weight process)。一个进程中可以包含多个线程。一个线程是一个程序内部的顺序控制流。1. 进程:每个进程都有独立的代码和数据空间(进程上下文) ,进程切换的开销大。 2. 线程:轻量的进程,同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器(PC),线程切换的开销小。 3. 多进程:在操作系统中,能同时运行多个任务程序。 4. 多线程:在同一应用程序中,有多个顺序流同时执行。同步和异步有和异同,在什么情况下分别使用他们?临界资源问题线程都是独立的,而且异步执行,也就是说每个线程都包
42、含了运行时所需要的数据或方法,而不需要外部的资源或方法,也不必关心其它线程的状态或行为。但是经常有一些同时运行的线程需要共享数据,此时就需考虑其他线程的状态和行为,否则就不能保证程序的运行结果的正确性。我们需要做的是允许一个线程彻底完成其任务后,再允许下一个线程执行。必须保证一个共享的资源一次只能被一个线程使用。实现此目的的过程称为同步。同步是用于确保资源一次只能被一个线程使用的过程。同步对于单线程程序没有任何好处。使用同步比非同步的性能差三到四倍。线程方法介绍:构造函数:Thread()Thread(Runable target)Thread(Runable target,String na
43、me)Thread(ThreadGroup group,Runable target)Thread(ThreadGroup group,Runable target,String name)Thread(ThreadGroup group,String name)用于完成一个线程“实际功能”的代码放在run方法中。Run方法可以在Thread的子类中重写,也可以在Runable对象中重写。一旦线程死去,它就永远不能再重新启动,否则会抛出异常。用start方法启动一个已经启动的线程也会抛出异常。isAlive、interrupt、Thread.currentThread、suspend、resu
44、me、stopSleep方法可以使低优先级的线程得到执行的机会,Yield方法只能使同优先级的线程有执行的机会。Join方法能够使调用该方法的线程在此之前执行完毕,在该方法之后,调用join方法的线程不会产生输出了,Wait与notify使用时,需要注意的事项?它们只能用于synchronized同步块中;它们需要配对使用;Wait一般出现在一个while循环中,while语句使用一个boolean标志控制。死锁当被锁定的A对象试图访问另一个被锁定的B对象,B对象同时又要访问已被锁定的A对象。这样导致两个线程都在等待另一个线程释放资源,这样就出现了死锁。16、JAVA多线程编程。 用JAVA写
45、一个多线程程序,如写四个线程,二个加1,二个对一个变量减一,输出。 希望大家补上,谢谢 17、STRING与STRINGBUFFER的区别。 答:STRING的长度是不可变的,STRINGBUFFER的长度是可变的。如果你对字符串中的内容经常进行操作,特别是内容要修改时,那么使用StringBuffer,如果最后需要String,那么使用StringBuffer的toString()方法 String s = new String(xyz);创建了几个String Object? 两个JDBC调用数据库的基本步骤Weblogic Server中的JDBC配置1、建立到指定数据库的连接池Conn
46、ection Pool2、建立基于该连接池的数据源DataSource3、访问数据库时通过数据源的JNDI名字查找到该数据源,然后通过数据源获得数据库连接对象。得到该对象后就可以依次生成数据库语句对象和结果集对象,进行相应的数据库操作。import java.sql.*;import javax.naming.*;import javax.sql.*;import java.util.*;import javax.rmi.*;public class DataSourceTestprivate static Context getInitialContext() throws Exceptio
47、nString url=t3:/localhost:7001;String user=system;String password=11111111;Properties properties=null;tryproperties=new Properties();properties.put(Context.INITIAL_CONTEXT_FACTORY,weblogic.jndi.WLInitialContextFactory);properties.put(Context.PROVIDER_URL,url);if(user!=null)properties.put(Context.SEC
48、URITY_PRINCIPAL,user);properties.put(Context.SECURITY_CREDENTIALS,password=null?:password);return new InitialContext(properties);catch(Exception e)throw e;public static void main(String args)UserTransaction tx=null;DataSource ds=null;Context ctx=null;Connection myConn=null;tryctx=getInitialContext()
49、;tx=(UserTranscation)ctx.lookup(javax.transcation.UserTranscation);tx.begin();ds=(DataSource)ctx.lookup(myTxDataSource);catch(Exception e)e.printStackTrace();Statement myStatement=null;ResultSet myResultSet=null;trymyConn=ds.getConnection();myStatement=myConn.createStatement();myResultSet=myStatemen
50、t.executeQuery(select fullname from employee);while(myResultSet.next()System.out.println(myResultSet.getString(fullname);mit();catch(Exception e)trytx.rollback();catch(Exception e)finallymyStatement.close();myConn.close();JavaMail发邮件的步骤:Properties props=System.getProperties();props.put(“mail.smtp.ho
51、st”,”*”); /设置相关的属性try /创建一个会话对象 Session session=Session.getDefaultInstance(props,null); /创建一个消息对象 MimeMessage message=new MimeMessage(session); message.setText(“*”); /发送文本格式的邮件 message.setSubject(“*”); message.setFrom(“*”); message.addRecipient(Message.RecipientType.To, new InternetAddress(“*”); /使用
52、传送类的send方法发送消息 Transport.send(message);catch(MessagingException me) me.printStackTrace();解析XML文件的几种方式和区别XML解析器使用的两种基本API是:文档对象模型DOM,一种基于树结构的API。它定义了一组java接口,用于创建、访问和操纵XML文档的内部结构。它是基于对象。整个XML文档被作为对象体系结构排列进行解析和存储,应用程序可以随机访问这些对象。DOM主要用于:在结构上修改XML文档时;在内存中与其他应用程序共享文档时。SAX提供一种用于解析XML文档的事件驱动模型,使用SAX接口的XML处
53、理器并不创建数据结构,而是扫描输入的XML文档,并生成元素开始、元素结束等事件,在发生事件时,解析器会通知应用程序。SAX优点:在解析大型文档时,不必将整个文件加载到内存中,因此占有的内存比DOM少。在只需要一个信息子集时,SAX忽略不需要的数据,而DOM无法做到这点。SAX的缺点是:必须按到达顺序处理数据,不能对文档进行随即访问。SAX是只读的,它是设计来读取XML文档而不是写入的。文档只能遍历一次。使用DOM API查找XML文档中的元素和属性import org.w3c.dom.*;import javax.xml.parsers.*;import java.io.*;import .U
54、RL;public class BookDetailspublic BookDetails(String filename)Document doc=null;tryDocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();dbf.setNamespaceAware(true);DocumentBuilder db=dbf.newDocumentBuilder();doc=db.parse(new File(filename);String nm=/booktitles;String local=a;String ob=;S
55、ystem.out.println(nm+名字空间中的元素);NodeList nl=doc.getElementsByTagNameNS(nm,*);for(int i=0;inl.getLength();i+)Node n=nl.item(i);System.out.println(n.getNodeName();System.out.println(n 名称为 +local+ 的元素);nl=doc.getElementsByTagNameNS(*,local);for(int i=0;inl.getLength();i+)Node n=nl.item(i);System.out.pri
56、ntln(n.getNodeName();System.out.println(n名字空间 +ob+ 中的属性);nl=doc.getElementsByTagName(*);for(int i=0;inl.getLength();i+)if(nl.item(i) instanceof Element)Text t=(Text)nl.item(i).getFirstChild();Element e=(Element)nl.item(i);Attr a=e.getAttributeNodeNS(ob,class);if(a!=null)String val=a.getNodeValue();S
57、ystem.out.println(+t.getNodeValue()+);catch(Exception e)e.printStackTrace();public static void main(String args)BookDetails nsd=null;if(args.length=1)nsd=new BookDetails(args0);elseSystem.out.println(Books.xml);使用SAX API解析XML文档import org.xml.sax.Attributes;import org.xml.sax.SAXException;import org.
58、xml.sax.helpers.DefaultHandler;import javax.xml.parsers.SAXParser;import javax.xml.parsers.SAXParserFactory;public class SAXParserHandler extends DefaultHanlderpublic void startDocument() throws SAXExceptionSystem.out.println(起始文档);public void endDocument() throws SAXExceptionSystem.out.println(结束文档
59、);/在遇到字符数据时激发public void characters(char ch,int start,int lenght) throws SAXException)String charString=new String(ch,start,lenght);System.out.println(字符:+charString);public void startElement(String namespaceURI,String localName,String qName,Attributes atts)throws SAXExceptionSystem.out.println(起始元素
60、+qName);for(int i=0;iatts.getLength();i+)System.out.println(属性值:+atts.getValue(i);public void endElement(String namespaceURI,String localName,String qName)throws SAXExceptionSystem.out.println(结束元素+qName);public static void main(String args) throws ExceptionSAXParserFactory factory=SAXParserFactory.
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论