尚学堂Java面试题整理

 
1. super()与this()的差别? - 6 - 

2. 作用域public,protected,private,以及不写时的差别? - 6 - 

3. 编程输出例如以下图形。 - 6 - 

4. JAVA的事件托付机制和垃圾回收机制 - 6 - 

5. 在JAVA中,怎样跳出当前的多重嵌套循环? - 6 - 

6. 什么是java序列化,怎样实现java序列化?(写一个实例) - 6 - 

7. 一个".java"源文件里能否够包含多个类(不是内部类)?有什么限制? - 7 - 

8. 排序都有哪几种方法?请列举。用JAVA实现一个高速排序? - 7 - 

9. Overload和Override的差别。Overloaded的方法能否够改变返回值的类型? - 7 - 

10. Final类有什么特点? - 7 - 

11. 继承时候类的运行顺序问题,一般都是选择题,问你将会打印出什么? - 7 - 

12. 内部类的实现方式? - 8 - 

13. 用JAVA实现一种排序,JAVA类实现序列化的方法(二种)? - 8 - 

14. 如在COLLECTION框架中,实现比較要实现什么样的接口? - 8 - 

15. 用插入法进行排序代码例如以下 - 8 - 

16. 编程:编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。 可是要保证汉字不被截半个,如"我ABC"4,应该截为"我AB",输入"我ABC汉DEF",6,应该输出为"我ABC"而不是"我ABC+汉的半个"。 - 9 - 

15、Java编程,打印昨天的当前时刻 - 9 - 

16、文件读写,实现一个计数器 - 10 - 

17、指出以下程序的执行结果。 - 10 - 

18、抽象类和接口的差别? - 10 - 

19、什么是类的返射机制? - 11 - 

20、类的返射机制中的包及核心类? - 11 - 

21、得到Class的三个过程是什么? - 11 - 

22、怎样唤起类中的一个方法? - 11 - 

23、怎样将数值型字符转换为数字(Integer,Double)? - 11 - 

24、怎样将数字转换为字符? - 11 - 

25、怎样去小数点前两位,并四舍五入。 - 11 - 

26、怎样取得年月日,小时分秒? - 11 - 

27、怎样取得从1970年到如今的毫秒数 - 11 - 

28、怎样获取某个日期是当月的最后一天? - 11 - 

29、怎样格式化日期? - 12 - 

30、编码转换,如何实现将GB2312编码的字符串转换为ISO-8859-1编码的字符串。 - 12 - 

32、String s = new String("xyz");创建了几个String Object? - 12 - 

33、float型float f=3.4是否正确? - 12 - 

35、说出一些经常使用的类,包,接口,请各举5个 - 12 - 

36、java中会存在内存泄漏吗,请简单描写叙述。 - 12 - 

37、java中实现多态的机制是什么? - 13 - 

38、垃圾回收器的基本原理是什么?垃圾回收器能够立即回收内存吗?有什么办法主动通知虚拟机进行垃圾回收? - 13 - 

39、静态变量和实例变量的差别? - 13 - 

41、能否够从一个static方法内部发出对非static方法的调用? - 13 - 

42、写clone()方法时,通常都有一行代码,是什么? - 13 - 

43、JAVA语言怎样进行异常处理,keyword:throws,throw,try,catch,finally分别代表什么意义?在try块中能够抛出异常吗? - 13 - 

45、冒泡排序法 - 13 - 

46、String and StringBuffer的差别? - 14 - 

47、用java代码编写堆栈 - 14 - 

48、集合的作用是什么? - 15 - 

49、集合的通用方法有那些?通用方法是什么?(操作) - 15 - 

50、说出ArrayList,Vector, LinkedList的存储性能和特性HashMap和Hashtable的差别 - 15 - 

51、Collection 和 Collections的差别。 - 15 - 

52、Set里的元素是不能反复的,那么用什么方法来区分反复与否呢? 是用==还是equals()? 它们有何差别?用contains来区分是否有反复的对象。还是都不用。 - 15 - 

53、List, Set, Map是否继承自Collection接口? - 16 - 

54、面向对象的特征有哪些方面 - 16 - 

55、String是最主要的数据类型吗? - 16 - 

56、int 和 Integer 有什么差别? - 16 - 

57、执行时异常与一般异常有何异同? - 16 - 

58、&和&&的差别? - 16 - 

59、final, finally, finalize的差别? - 16 - 

62、heap和stack有什么差别? - 16 - 

63、Static Nested Class 和 Inner Class的不同? - 16 - 

64、什么时候用assert? - 17 - 

65、GC是什么? 为什么要有GC? - 17 - 

66、short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错? - 17 - 

67、Math.round(11.5)等於多少? Math.round(-11.5)等於多少? - 17 - 

68、Java有没有goto? - 17 - 

69、给我一个你最常见到的runtime exception - 17 - 

70、接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是否可继承实体类(concrete class)? - 17 - 

71、abstract的method是否可同一时候是static,是否可同一时候是native,是否可同一时候是synchronized? - 17 - 

72、数组有没有length()这种方法? String有没有length()这种方法? - 18 - 

73、构造器Constructor是否可被override? - 18 - 

74、能否够继承String类? - 18 - 

75、swtich能否作用在byte上,能否作用在long上,能否作用在String上? - 18 - 

76、try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被运行,什么时候被运行,在return前还是后? - 18 - 

77、编程题: 用最有效率的方法算出2乘以8等於几? - 18 - 

78、两个对象值同样(x.equals(y) == true),但却可有不同的hash code,这句话对不正确? - 18 - 

79、当一个对象被当作參数传递到一个方法后,此方法可改变这个对象的属性,并可返回变化后的结果,那么这里究竟是值传递还是引用传递? - 18 - 

80、四种会话跟踪技术 - 18 - 

81、编程题: 写一个Singleton出来。 - 18 - 

83、Java中的异常处理机制的简单原理和应用。 - 19 - 

84、垃圾回收的长处和原理。并考虑2种回收机制。 - 19 - 

85、描写叙述一下JVM载入class文件的原理机制? - 19 - 

86、char型变量中能不能存贮一个中文汉字?为什么? - 19 - 

88、写一个程序,从文件(c:\test.txt)中查出字符串”mobnet”出现的次数? - 19 - 

java基础类库(io流,集合类,线程,Socket,AWT,Swing,sql) - 20 - 

1、java中有几种类型的流?JDK为每种类型的流提供了一些抽象类以供继承,请说出他们各自是哪些类? - 20 - 

2、启动一个线程是用run()还是start()? - 20 - 

3、线程的基本概念、线程的基本状态以及状态之间的关系 - 20 - 

4、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么? 用什么keyword修饰同步方法? stop()和suspend()方法为何不推荐使用? - 20 - 

用synchoronized修饰同步方法。 - 20 - 

5、集合框架有什么? - 20 - 

12、设计4个线程,当中两个线程每次对j添加1,另外两个线程对j每次降低1。写出程序 - 21 - 

13、同步和异步有和异同,在什么情况下分别使用他们?举例说明。 - 21 - 

14、sleep() 和 wait() 有什么差别? - 22 - 

15、当一个线程进入一个对象的一个synchronized方法后,其他线程是否可进入此对象的其他方法? - 22 - 

17、输入输出流的理解: - 22 - 

18、请写一个程序的读写,要求用两种方式一种是低层流还有一种是高层流。 - 22 - 

19、怎样列出某个文件夹下的全部文件 - 23 - 

Socket - 24 - 

20、用socket通讯写出client和server端的通讯,要求客户发送数据后可以回显同样的数据? - 24 - 

23、介绍JAVA中的Collection FrameWork(包含怎样写自己的数据结构)? - 25 - 

24、请说出你所知道的线程同步的方法 - 25 - 

jdbc数据訪问技术 - 25 - 

1、JDBC怎样做事务处理? - 25 - 

2、写出几个在Jdbc中经常使用的接口 - 25 - 

3、简述你对Statement,PreparedStatement,CallableStatement的理解 - 25 - 

4、Java中訪问数据库的步骤? - 26 - 

5、JDBC中的核心类及其作用是什么? - 26 - 

6、运行存储过程用那一个类,怎样操作输出參数?(操作) - 26 - 

8、可能会让你写一段Jdbc连Oracle的程序. - 26 - 

9、Class.forName的作用?为什么要用? - 26 - 

10、Jdo是什么? - 26 - 

11、在ORACLE大数据量下的分页解决方法。一般用截取ID方法,还有是三层嵌套方法 - 27 - 

Web编程Jsp&Servlet技术 - 27 - 

1、简单说说tomcat的配置? - 27 - 

2、JSP中动态INCLUDE与静态INCLUDE的差别? - 27 - 

3、forward和redirect的差别? - 27 - 

4、Servlet的体系结构是什么? - 28 - 

Servlet - 28 - 

5、怎样实现一个自己定义的servlet? - 28 - 

6、Servlet的生命周期是什么? - 28 - 

7、jsp就是一个servlet是否正确? - 28 - 

8、请罗列jsp中的脚本、指令及动作? - 28 - 

9、JSP的内置对象及方法 - 28 - 

10、说出在JSP页面里是怎么分页的? - 28 - 

11、include的两种实现方式的差别? - 30 - 

12、jsp页面中两种跳转方式各自是什么?有什么差别? - 30 - 

13、描写叙述JSP和Servlet的差别、共同点、各自应用的范围 - 30 - 

14、在JSP中怎样读取client的请求,怎样确定某个Jsp文件的真实路径? - 30 - 

15、描写叙述Cookie和Session的作用,差别和各自的应用范围,Session工作原理。 - 30 - 

16、说明Jsp中errorPage的作用,应用范围。 - 31 - 

17、介绍在Jsp中怎样使用JavaBeans - 31 - 

19、简介JSP的标记库 - 31 - 

20、Servlet中的核心类有那些,各有什么特点? - 31 - 

21、Servlet中重要的包有那些,有什么差别? - 31 - 

22、说出Servlet的生命周期,并说出Servlet和CGI的差别? - 31 - 

23、什么情况下调用doGet()和doPost()? - 31 - 

25、怎样现实servlet的单线程模式 - 32 - 

27、Request对象的主要方法: - 32 - 

28、我们在web应用开发过程中常常遇到输出某种编码的字符,如iso8859-1等,怎样输出一个某种编码的字符串? - 32 - 

30、Servlet运行时一般实现哪几个方法? - 32 - 

5 Hibernate持久层技术 - 32 - 

1、在myeclipse增加hibernate环境的全过程是什么? - 32 - 

2、hibernate的核心配置文件是什么及其作用? - 33 - 

3、hibernate的核心类是什么,它们的相互关系是什么?重要的方法是什么? - 33 - 

4、关联: - 33 - 

5、hibernate中的one-to-many或many-to-one中经常使用的方式是什么? - 33 - 

6、Criteria 的作用? - 33 - 

7、DetachedCriteria的作用? - 33 - 

8、Query - 34 - 

9、继承关系的实现 - 34 - 

10、tomcat连接池:在容器中预先产生了n个连接实例,client不用又一次实例化,能够直接取。 - 34 - 

11、对象的三大状态 - 35 - 

12、hibernate常见优化策略 - 36 - 

6. iBatis持久层技术 - 36 - 

用ibatis的原因: - 36 - 

jdbc、hibernate、ibatis的差别 - 36 - 

ibatis的核心配置文件: - 36 - 

ibatis的核心类: - 36 - 

7 Structs界面控制层技术 - 37 - 

1、请说出struts框架的几大组件? - 37 - 

3、struts的核心类有那些,在MVC模式中其相应的关系是什么? - 37 - 

4、Struts的处理请求的全过程是什么? - 37 - 

5、在struts中怎样通过一个url找到一个action,它的核心配置文件是什么? - 38 - 

6、为什么使用MVC,其主要目的是什么? - 38 - 

7、对于MVC在action中相应有类有几种,各有什么作用? - 38 - 

8、struts的标记有几类,请列举并说明其作用? - 38 - 

9、怎样在struts中配置数据源在,什么文件?用什么标签?怎样取出DataSource? - 38 - 

10、怎样在jbuilder中开发struts? - 38 - 

11、怎样实现struts的validator框架? - 39 - 

13、怎样实现国际化? - 39 - 

国际化:不用改动代码,就适用于不同的语言国家 - 39 - 

8 JSF界面控制层技术 - 40 - 

1、Jsf中的核心类用那些?有什么作用? - 40 - 

2、Jsf中的LiftCycle六大生命周期是什么? - 40 - 

3、怎样管量web层中的Bean,用什么标签。怎样通过jsp页面与Bean绑定在一起进行处理? - 40 - 

4、Jsf中导航的标签是什么? - 40 - 

5、jsf中用户界面组件模型有几类,各代表什么? - 40 - 

6、表格处理及取值 - 40 - 

7、jsf的标签库有哪些? - 41 - 

9 Spring 应用框架技术 - 41 - 

1、Spring和Struts的差别? strusts:是一种基于MVC模式的一个web层的处理。 - 41 - 

2、什么是aop,aop的作用是什么? - 41 - 

3、aop中的关键名词有些那些,相互关系是什么? - 41 - 

4、依赖注入的方式有几种,各是什么? - 41 - 

5、spring中的核心类有那些,各有什么作用? - 42 - 

6、ApplicationContext的作用 - 42 - 

7、怎样实现资源管理 - 42 - 

8、怎样实现增加web框架中 - 42 - 

9、怎样实现事件处理 - 42 - 

10、spring的ioc及di代表什么意思? - 42 - 

、怎样在spring中实现国际化? - 42 - 

12、spring的配置的主要标签是什么?有什么作用? - 43 - 

13、spring与ejb2.0的事务管理比較的优缺点? - 43 - 

14、spring的jdbc与传统的jdbc有什么差别,其核心类有那些? - 43 - 

15、在spring中有几种事务管理,各自是什么? - 43 - 

16、在spring中怎样配代码的事务管理? - 44 - 

17、在spring中怎样配容器的事务管理,相关的类有那些? - 44 - 

18、假设spring与hibernate结合在一起能够不须要hibernate.cfg.xml文件是否正确? - 44 - 

19、spring+hibernate的配置文件里的主要类有那些?怎样配置? - 44 - 

20、spring+hibernate的代码实现中,对于实现类一定继承于一个类是那一个,它有什么作用。 - 44 - 

21、怎样配置spring+struts? - 44 - 

22、怎样在web环境中配置applicationContext.xml文件? - 44 - 

24、Jsf和spring的差别? - 45 - 

jsf:是一种基于MVC模式的一个web层的处理,粒度较struts较细。 - 45 - 

Ejb技术 - 45 - 

1、weblogic的热公布 - 45 - 

2、在ejb中实现one-to-many - 45 - 

3、ejb所用的技术: - 45 - 

4、实现ejb几个接口,几个类? - 45 - 

5、实现ejb相关的配置文件是什么? - 45 - 

6、ejb的分类?差别 - 46 - 

7、本地接口与远程接口的差别。 - 46 - 

8、请求处理的过程? - 46 - 

9、statefull的生命周期 - 46 - 

10、stateless的生命周期 - 46 - 

11、entityBean的生命周期: - 46 - 

12、EJB需直接实现它的业务接口或Home接口吗,请简述理由。 - 47 - 

13、EJB的激活机制 - 47 - 

14、EJB是基于哪些技术实现的?并说 出SessionBean和EntityBean的差别, - 47 - 

15、EJB的分类是什么?各有什么特点? - 47 - 

10、EJB中基本的配置文件及作用是什么? - 47 - 

15、说出数据连接池的工作机制是什么? - 48 - 

16、EJB2.0有哪些内容?分别用在什么场合? EJB2.0和EJB1.1的差别? - 48 - 

18、EJB与JAVA BEAN的差别? - 48 - 

19、EJB的角色和三个对象 - 48 - 

20、EJB容器提供的服务 - 48 - 

21、EJB规范规定EJB中禁止的操作有哪些? - 48 - 

26、EJB的基本架构 - 49 - 

30、怎样在weblogic中进行ssl配置与client的认证配置或说说j2ee(标准)进行ssl的配置 - 49 - 

31怎样查看在weblogic中已经公布的EJB? - 49 - 

WebService技术 - 49 - 

1、什么是Web Service? - 49 - 

2、什么是Web容器? - 50 - 

3、应用server有那些? - 50 - 

5、怎样给weblogic指定大小的内存? - 50 - 

6、怎样设定的weblogic的热启动模式(开发模式)与产品公布模式? - 50 - 

7、怎样启动时不需输入username与password? - 50 - 

8、在weblogic管理制台中对一个应用域(或者说是一个站点,Domain)进行jms及ejb或连接池等相关信息进行配置后,实际保存在什么文件里? - 50 - 

9、说说weblogic中一个Domain的缺省文件夹结构?比方要将一个简单的helloWorld.jsp放入何文件夹下,然的在浏览器上就可打入 http://主机:port号//helloword.jsp就能够看到执行结果了? 又比方这当中用到了一个自己写的javaBean该怎样办? - 50 - 

12、CORBA是什么?用途是什么? - 50 - 

13、说说在weblogic中开发消息Bean时的persistent与non-persisten的区别 - 50 - 

14、WEB SERVICE名词解释。JSWDL开发包的介绍。JAXP、JAXM的解释。SOAP、UDDI,WSDL解释。 - 50 - 

j2ee模式(MVC模式、Model1,Model2) - 51 - 

1、j2ee经常使用的设计模式?说明工厂模式。 - 51 - 

2、说说你所熟悉或听说过的j2ee中的几种经常使用模式?及对设计模式的一些看法 - 51 - 

3、解释以下关于J2EE的名词 - 51 - 

4、介绍J2EE、J2SE、J2ME的差别。 - 51 - 

5、开发中都用到了那些设计模式?用在什么场合? - 52 - 

6、J2EE是什么? - 52 - 

7、J2EE是技术还是平台还是框架? - 52 - 

其它 - 52 - 

1、当前主流的解析器有那些? - 52 - 

2、Dom解析处理的过程是什么? - 52 - 

3、Sax解析处理的过程是什么? - 53 - 

4、Dom与Sax相比它们的优缺点是什么? - 54 - 

5、怎样将Dom对象写入到文件里? - 54 - 

6、用jdom解析xml文件时怎样解决中文问题? - 54 - 

7、XML文档定义有几种形式?它们之间有何本质差别?解析XML文档有哪几种方式? - 54 - 

8、标准建模语言UML中的各种图? - 54 - 

9、BS与CS的联系与差别。 - 54 - 

10、Uml的概念是什么?基本的工具是什么 - 55 - 

Uml:统一建模语言 - 55 - 

11、Uml的概念中的九大图形是什么?最重的三个图是什么?各有什么特点? - 55 - 

13、在类图中怎样找类? - 56 - 

Java面试题整理 

Java面向对象 

super()与this()的差别? 

This():当前类的对象,super父类对象。 

Super():在子类訪问父类的成员和行为,必须受类继承规则的约束 

而this他代表当前对象,当然全部的资源都能够訪问. 

在构造函数中,假设第一行没有写super(),编译器会自己主动插入.可是假设父类没有不带參数的构造函数,或这个函数被私有化了(用private修饰).此时你必须增加对父类的实例化构造.而this就没有这个要求,由于它本身就进行实例化的构造.而在方法中super和this使用的方法就差点儿相同了.仅仅只是super 要考虑能否訪问其父类的资源. 



作用域public,protected,private,以及不写时的差别? 

Public:不同包、同一包、类内都可用 

Private:类内 

Protected: 不同包的子类、同一包、类内都可用 

不写时:同一包内、类内 

编程输出例如以下图形。 

* * * * * 

* * * * 

* * * 

* * 



代码例如以下: 

public class Print { 

public static void main(String[] args) { 

for (int i = 0; i < 5; i++) { 

for (int j = 5; j > i; j--) { 

System.out.print("*"); 



System.out.println(); 







JAVA的事件托付机制和垃圾回收机制 

java 事件托付机制的概念,一个源产生一个事件并将它送到一个或多个监听器那里。在这样的方案中,监听器简单的等待,直到它收到一个事件。一旦事件被接受,监听器将处理这个事件,然后返回。 

垃圾回收机制 垃圾收集是将分配给对象但不再使用的内存回收或释放的过程。假设一个对象没有指向它的引用或者其赋值为null,则次对象适合进行垃圾回收 



在JAVA中,怎样跳出当前的多重嵌套循环? 

用break; return 方法。 

什么是java序列化,怎样实现java序列化?(写一个实例) 

序列化: 

能够将一个对象保存到一个文件,所以能够通过流的方式在网络上传输,能够将文件的内容读取,转化为一个对象。 



处理对象流的机制,所谓对象流也就是将对象的内容进行流化。能够对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了解决在对对象流进行读写操作时所引发的问题。 

序列化的实现: 

将须要被序列化的类实现Serializable接口,该接口没有须要实现的方法,implements Serializable仅仅是为了标注该对象是可被序列化的,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就能够将參数为obj的对象写出(即保存其状态),要恢复的话则用输入流。 



一个".java"源文件里能否够包含多个类(不是内部类)?有什么限制? 

能够。假设这个类的修饰符是public,其类名与文件名称必须同样。 

排序都有哪几种方法?请列举。用JAVA实现一个高速排序? 

排序的方法有:插入排序(直接插入排序、希尔排序),交换排序(冒泡排序、高速排序),选择排序(直接选择排序、堆排序),归并排序,分配排序(箱排序、基数排序) 

高速排序的伪代码。 

Overload和Override的差别。Overloaded的方法能否够改变返回值的类型? 

方法的 

重写Override,子类覆盖父类的方法,将子类传与父类的引用调用的还是子类的方法。 

重载Overloading 一个类多个方法,名称同样,參数个数类型不同。 

两者都是Java多态性的不同表现。 

Overloaded的方法是能够改变返回值的类型。 



1, public class Ctest() 



Public static void main() 



System.out.prinln(8+8+”88”+8+8); 







168888 

Final类有什么特点? 

属性常量 

方法不能够overridding 

类不能够继承 

继承时候类的运行顺序问题,一般都是选择题,问你将会打印出什么? 

答:父类: 

package test; 

public class FatherClass 



public FatherClass() 



System.out.println("FatherClass Create"); 





子类: 

package test; 

import test.FatherClass; 

public class ChildClass extends FatherClass 



public ChildClass() 



System.out.println("ChildClass Create"); 



public static void main(String[] args) 



FatherClass fc = new FatherClass(); 

ChildClass cc = new ChildClass(); 





输出结果: 

C:>java test.ChildClass 

FatherClass Create 

FatherClass Create 

ChildClass Create 

内部类的实现方式? 

答:演示样例代码例如以下: 

package test; 

public class OuterClass 



private class InterClass 



Public Interlass() 



System.out.println("InterClass Create"); 





public OuterClass() 



InterClass ic = new InterClass(); 

System.out.println("OuterClass Create"); 



public static void main(String[] args) 



OuterClass oc = new OuterClass(); 





输出结果: 

C:>java test/OuterClass 

InterClass Create 

OuterClass Create 

用JAVA实现一种排序,JAVA类实现序列化的方法(二种)? 

如在COLLECTION框架中,实现比較要实现什么样的接口? 

Collection框架中实现比較要实现Comparable 接口和 Comparator 接口 

用插入法进行排序代码例如以下 

package test; 

import java.util.*; 

class InsertSort 



ArrayList al; 

public InsertSort(int num,int mod) 



al = new ArrayList(num); 

Random rand = new Random(); 

System.out.println("The ArrayList Sort Before:"); 

for (int i=0;i<num ;i++ ) 



al.add(new Integer(Math.abs(rand.nextInt()) % mod + 1)); 

System.out.println("al["+i+"]="+al.get(i)); 





public void SortIt() 



Integer tempInt; 

int MaxSize=1; 

for(int i=1;i<al.size();i++) 



tempInt = (Integer)al.remove(i); 

if(tempInt.intValue()>=((Integer)al.get(MaxSize-1)).intValue()) 



al.add(MaxSize,tempInt); 

MaxSize++; 

System.out.println(al.toString()); 

} else { 

for (int j=0;j<MaxSize ;j++ ) 



if 



(((Integer)al.get(j)).intValue()>=tempInt.intValue()) 



al.add(j,tempInt); 

MaxSize++; 

System.out.println(al.toString()); 

break; 









System.out.println("The ArrayList Sort After:"); 

for(int i=0;i<al.size();i++) 



System.out.println("al["+i+"]="+al.get(i)); 





public static void main(String[] args) 



InsertSort is = new InsertSort(10,100); 

is.SortIt(); 









JAVA类实现序例化的方法是实现java.io.Serializable接口 



编程:编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。 可是要保证汉字不被截半个,如"我ABC"4,应该截为"我AB",输入"我ABC汉DEF",6,应该输出为"我ABC"而不是"我ABC+汉的半个"。 

答:代码例如以下: 

public static void split(String source,int num) throws Exception 



int k=0; 

String temp=""; 

for (int i = 0; i <source.length(); i++) 

{

byte[] b=(source.charAt(i)+"").getBytes(); 

k=k+b.length; 

if(k>num) 



break; 



temp=temp+source.charAt(i);

}

System.out.println(temp); 





15、Java编程,打印昨天的当前时刻 

public class YesterdayCurrent{ 

public void main(String[] args){ 

Calendar cal = Calendar.getInstance(); 

cal.add(Calendar.DATE, -1); 

System.out.println(cal.getTime()); 





16、文件读写,实现一个计数器 

public int getNum(){ 

int i = -1; 

try{ 

String stri=""; 

BufferedReader in = new BufferedReader(new FileReader(f)); 

while((stri=in.readLine())!=null){ 

i = Integer.parseInt(stri.trim()); 



in.close(); 

}catch(Exception e){ 

e.printStackTrace(); 



return i; 



public void setNum(){ 

int i = getNum(); 

i++; 

try{ 

PrintWriter out=new PrintWriter(new BufferedWriter(new FileWriter(f,false))); 

out.write(String.valueOf(i)); //可能是编码的原因,假设直接写入int的话,将出现java编码和windows编码的混乱,因此此处写入的是String 

out.close() ; 

}catch(Exception e){ 

e.printStackTrace(); 







17、指出以下程序的执行结果。 

class A{ 

static{ 

System.out.print("1"); 



public A(){ 

System.out.print("2"); 





class B extends A{ 

static{ 

System.out.print("a"); 



public B(){ 

System.out.print("b"); 





public class Hello{ 

public static void main(String[] ars){ 

A ab = new B(); //运行到此处,结果: 1a2b 

ab = new B(); //运行到此处,结果: 1a2b2b 





  注:类的static 代码段,能够看作是类首次载入(被虚拟机载入)运行的代码,而对于类的载入,首先要运行其基类的构造,再运行其本身的构造 

18、抽象类和接口的差别? 

(1)接口能够被多重implements,抽象类仅仅能被单一extends 

(2)接口仅仅有定义,抽象类能够有定义和实现 

(3)接口的字段定义默觉得:public static final, 抽象类字段默认是"friendly"(本包可见) 

当功能须要累积时用抽象类,不须要累积时用接口。 

19、什么是类的返射机制? 

通过类(Class对象),能够得出当前类的fields、method、construtor、interface、superClass、modified等,同是能够通过类实例化一个实例、设置属性、唤醒方法。Spring中一切都是返射、struts、hibernate都是通过类的返射进行开发的。 

20、类的返射机制中的包及核心类? 

 java.lang.Class 

 java.lang.refrection.Method 

 java.lang.refrection.Field 

 java.lang.refrection.Constructor 

 java.lang.refrection.Modifier 

 java.lang.refrection.Interface 

21、得到Class的三个过程是什么? 

对象.getClass() 

类.class或Integer.type(int)  Integer.class(java.lang.Integer) 

Class.forName(); 

22、怎样唤起类中的一个方法? 

产生一个Class数组,说明方法的參数 

通过Class对象及方法參数得到Method 

通过method.invoke(实例,參数值数组)唤醒方法 

23、怎样将数值型字符转换为数字(Integer,Double)? 

Integer.parseInt(“1234”) 

Double.parseDouble(“123.2”) 

24、怎样将数字转换为字符? 

1+”” 

1.0+”” 

25、怎样去小数点前两位,并四舍五入。 

double d=1256.22d; 

d=d/100; 

System.out.println(Math.round(d)*100); 

26、怎样取得年月日,小时分秒? 

Calendar c=Calendar.getInstance(); 

c.set(Calendar.YEAR,2004); 

c.set(Calendar.MONTH,0); 

c.set(Calendar.DAY_OF_MONTH,31); 

System.out.println(c.get(Calendar.YEAR)+"  "+(c.get(Calendar.MONTH)+1)+"  "+c.get(Calendar.DAY_OF_MONTH)); 

27、怎样取得从1970年到如今的毫秒数 

Java.util.Date dat=new Date(); 

long now=dat.getTime(); 

28、怎样获取某个日期是当月的最后一天? 

当前日期加一天,若当前日期与结果的月份不同样,就是最后一天。 



取下一个月的第一天,下一个月的第一天-1 



public static void main(String[] args) 



Calendar c=Calendar.getInstance(); 

c.set(Calendar.YEAR,2004); 

c.set(Calendar.MONTH,0); 

c.set(Calendar.DAY_OF_MONTH,30); 

Calendar c1=(Calendar)c.clone(); 

System.out.println(c.get(Calendar.YEAR)+"  "+(c.get(Calendar.MONTH)+1)+"  "+c.get(Calendar.DAY_OF_MONTH)); 



c.add(Calendar.DAY_OF_MONTH,1); 

if(c.get(Calendar.MONTH)!=c1.get(Calendar.MONTH)) 



System.out.println("是最后一天"); 



else 



System.out.println("不是取后一天"); 







29、怎样格式化日期? 

Import java.text. SimpleDateFormat; 

SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); 

Date dat=new Date(); 

//把日期转化为字符串 

String str=sdf.format(dat); 

System.out.println(str); 

//将字符串转化为日期 

Java.util.Date d1=sdf.parse(“yyyy-mm-dd”); 

30、编码转换,如何实现将GB2312编码的字符串转换为ISO-8859-1编码的字符串。 

String a=new String("中".getBytes("gb2312"),"iso-8859-1"); 





String a=new String("中".getBytes("iso-8859-1")); 



32、String s = new String("xyz");创建了几个String Object? 

New了一个,”XYZ”本来又是一个 

两个 

33、float型float f=3.4是否正确? 

 报错,应当是float f=3.4f 

 假设是float f=3(整数)正确 

35、说出一些经常使用的类,包,接口,请各举5个 

经常使用的类:BufferedReader  BufferedWriter  FileReader  FileWirter  String  Integer 

经常使用的包:java.lang  java.awt  java.io  java.util  java.sql javax.xml javax.sevlet javax.ejb.  java.net  javax.faces  

经常使用的接口: List  Map  Document  NodeList EjbObject EjbHome SessionBean  EntityBean 

36、java中会存在内存泄漏吗,请简单描写叙述。 

会。如:int i,i2;  return (i-i2);   //when i为足够大的正数,i2为足够大的负数。结果会造成溢位,导致错误。 

37、java中实现多态的机制是什么? 

静态的多态:方法名同样,參数个数或类型不同样。(overloading) 

动态的多态: 

子类覆盖父类的方法,将子类的实例传与父类的引用调用的是子类的方法 

实现接口的实例传与接口的引用调用的实现类的方法。

38、垃圾回收器的基本原理是什么?垃圾回收器能够立即回收内存吗?有什么办法主动通知虚拟机进行垃圾回收? 

动态内存 

存放类实例 

静态内存 

类本身 

垃圾收集主要针对的是动态内存,一般当内存不够用时会进行垃圾收集。 

或通过System.gc()手动收集,但不保证一定运行。 

39、静态变量和实例变量的差别? 

static i = 10; //常量 

  class A a;  a.i =10;//可变 

静态方法能够调用静态变量。 

实现方法能够调用静态变量、实例变量 

41、能否够从一个static方法内部发出对非static方法的调用? 

不能够,假设当中包括对象的method();不能保证对象初始化. 

42、写clone()方法时,通常都有一行代码,是什么? 

Clone 有缺省行为,super.clone();他负责产生正确大小的空间,并逐位复制。 

43、JAVA语言怎样进行异常处理,keyword:throws,throw,try,catch,finally分别代表什么意义?在try块中能够抛出异常吗? 

Try:运行部分,产生异常 

Catch:捕捉异常 

Finally:无论有没有异常都运行 

Throws:在方法声明处声明要抛出的异常,调用者必须对其进行处理。 

Throw:抛出一个异常 



在try中能够抛出异常,一般与声明的异常同样。 



自己定义异常要继承于Exception或Exception的子类 

45、冒泡排序法 

//相邻两个数比較,将最小或最大的放到后面,最后面数的不參与比較 

public class BubbleSort { 

private static int al[] = new int[10]; 

public BubbleSort() { 

al[0]=2; 

al[1]=3; 

al[2]=23; 

al[3]=45; 

al[4]=1; 

al[5]=67; 

al[6]=23; 

al[7]=80; 

al[8]=35; 

al[9]=72; 



public static void main(String[] args) { 

BubbleSort bs = new BubbleSort(); 

System.out.println("排序前:"); 

display(al); 



for(int i=0;i<al.length;i++) { 



for (int j = 0; j < al.length-i-1; j++) { 



if(al[j]>al[j+1]) { 

swap(j,j+1); 







System.out.println(); 

System.out.println("排序后:"); 

display(al); 



private static void display(int[] al2) { 

for (int i = 0; i < al2.length; i++) { 

System.out.print(al2[i]+"  "); 





private static void swap(int i, int j) { 

int temp = al[i]; 

al[i]= al[j]; 

al[j] = temp; 





46、String and StringBuffer的差别? 

String:长度给定不可变,当多个字符串联合时要先转为StringBuffer,再联合,速度慢。 

StringBuffer:长度可变,能够将多个字符串值直接联合,效率高 

47、用java代码编写堆栈 

public class Stack { 



int[] data; 

int maxSize; 

int top; 

public Stack(int maxSize) { 

this.maxSize = maxSize; 

data = new int[maxSize]; 

top = -1; 





/** 

* 依次增加数据 

* @param data 要增加的数据 

* @return 加入是否成功 

*/ 

public boolean push(int data) { 

if(top+1== maxSize) { 

System.out.println("栈已满!"); 

return false; 



this.data[++top] = data; 

return true; 





/** 

* 从栈中取出数据 

* @return 取出的数据 

*/ 

public int pop() throws Exception{ 

if(top==-1) { 

throw new Exception("栈已空!"); 



return this.data[top--]; 





public static void main(String[] args) throws Exception { 

Stack stack=new Stack(1000); 

stack.push(1); 

stack.push(2); 

stack.push(3); 

stack.push(4); 

stack.push(5); 

while(stack.top>=0) 



System.out.println(stack.pop()); 

}





48、集合的作用是什么? 

数据的传送 增、删、改、查、constainsAll,能够存放不同类型的对象。 

49、集合的通用方法有那些?通用方法是什么?(操作) 

集合List 的遍历方法有: 

Iterator: 

Enumeration 

For 

Get 

set 

Collection的通用方法有: 

Iterator() 

Add() 

Clear(); 

remove() 



50、说出ArrayList,Vector, LinkedList的存储性能和特性HashMap和Hashtable的差别 

ArrayList Vector:以数组的方式存储,增、删慢,查、改快 

ArrayList:线程不安全,速度快 

Vector:线程安全,速度慢(synchoronized) 

LikedList: 以单链表的方式存储,增、删快,查、改慢 



HashMap与Hashtable都实现的Map接口,HashTable线程安全,HashMap线程不安全。 

51、Collection 和 Collections的差别。 

Collection是集合的根接口,其下有set及list 

Collections是集合的算法。 

52、Set里的元素是不能反复的,那么用什么方法来区分反复与否呢? 是用==还是equals()? 它们有何差别?用contains来区分是否有反复的对象。还是都不用。 



在比較时先调用hashCode方法,假设不同样,证明不相等。 

假设同样,再调用equals方法,假设equals方法同样,证明相等,不同样,证明不相等。 



==:主要用在基本数据类型及引用 

Equals:主要是对象或对象引用的比較。 



集合中是否包括某一个元素用contains来推断。 

53、List, Set, Map是否继承自Collection接口? 

List,set继承于Collection 

Map没有继承于Collection,其相对是独立的。 

属于Collection类型的对象,能够通过构造函数将一个集合构造成另外一个集合。 

54、面向对象的特征有哪些方面  

1.抽象: 

找共性,将共同拥有的属性、方法放到父类中 

2.继承: 

子类继承于父类,具有父类的全部属性与方法,能够重用,也能够覆盖。 

3.封装: 

一个类包含多个属性及方法。 

4. 多态性: 

动态: 

静态: 

55、String是最主要的数据类型吗? 

基本数据类型包含byte、int、char、long、float、double、boolean和short。 



java.lang.String类是final类型的,因此不能够继承这个类、不能改动这个类。为了提高效率节省空间,我们应该用StringBuffer类 

56、int 和 Integer 有什么差别? 

Int是基本数据类型,不是对象,占一个内存空间,没有方法。与其同类的有long,char,doble 

Integer是封装类,具有方法及属性。与其同类的有Long,Double.Float 

57、执行时异常与一般异常有何异同? 

执行时异常:java JVM抛出的异常,代码中不用处理。 



一般异常:用户抛出的异常,假设用throws 声明了,调用这种方法的代码必须对其处理。 

58、&和&&的差别? 

&:与: 左边若为false右边还运行。 

&&:短路与,左边若为false右边不运行。 

59、final, finally, finalize的差别? 

final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。 

finally是异常处理语句结构的一部分,表示总是运行。 

finalize是Object类的一个方法,在垃圾收集器运行的时候会调用被回收对象的此方法,能够覆盖此方法提供垃圾收集时的其它资源回收,比如关闭文件等。 

算符能够用来决定某对象的类是否实现了接口。 

62、heap和stack有什么差别? 

栈是一种线形集合,其加入和删除元素的操作应在同一段完毕。栈依照后进先出的方式进行处理。 

堆是栈的一个组成元素 



63、Static Nested Class 和 Inner Class的不同? 

Static Nested Class是被声明为静态(static)的内部类,它能够不依赖于外部类实例被实例化。而通常的内部类须要在外部类实例化后才干实例化。 

64、什么时候用assert? 

assertion (断言)在软件开发中是一种经常使用的调试方式,非常多开发语言中都支持这样的机制。在实现中,assertion就是在程序中的一条语句,它对一个 boolean表达式进行检查,一个正确程序必须保证这个boolean表达式的值为true;假设该值为false,说明程序已经处于不对的状态下,系统将给出警告或退出。一般来说,assertion用于保证程序最基本、关键的正确性。assertion检查通常在开发和測试时开启。为了提高性能,在软件公布后,assertion检查一般是关闭的。 

65、GC是什么? 为什么要有GC? 

GC是垃圾收集的意思(Gabage Collection),内存处理是编程人员easy出现故障的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃,Java提供的GC功能能够自己主动监測对象是否超过作用域从而达到自己主动回收内存的目的,Java语言没有提供释放已分配内存的显示操作方法。 

66、short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错? 

short s1 = 1; s1 = s1 + 1; (s1+1运算结果是int型,须要强制转换类型) short s1 = 1; s1 += 1;(能够正确编译) 

67、Math.round(11.5)等於多少? Math.round(-11.5)等於多少? 

Math.round(11.5)==12 Math.round(-11.5)==-11 round方法返回与參数最接近的长整数,參数加1/2后求其floor. 



68、Java有没有goto? 

java中的保留字,如今没有在java中使用。 



69、给我一个你最常见到的runtime exception 

ArithmeticException, ArrayStoreException, BufferOverflowException, BufferUnderflowException, CannotRedoException, CannotUndoException, ClassCastException, CMMException, ConcurrentModificationException, DOMException, EmptyStackException, IllegalArgumentException,
IllegalMonitorStateException, IllegalPathStateException, IllegalStateException, ImagingOpException, IndexOutOfBoundsException, MissingResourceException, NegativeArraySizeException, NoSuchElementException, NullPointerException, ProfileDataException, ProviderException,
RasterFormatException, SecurityException, SystemException, UndeclaredThrowableException, UnmodifiableSetException, UnsupportedOperationException 



一般异常: 

IOException 

FileNotFoundException 

SqlException 



70、接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是否可继承实体类(concrete class)? 

接口能够继承接口。抽象类能够实现(implements)接口,抽象类是否可继承实体类。 

71、abstract的method是否可同一时候是static,是否可同一时候是native,是否可同一时候是synchronized? 

    都不能 

72、数组有没有length()这种方法? String有没有length()这种方法? 

数组没有length()这种方法,有length这个属性 

String有length()这种方法. 

73、构造器Constructor是否可被override? 

构造器Constructor不能被继承,因此不能重写Overriding,但能够被重载Overloading。 

74、能否够继承String类? 

String类是final类故不能够继承。 

75、swtich能否作用在byte上,能否作用在long上,能否作用在String上? 

switch(expr1)中,expr1是一个整数表达式。因此传递给 switch 和 case 语句的參数应该是 int、 short、 char 或者 byte。long,string 都不能作用于swtich。 

76、try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被运行,什么时候被运行,在return前还是后? 

会运行,在return前运行。 

77、编程题: 用最有效率的方法算出2乘以8等於几? 

2 << 3 

78、两个对象值同样(x.equals(y) == true),但却可有不同的hash code,这句话对不正确? 

对,有同样的hash code。 

79、当一个对象被当作參数传递到一个方法后,此方法可改变这个对象的属性,并可返回变化后的结果,那么这里究竟是值传递还是引用传递? 

是引用传递 

基本数据类型:值 

对象: 引用 

80、四种会话跟踪技术 

Cookie 

Session 

Hidden 

url 重写 

81、编程题: 写一个Singleton出来。 

Singleton模式主要作用是保证在Java应用程序中,一个类Class仅仅有一个实例存在。 

一般Singleton模式通常有几种种形式: 

第一种形式: 定义一个类,它的构造函数为private的,它有一个static的private的该类变量,在类初始化时实例话,通过一个public的getInstance方法获取对它的引用,继而调用当中的方法。 

public class Singleton { 

private Singleton(){} 

      //在自己内部定义自己一个实例,是不是非常奇怪? 

      //注意这是private 仅仅供内部调用 

      private static Singleton instance = new Singleton(); 

      //这里提供了一个供外部訪问本class的静态方法,能够直接訪问   

      public static Singleton getInstance() { 

        return instance;    

      } 

    } 

    另外一种形式: 

public class Singleton { 

  private static Singleton instance = null; 

  public static synchronized Singleton getInstance() { 

  //这种方法比上面有所改进,不用每次都进行生成对象,仅仅是第一次      

  //使用时生成实例,提高了效率! 

  if (instance==null) 

    instance=new Singleton(); 

return instance;   } 



其它形式: 

定义一个类,它的构造函数为private的,全部方法为static的。 

一般觉得第一种形式要更加安全些 

83、Java中的异常处理机制的简单原理和应用。 

原理 

有错直接转到异常处理部分或向上抛出。 

应用: 

JAVA的异常就是错误,有两种一种是执行时,编码能够不用捕捉。一种是一般异常,假设throws声明了,必须进行处理。 

84、垃圾回收的长处和原理。并考虑2种回收机制。 

长处: 

程序猿不用管内存,jvm自己主动完毕,开发方便。执行优先很低,程序无法清楚实例什么时候被消毁。 



85、描写叙述一下JVM载入class文件的原理机制? 

JVM中类的装载是由ClassLoader和它的子类来实现的,Java ClassLoader 是一个重要的Java执行时系统组件。它负责在执行时查找和装入类文件的类。 

86、char型变量中能不能存贮一个中文汉字?为什么? 

可以定义成为一个中文的,由于java中以unicode编码,一个char占16个字节,所以放一个中文是没问题的 



88、写一个程序,从文件(c:\test.txt)中查出字符串”mobnet”出现的次数? 





java基础类库(io流,集合类,线程,Socket,AWT,Swing,sql) 

1、java中有几种类型的流?JDK为每种类型的流提供了一些抽象类以供继承,请说出他们各自是哪些类? 

字节流,字符流。字节流继承于InputStream OutputStream,字符流继承于Reader Writer。在java.io包中还有更多的流,低层流与调层流,高层流主要是为了提高性能和使用方便。 

2、启动一个线程是用run()还是start()? 

启动一个线程是调用start()方法,启动线程并调用run方法。 

3、线程的基本概念、线程的基本状态以及状态之间的关系 

线程是进程内的并发,没有自已内存空间,共享进程的,线程间的通信成本较低。 

Java中的线程有四种状态各自是:执行、就绪、挂起、结束。 

4、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么? 用什么keyword修饰同步方法? stop()和suspend()方法为何不推荐使用? 

Extends Thread 

Implements Runnable 

同步 

Public synchronized aa() 











Public void cc(object aa) 



synchronized(aa) 









用synchoronized修饰同步方法。 



答:多线程有两种实现方法,各自是继承Thread类与实现Runnable接口 

同步的实现方面有两种,各自是synchronized,wait与notify 

反对使用stop(),是由于它不安全。它会解除由线程获取的全部锁定,并且假设对象处于一种不连贯状态,那么其它线程能在那种状态下检查和改动它们。结果非常难检查出真正的问题所在。suspend()方法easy发生死锁。调用suspend()的时候,目标线程会停下来,但却仍然持有在这之前获得的锁定。此时,其它不论什么线程都不能訪问锁定的资源,除非被"挂起"的线程恢复执行。对不论什么线程来说,假设它们想恢复目标线程,同一时候又试图使用不论什么一个锁定的资源,就会造成死锁。所以不应该使用suspend(),而应在自己的Thread类中置入一个标志,指出线程应该活动还是挂起。若标志指出线程应该挂起,便用wait()命其进入等待状态。若标志指出线程应当恢复,则用一个notify()又一次启动线程。 

5、集合框架有什么? 

Collection    Map 

List             set                                     HashMap 

ArrayList  linkedList  HashSet  TreeSet 



12、设计4个线程,当中两个线程每次对j添加1,另外两个线程对j每次降低1。写出程序 



public class TestThread 



private int j; 

public synchronized void inc() 



j++; 

System.out.println(Thread.currentThread().getName() + "-inc:" + j); 



public synchronized void dec() 



j--; 

System.out.println(Thread.currentThread().getName() + "-dec:" + j); 



public static void main(String[] args) 



TestThread t=new TestThread(); 

for (int i = 0; i < 2; i++) 



Thread inc=new Thread(new Inc(t)); 

Thread dec=new Thread(new Dec(t)); 

inc.start(); 

dec.start(); 









class Inc implements Runnable 



private TestThread obj; 

public Inc(TestThread obj) 



this.obj=obj; 



public void run() 



// for (int i = 0; i < 100; i++) 

// { 

this.obj.inc(); 

// } 





class Dec implements Runnable 



private TestThread obj; 

public Dec(TestThread obj) 



this.obj=obj; 



public void run() 



// for (int i = 0; i < 100; i++) 

// { 

this.obj.dec(); 

// } 







13、同步和异步有和异同,在什么情况下分别使用他们?举例说明。 

同步:上一段代码没的完毕,下一段必须等到上一段代码完毕后才干够运行。如买票排队 

异步:上一段代码没的完毕,下一段不必等到上一段代码完毕就能够运行。如手机发送短信。 

14、sleep() 和 wait() 有什么差别? 

Sleep是指休眠给定的时间,当这个时间达到之后,线程会再次醒来。 

Wait是等待状态,多长时间不清楚,由还有一个线程将其唤醒。 



15、当一个线程进入一个对象的一个synchronized方法后,其他线程是否可进入此对象的其他方法? 

如仅仅其他方法是同步方法,不能够进入。假设不是能够进入。 

17、输入输出流的理解: 

在java使用流的机制进行数据的传送,从文件到内存是输入流,从内存到文件是输出流,输入流能够通过 read读取,输出流以write或print写入,对于流能够是分为高层流和低层流,低层以一个字节或字符为单位进行处理,高层流以一批数据为单位进行处理。 

FileInputStream(System.in)至InputSteamReader至BufferReader 

OutputSteam(System.out)至printStream 

FileReader至BufferedReader 

FileWriter 至 PrintWriter或bufferWriter 

分类: 

字节(二进制) 

FileInputStream(低层输入流) 

FileOutputStream(低层输出流) 



PrintStream(高层流)  System.out.println() 

字符(一个char) 

FileReader 

FileWriter 



18、请写一个程序的读写,要求用两种方式一种是低层流还有一种是高层流。 



import java.io.FileWriter; 

import java.io.InputStream; 

import java.io.BufferedWriter; 

import java.io.InputStreamReader; 

import java.io.BufferedReader; 

import java.io.FileReader; 





public class Untitled1 { 

    public static void writeFileChar() throws Exception { 

        FileWriter f = new FileWriter("c:\\aa.txt"); 

        InputStream is = System.in; 

        int c = is.read(); 

        while (((char) c) != 'x') { 

            f.write(c); 

            c = is.read(); 

        } 

        f.close(); 

        is.close(); 

    } 



    public static void writeFileString() throws Exception { 

        FileWriter f = new FileWriter("c:\\aa.txt"); 

        BufferedWriter bwr=new BufferedWriter(f); 

        BufferedReader bf = new BufferedReader(new InputStreamReader(System.in)); 

        String c = bf.readLine(); 

        while (!c.equals("stop")) { 

            bwr.write(c+"\r\n"); 

            c = bf.readLine(); 

        } 

        bwr.close(); 

        f.close(); 

        bf.close(); 

    } 

    

    public static void readFileChar() throws Exception { 

       FileReader f = new FileReader("c:\\aa.txt"); 

       int c = f.read(); 

       while (c!=-1) { 

           System.out.print((char)c); 

           c=f.read(); 

       } 

       f.close(); 

   } 



   public static void readFileString() throws Exception { 

       BufferedReader bf = new BufferedReader(new FileReader("c:\\aa.txt")); 

       String c = bf.readLine(); 

       while (c!=null) 

       { 

           System.out.println(c); 

           c=bf.readLine(); 

       } 

       bf.close(); 

   } 





    public static void main(String[] args) throws Exception { 

        readFileString(); 

    } 



19、怎样列出某个文件夹下的全部文件 

Import java.io.File; 

File f=new File("C:\\"); 

        File[] f1=f.listFiles(); 

        for(int i=0;i<f1.length;i++) 

        { 

            if(f1[i].isDirectory()) 

            { 

                System.out.println("dirctory is"+f1[i].getName()); 

            } 

            else 

            { 

                System.out.println("file is"+f1[i].getName()); 

            } 

        } 

    } 

怎样列出某个文件夹下的全部子文件夹 

public static void main(String[] args) throws Exception 



       getFile(new File("C:\\entityBean"),"\t"); 



public static void getFile(File f,String sem) throws Exception 



        System.out.println(sem+f.getName()); 

        File fl[]=f.listFiles(); 

        if(fl.length>=1) 

        { 

            for(int i=0;i<fl.length;i++) 

            { 

                if(fl[i].isDirectory()) 

                { 

                    getFile(fl[i],sem+"\t"); 

                } 

            } 

        } 

    } 

推断一个文件或文件夹是否存在 

  File f=new File("C:\\entityBean"); 

   if(f.exists()) 

   { 

          System.out.println("exist"); 

   } 

    else 

    { 

        System.out.println("not exist"); 

    } 

Socket 

20、用socket通讯写出client和server端的通讯,要求客户发送数据后可以回显同样的数据? 

public class ServerSocket_1 



    public static void main(String[] args) 

            throws Exception 

    { 

        ServerSocket ss = new ServerSocket(4001); 

        Socket s = ss.accept(); 

        BufferedReader br = new BufferedReader(new InputStreamReader(s. 

                getInputStream())); 

        PrintStream ps=new PrintStream(s.getOutputStream()); 

        String temp = br.readLine(); 

        while (true) 

        { 

            System.out.println("client:"+temp); 

            ps.println(temp); 

            if (temp.equals("stop")) 

            { 

                break; 

            } 

            temp = br.readLine(); 

        } 

        br.close(); 

        ps.close(); 

        ss.close(); 

    } 





public class ClientSocket 



  public static void main(String[] args) throws Exception 

  { 

      Socket s = new Socket("localhost", 4001); 

      PrintStream ps = new PrintStream(s.getOutputStream()); 

      BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); 

      BufferedReader br_server = new BufferedReader(new InputStreamReader(s. 

              getInputStream())); 

      String temp = br.readLine(); 

      while (true) 

      { 

          ps.println(temp); 

          temp = br_server.readLine(); 

          System.out.println("server的信息:" + temp); 

          if (temp.equals("stop")) 

          { 

              break; 

          } 

          temp = br.readLine(); 

      } 

      s.close(); 

      br.close(); 

      br_server.close(); 

  } 





23、介绍JAVA中的Collection FrameWork(包含怎样写自己的数据结构)? 

答:Collection FrameWork例如以下: 

Collection 

├List 

│├LinkedList 

│├ArrayList 

│└Vector 

│ └Stack 

└Set 

Map 

├Hashtable 

├HashMap 

└WeakHashMap 

Collection是最主要的集合接口,一个Collection代表一组Object,即Collection的元素(Elements) 

Map提供key到value的映射 



24、请说出你所知道的线程同步的方法 

HashTable中的put,get,remove 

Vector的相关方法。 



jdbc数据訪问技术 

1、JDBC怎样做事务处理? 

Con.setAutoCommit(false) 

Con.commit(); 

Con.rollback(); 

2、写出几个在Jdbc中经常使用的接口 

preparedStatement,callableStatement,statement,Connection,ResultSet 

3、简述你对Statement,PreparedStatement,CallableStatement的理解 

statement用于运行静态 SQL 语句并返回它所生成结果的对象,在运行时确定sql。 







PreparedStatement表示预编译的 SQL 语句的对象。 SQL 语句被预编译而且存储在 PreparedStatement 对象中。然后能够使用此对象高效地多次运行该语句,能够传參数,在得到PreparedStatement对象时确定sql. 

CallableStatement用于运行 SQL 存储过程的接口。假设有输出參数要注冊说明是输出參数。 



4、Java中訪问数据库的步骤? 

1连接Oracle数据库 

Class.forName(“oracle.jdbc.driver.OracleDriver”); 

Connection con=DriverManager.openConnection(“jdbc:oracle:thin:@localhost:1521:DataBase ”,” UserName”,”Password ”) 

利用JDBC检索出表中的数据 

Class.forName(“”); 

Connection con=DriverManager.openConnection(“ ”,” ”,” ”) 

preparedStatment  ps=Con.preparedStatment(“select * from [table]”); 

ResultSet rs=ps.executeQuery(); 

While(rs.next) 



Rs.getString(1) 或rs.getString(“字段名”) 



5、JDBC中的核心类及其作用是什么? 

DriverManager 

Class.forName(); 

DriverManager.getConnection(“”,”sa”,””) 

Connection   

PreparedStatement(Statement) 

ResultSet  rs=executeQuery()  dql 

While(rs.next()) 







executeUpdate()  dml ddl 

6、运行存储过程用那一个类,怎样操作输出參数?(操作)

CallableStatement c=con. prepareCall ("{call getCustomerName(?,?)}"); 

c.setString(1,"1"); 

c.registerOutParameter(2,java.sql.Types.VARCHAR); 

c.execute(); 

c.getString(2); 

8、可能会让你写一段Jdbc连Oracle的程序. 

Class.forName("oracle.jdbc.driver.OracleDriver"); 

        Connection con=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:accp","system","system"); 

9、Class.forName的作用?为什么要用? 

注冊一个数据库驱动,将驱动载入到当前的JVM中。 

10、Jdo是什么?

JDO是Java对象持久化的新的规范,为java data object的简称,也是一个用于存取某种数据仓库中的对象的标准化API。JDO提供了透明的对象存储,因此对开发者来说,存储数据对象全然不须要额外的代码(如JDBC API的使用)。这些繁琐的例行工作已经转移到JDO产品提供商身上,使开发者解脱出来,从而集中时间和精力在业务逻辑上。另外,JDO非常灵活,由于它能够在不论什么数据底层上执行。JDBC仅仅是面向关系数据库(RDBMS)JDO更通用,提供到不论什么数据底层的存储功能,比方关系数据库、文件、XML以及对象数据库(ODBMS)等等,使得应用可移植性更强。(o/rMapping工具
集合处理) 

11、在ORACLE大数据量下的分页解决方法。一般用截取ID方法,还有是三层嵌套方法

create or replace package myPack 

is 

type c_type is ref cursor; 

procedure getPage(v_sql varchar2,pageSize number,pageIndex number,c out c_type); 

end; 



create or replace  package  body myPack 

is 

procedure getPage(v_sql varchar2,pageSize number,pageIndex number,c out c_type) 

  is 

    pageTotal int:=0; 

    pageFirstRow int:=0; 

    pageLastRow int:=0; 

    rowTotal int:=0; 

  begin 

    execute immediate 'select count(*)  from ('||v_sql||')' into rowTotal; 

    pageTotal:=ceil(rowTotal/pageSize); 

    if(pageIndex<1) then 

           raise_application_error(-20001,'页数不能小于1'); 

    end if; 

    if(pageIndex>pageTotal) then 

           raise_application_error(-20001,'页数太大,不能读取'); 

    end if; 

    pageFirstRow:=(pageIndex-1)*pageIndex+1; 

    pageLastRow:=pageFirstRow+pageSize; 

    open c for ' select * from '||v_sql||' where rownum<'|| 

         pageLastRow||'minus select * from '||v_sql 

         ||' where rownum<'||pageFirstRow;    

  end; 

end; 

Web编程Jsp&Servlet技术 

1、简单说说tomcat的配置? 

JAVA_HOME=JDK的根文件夹 

CATALINA_HOME=tomcat的根文件夹 



CATALINA-HOME\conf\server.xml:能够配置tomcat的port,能够配置tomcat中下连接池。 

CATALINA-HOME\common\lib:存放公用的类包 



在My eclipse中怎样配置tomcat 

在eclipse中,选择windows->preference->MyEclipse->ApplicationServer->Tomcat 

选择Tomcat 的安装文件夹,并选择TomCat所需的jdk,选择enable,确定就可以。 

2、JSP中动态INCLUDE与静态INCLUDE的差别? 

jsp:include:在执行时调用还有一个页面,变量是能够反复的。 

<%@include file=””%>:在转译时合在一起,会成为同一个类,变量不能够反复。 

3、forward和redirect的差别? 

forward: 转发,在下一个页面中,request保留上一个页面中的request的全部值 



redirect: 跳转,不传递request对象。 

4、Servlet的体系结构是什么? 

Servlet 

GenericServlet 

HttpServlet 

自己定义 

5、怎样实现一个自己定义的servlet? 

extends HttpServlet 并覆盖doPost或doGet方法 



在web.xml中进行部署 

6、Servlet的生命周期是什么? 

Init 

多次运行doGet或doPost  

destroy 

7、jsp就是一个servlet是否正确? 

对 

8、请罗列jsp中的脚本、指令及动作? 

脚本 

<%%>  <%=%>  <%!%> <%----%> 

指令 

<%@page contentType=”text/html;charset=utf-8” language=”java” import=””%> 

<%@include file=””%> 

<%@taglib uri=”” prefix=””%> 

动作: 

<jsp:useBean class=”” id=”” scope=””>  在scope中假设没有实例化一个对象,假设有直接用曾经的。 

<jsp:getProperty name=”” property=””>  向一个bean中设置属性值 

<jsp:forward >  jsp页的转发 

<jsp:include page=””>  导入一个jsp页面 

9、JSP的内置对象及方法 

Request  request表示HttpServletRequest对象。取client表单域信息及cookie, header, 和session 

response response表示HttpServletResponse对象,对client的响应返回文本、写cookies。 

out out 向client打印html文本. 

pageContext :当前jsp页面的上下文环境,能够得到session、request、application等内置对象,在自己定义标签中使用的非常多。 

session session表示一个请求的javax.servlet.http.HttpSession对象。Session一个用户多个页面共享同一变量。 

application applicaton 表示一个javax.servle.ServletContext对象。存放容器级的变量。 

config config表示一个javax.servlet.ServletConfig对象。该对象用于存取servlet实例的初始化參数。 

page page表示从该页面产生的一个servlet实例 

exception:异常,当iserrorpage=true 

10、说出在JSP页面里是怎么分页的? 

页面须要保存下面參数:(数据库的分页及比較) 

总行数:依据sql语句得到总行数 

每页显示行数:设定值 

当前页数:请求參数 

页面依据当前页数和每页行数计算出当前页第一行行数,定位结果集到此行,对结果集取出每页显示行数的行就可以。 



数据库: 

Sqlserver: 

SELECT TOP 页大小 * 

FROM TestTable 



WHERE (ID NOT IN 

        (SELECT TOP 页大小*(页数-1) id 

         FROM 表 

         ORDER BY id)) 

ORDER BY ID 





--pageSize=5  页大小 

--pageIndex=2 所要的页 

--假设有主键能够,没以及键不行 

select top 5 * 

from aa where a1 not in 

(select top 5 a1 from aa order by a1) 

order by a1; 



oracle: 

select * from '||v_sql||' where rownum<'|| 

         pageLastRow||'minus select * from '||v_sql 

         ||' where rownum<'||pageFirstRow; 





Session 

先取出数据中的全部信息封装到对象并保存在session中,转发到jsp页面做例如以下处理。 

<table border="1"> 

    <tr> 

      <td>a1</td> 

      <td>a2</td> 

    </tr> 

<% 

     List l=(List)session.getAttribute("as"); 

     //一页显示多少行 

     int pageSize=3; 

     //总页数 

     int pageCount=0; 

     int currentPage=1; 

     if(l!=null && l.size()>0) 

     { 

     pageCount=(l.size()/pageSize)+(l.size()%pageSize==0?0:1); 

     if(request.getParameter("page")!=null) 

     { 

       currentPage=Integer.parseInt(request.getParameter("page")); 

     } 

     if(currentPage<1) 

     { 

       currentPage=1; 

     } 

     if(currentPage>pageCount) 

     { 

       currentPage=pageCount; 

     } 

     for (int i = (currentPage-1)*pageSize; i <(currentPage-1)*pageSize+pageSize; i++) 

     { 

       if(i>=l.size()) 

       { 

         break; 

       } 

       Aa aa=(Aa)l.get(i); 

       %> 

        <tr> 

      <td><%=aa.getA1()%></td> 

      <td><%=aa.getA2()%></td> 

    </tr> 

       <% 

       } 

     } 

%> 

<tr> 

  <td colspan="2"> 

    <% 

    if(currentPage!=1) 

    { 

    %> 

    <a href="page.jsp?page=1">首页</a>&nbsp;&nbsp; 

    <a href="page.jsp?page=<%=currentPage-1%>">上一页</a>&nbsp;&nbsp; 

    <% 

    } 

    if(currentPage!=pageCount) 

    { 

    %> 

    <a href="page.jsp?page=<%=currentPage+1%>">下一页</a>&nbsp;&nbsp; 

    <a href="page.jsp?page=<%=pageCount%>">最后一页</a>&nbsp;&nbsp; 

    <% 

    } 

    %> 

  </td> 

</tr> 

  </table> 



11、include的两种实现方式的差别? 

<@include file>:在将jsp生成servlet类前将两个文件和在一起,生成一个java类,一起执行的。所以是一家子,其中的变量名不能重名。 

<jsp:include page>:是两个类,是一个调用关系,在执行时动态的调用,不是一家子,能够反复变量。 

12、jsp页面中两种跳转方式各自是什么?有什么差别? 

转发: 保留上次的request 

<jsp:forward> 

actionMapping.findForWard(“”); 

pageContext.forward(); 

request.getRequestDispacher(“a.jsp”).forward(request,response) 

跳转:不保留上次的request 

Response.setRedirect(“”) 

13、描写叙述JSP和Servlet的差别、共同点、各自应用的范围 

Jsp主要在于页面的显示动态生成页面,能够与html标记一起使用,其还是要生成为一个servlet。 

Servlet:主要是控制的处理,如调用业务层,跳转不同的jsp页面。 

Mvc: 

Jsp:v 

Servlet:c 

14、在JSP中怎样读取client的请求,怎样确定某个Jsp文件的真实路径? 

Request.getparameter(“”) 

<%=application.getRealPath("aa.jsp") %> 

15、描写叙述Cookie和Session的作用,差别和各自的应用范围,Session工作原理。 

Cookie:主要用在保存client,其值在client与服务端之间传送,不安全,存储的数据量有限。 

Session:保存在服务端,每个session在服务端有一个sessionID作一个标识。存储的数据量大,安全性高。占用服务端的内存资源。 

16、说明Jsp中errorPage的作用,应用范围。 

正常页面中 

%@page erropage=”error.jsp”% 

错误页面 

<%@page iserrorpage=”true”%> 

有一内置对象:exception 

17、介绍在Jsp中怎样使用JavaBeans 

<jsp:useBean class=”” id=”” scope=””/> 

<% 

New 类(); 

%> 

19、简介JSP的标记库 

做一个标记处理类 extends TagSupport 

通过tld说明标记处理的类的前缀及后缀 

在web.xml中说明tld文件 

<taglib> 

<taglib-uri> 

<taglib-location> 

<taglib> 

在jsp页面是引用tld<%@taglib uri=”” prefix=””%> 

20、Servlet中的核心类有那些,各有什么特点? 

ServletContext:容器,放置全局变量 

setAtribute() 

getAttribute() 

ServletConfig:一个servlet的配置 

getInitParameter(”名称”) 

HttpServletRequest:封装的全部的请求 

getParameterValue(”名称”) 

getParameterValues(”称”) 

getSession(); 

getAttribute(” 名称”); 

getRequestDispatch(”a.jsp”).forward(request,response) 

HttpServletResponse:响应 

getOut(); 

sendRedirect(””)

HttpSession:一个用户多个页面共享同一变量 

setAttribute(””,””) 

21、Servlet中重要的包有那些,有什么差别? 

javax.servlet.*;javax.servlet.http.*; 

22、说出Servlet的生命周期,并说出Servlet和CGI的差别? 

Servlet被server实例化后,容器执行其init方法,请求到达时执行其service方法,service方法自己主动派遣执行与请求相应的doXXX方法(doGet,doPost)等,当server决定将实例销毁的时候调用其destroy方法。 



与cgi的差别在于servlet处理server进程中,它通过多线程方式执行其service方法,一个实例能够服务于多个请求,而且事实上例一般不会销毁,而CGI对每一个请求都产生新的进程,服务完毕后就销毁,所以效率上低于servlet。 

23、什么情况下调用doGet()和doPost()? 

Jsp页面中的form标签里的method属性为get时调用doGet(),为post时调用doPost()。 

25、怎样现实servlet的单线程模式 

在doGet及doPost方法前增加synchoronized 

JSP: 

<%@ page isThreadSafe="true"%> 

27、Request对象的主要方法: 

setAttribute(String name,Object):设置名字为name的request的參数值 

getAttribute(String name):返回由name指定的属性值 

getAttributeNames():返回request对象全部属性的名字集合,结果是一个枚举的实例 

getCookies():返回client的全部Cookie对象,结果是一个Cookie数组 

getCharacterEncoding():返回请求中的字符编码方式 

getContentLength():返回请求的Body的长度 

实例 

getInputStream():返回请求的输入流,用于获得请求中的数据 

getMethod():获得client向server端传送数据的方法 

getParameter(String name):获得client传送给server端的有name指定的參数值 

getParameterNames():获得client传送给server端的全部參数的名字,结果是一个枚举的实例 

getParameterValues(String name):获得有name指定的參数的全部值 

getProtocol():获取client向server端传送数据所根据的协议名称 

getQueryString():获得查询字符串 

getRequestURI():获取发出请求字符串的client地址 

getRemoteAddr():获取client的IP地址 

getRemoteHost():获取client的名字 

getSession([Boolean create]):返回和请求相关Session 

getServerName():获取server的名字 

getServletPath():获取client所请求的脚本文件的路径 

getServerPort():获取server的port号 

removeAttribute(String name):删除请求中的一个属性 

28、我们在web应用开发过程中常常遇到输出某种编码的字符,如iso8859-1等,怎样输出一个某种编码的字符串? 

  Public String translate (String str) { 

    String tempStr = ""; 

    try { 

      tempStr = new String(str.getBytes("ISO-8859-1"), "GBK"); 

      tempStr = tempStr.trim(); 

    } 

    catch (Exception e) { 

      System.err.println(e.getMessage()); 

    } 

    return tempStr; 

  } 



30、Servlet运行时一般实现哪几个方法? 

public void init(ServletConfig config) 

public ServletConfig getServletConfig() 

public String getServletInfo() 

public void service(ServletRequest request,ServletResponse response) 

public void destroy() 

5 Hibernate持久层技术 

1、在myeclipse增加hibernate环境的全过程是什么? 

Db-browers增加配置连接 

新建project 

增加hibernate环境,指定*.hbm.xml及HibernateSessionFactory文件所在的位置 

2、hibernate的核心配置文件是什么及其作用? 

Hibernate.cfg.xml:数据库连接、指定相关的映射文件 

*.hbm.xml:详细的o/r mapping说明 

3、hibernate的核心类是什么,它们的相互关系是什么?重要的方法是什么? 

Configuration 

SessionFactory 

Session例如以下方法 

Save 

load 

Update 

Delete 

    Query q=CreateQuery(“from Customer where customerName=:customerName”) 

beginTransaction 

close 

Transaction 

Commit()

4、关联: 

one-to-many 

inverse:主控方,外键的关系有谁控制 

inverse=false 是主控方,外键是由它控制的

inverse=true 是被控方,外键与它没关系 

要想实现主控方的控制必须将被控方作为主控方的属性 

cascade:级联 

主表增从表增 

主表修从表修 

主表删从表删 

lazy:延迟 

lazy=false:一下将全部的内容取出,不延时(经常使用) 

lazy=true:取出部分内容,其余内容动态去取 

通过get能够取出对方的全部内容

5、hibernate中的one-to-many或many-to-one中经常使用的方式是什么? 

主控方在many这边,不及连删除 

6、Criteria 的作用? 

Criteria c=session.createCriteria(Customer.class); 

//设置条件 

c.add(Expression.ge(“字段名”,”值对象”)) 

ge:>= 

gt:> 

le:<= 

lt:< 

eq:= 

//排序 

c.addOrder(Order.asc(“字段名”)) 

//分页 

c.setFirstResult(1)//从第2行開始提取 

c.setMaxResults(5)//返回5行 

7、DetachedCriteria的作用? 

产生时不须要session 

DetachedCriteria dc= DetachedCriteria.forClass(Customer.class) 

Criteria c=Dc.getExecutableCriteria(session) 

8、Query 

1 个或多个属性查询: 

Query query=session.createQuery(”select customername,customerid from Customer”) 

List l=query.list(); 

For(int i=0;i<l.size();i++) 



Obejct[] object=(Object[])l.get(i); 

Object[0]  object[1] 





分组: "select count(*),productname from Product group by productname order by productname" 

取值与属性一样 

配置的查询,在*.hbm.xml中 

<query name="sql"> 

    <![CDATA[ 

    from Product where productid=:productid 

    ]]> 

</query> 

Query query=session.getNamedQuery(sql); 

联接1 

"from Customer as customer join fetch customer.buySet":将多的放到buySet属性中,得出的结是Customer有一个,Buy有多个 

联接2 

"from Customer as customer join customer.buySet":得出的对象,customer与buy是1对1 

子查询: 

"from Customer as customer where (select count(*) from customer.buySet)>1" 

9、继承关系的实现 

1、两个表,子类反复父类的属性。 

2、一个表,子类父类共用一个表 

  <class name="Users" table="users" discriminator-value="Users"> 

<discriminator column="DISCRIMINATOR_USERTYPE" type="string"/> 

<subclass name="admin" discriminator-value="admin"> 

        <property name="adminRemark" column="admin_remark" type="string" /> 

      </subclass> 

  </class> 

3、两个表,子类引用父类的主键,享用公共的字段或属性。 

    <class name="Users" table="users"> 

        <id name="userid" column="USERID" type="string"> 

            <generator class="assigned"/> 

        </id> 

        <property name="pwd" column="pwd" type="string" /> 

<joined-subclass name="Guest" table="guest"> 

<key column="USERID"/> 

        <property name="guestRemark" column="guest_remark" type="string" /> 

        </joined-subclass> 

</class> 

批量删除 

Query query=session.createQuery("update"或"delete"); 

query.executeUpdate(); 



10、tomcat连接池:在容器中预先产生了n个连接实例,client不用又一次实例化,能够直接取。 

6.1、在tomcat-5.0\conf\server.xml中</host>前面增加例如以下内容 

<Context path="/app1" docBase="app1" debug="0"    reloadable="true" crossContext="true">   

<Resource name="jdbc/sa" auth="Container" type="javax.sql.DataSource"/>   

           <ResourceParams name="jdbc/sa">

     <parameter>

     <name>factory</name>

     <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>

     </parameter>   

<parameter>

            <name>driverClassName</name>

       <value>com.microsoft.jdbc.sqlserver.SQLServerDriver</value>

     </parameter>

<parameter>

       <name>url</name>

       <value>jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=jspdev;SelectMethod=cursor</value>   

</parameter>

     <parameter>     

<name>username</name>

               <value>sa</value>   

</parameter>

     <parameter>     

<name>password</name>     

<value></value>

     </parameter>

     <parameter>     

<name>maxActive</name>     

        <value>20</value>   

</parameter> 

     <parameter>

       <name>maxIdle</name>     

<value>10</value>   

</parameter>   

<parameter>

       <name>maxWait</name>     

<value>-1</value>   

</parameter>

     </ResourceParams>     

</Context> 

6.2、将sql-server包复制到C:\tomcat-5\common\lib 

6.3、jdbc測试代码 

Context initCtx = new InitialContext(); 

   Context envCtx = (Context)initCtx.lookup("java:comp/env"); 

ds = (DataSource)envCtx.lookup("jdbc/sa"); 

Connection conn = ds.getConnection(); 

6.4、hibernate通过连接池实现连接 

<session-factory name="foo"> 

<property name="connection.datasource">java:comp/env/jdbc/sa</property>  <!--指定tomcat连接池--> 

<property name="show_sql">true</property> <!--是否显示sql--> 

<property name="dialect">org.hibernate.dialect.SQLServerDialect</property> <!--hibernate的驱动管理器--> 

<mapping resource="com/accp/t15/Customer.hbm.xml"/> 

</session-factory> 



11、对象的三大状态 

*(transient) 

与session无关 

持久(persistent) 

由session来管理 

在持久状态中通过get方法取出对方 

游离(detached) 

被session抛弃

12、hibernate常见优化策略 

用最新版本号的hibernate 

制定合理的缓存策略 

採用合理的session管理机制 

尽量使用延迟载入 

many 

大文本、大文件 

设定合理的批处理參数(batch-size) 

如有可能,选用uuid作为主键生成器 

如有可能,选用基于version的乐观锁替代悲观锁 

开发过程中,打开hibernate的SQl日志输出(hibernate.show_sql=true),通过观察hibernate生成的sql语句进一步了解其实现原理,从而指其实更好的实现策略。


iBatis持久层技术 



用ibatis的原因: 

仅仅对开发团队提供几条Select SQL(或存储过程)以获取所需数据,详细的表结构不予公开。 

开发规范中要求,全部牵涉到业务逻辑部分的数据库操作,必须在数据库层由存储过程实现 

系统数据处理量巨大,性能要求极为苛刻,这往往意味着我们必须通过经过高度优化的SQL语句 

(或存储过程)才干达到系统性能设计指标。 

jdbc、hibernate、ibatis的差别 

jdbc:手动 

手动写sql 

delete、insert、update要将对象的值一个一个取出传到sql中,不能直接传入一个对象。 

select:返回的是一个resultset,要从ResultSet中一行一行、一个字段一个字段的取出,然后封装到一个对象中,不直接返回一个对象。 

ibatis的特点:半自己主动化 

sql要手动写 

delete、insert、update:直接传入一个对象 

select:直接返回一个对象

hibernate:全自己主动 

不写sql,自己主动封装 

delete、insert、update:直接传入一个对象 

select:直接返回一个对象 

ibatis的核心配置文件: 

sqlmapclient.xml:数据库连接及相关o/rMapping的映射文件(hibernate.cfg.xml) 

sqlmapBuy.xml:详细的o/rmapping映射(*.hbm.xml)

四大标记: 

select 

update 

delete 

insert 

procedure 

ibatis的核心类: 

SqlMapClientBuilder:载入配置文件,返回一个会话。 

SqlMapClient:详细的会话 

List list=queryForList("标签名",object); 

Object obj=queryForObject("标签名",object); 

delete("标签名",object) 

update("标签名",object) 

insert("标签名",object) 

project的使用: 

将ibatisfactory复制到project文件夹下 

将ms的3个包及ibatis的三个包复制到/WEB-INF/lib下 

改动ibatisfactory中的abatorConfig.xml文件 

进入ibatisfactory文件夹执行java -jar  abator.jar abatorConfig.xml true 

将sql标记、select、update、insert、delete的副本删除 

spring&ibatis: 

dataSource 

sqlMapClient:SqlMapClientFactoryBean 

configLocation 

classpath:sqlMapClient.xml 

/WEB-INF/sqlMapClient.xml 

dataSource 

transactionManager:DataSourceTransactionManager 

dataSource 

customerDao extends SqlMapClientDaoSupport 

sqlMapClient 

buyDao 

sqlMapClient 

Facade 

buyDao 

customerDao 

abstractProxy:TransactionProxyFactoryBean 

transactionManager 

transactionAttributes 

facadeProxy 

target:façade 

7 Structs界面控制层技术 

1、请说出struts框架的几大组件? 

1、MVC 

2、标签库 

3、校验框架 

4、国际化 

5、tiles 

3、struts的核心类有那些,在MVC模式中其相应的关系是什么? 



ActionServlet 

RequestProcessor 

Action 

actionMapping(struts-config.xml) 

actionFormard 



ActionForm 

Jsp 



Dao 

Manager(facade) 

4、Struts的处理请求的全过程是什么? 

url-> ActionServlet(process)-> RequestProcessor(process)->实例化form ->填充form值->进行校验->实例化action->调用execute 

5、在struts中怎样通过一个url找到一个action,它的核心配置文件是什么? 

配置文件是struts-config.xml 

6、为什么使用MVC,其主要目的是什么? 

让v与M强制解耦,提高可重用性(旅馆的服务员(C)) 

7、对于MVC在action中相应有类有几种,各有什么作用? 

 Action: 

1) 主要的 

 DispatchAction: 

2) 存在多个方法,依据页面传入的表单域的值调用不同的方法,表单域的名称在<action param=””/>标记中进行配置 

 LookupDispatchAction 

3) 多个button用同一个action的不同方法。实现getMap方法,说明每个button在*.properties中的键名及键值,在struts-config.xml通过parameter说明button的名称,button的值相应*.properties的值,通过值找键名,通过键名找Map中的键名找到值就是相应的方法。 

 MappingDispatchAction:未知 

 forwordAction:直接跳转到不同页面不运行逻辑(???) 

 类所在的包:org.apache.struts.actions.ForwardAction 

8、struts的标记有几类,请列举并说明其作用?

Bean: 

<bean:define scope=”” name=”” property=”” id=””/> 

<bean:write  name=”customer” property=”customerName”/>

<bean:message key=””/>国际化 

Logic: 

<logic:iteator>  //将集合的内容取出 

<logic:present> // 

<logic:equals> // 

Html: 

<html:file>上传文件 

<html:select property=”sex”> 

<html:options collection=”” property=”” labelProperty=””/> 

</html:select> 

9、怎样在struts中配置数据源在,什么文件?用什么标签?怎样取出DataSource?

Struts-config.xml 



<data-sources> 

  <data-source key="data" type="org.apache.commons.dbcp.BasicDataSource"> 

  <set-property property="driverClassName"   value="com.microsoft.jdbc.sqlserver.SQLServerDriver" /> 

  <set-property property="url"     value="jdbc:microsoft:sqlserver://localhost:1433;databaseName=t23" /> 

  <set-property property="username" value="sa" /> 

   <set-property property="password" value="" />  

</data-source> 

</data-sources> 



DataSource ds=(DataSource)this.getServlet().getServletContext().getAttribute("data"); 

Connection con=ds.getConnection(); 

10、怎样在jbuilder中开发struts?

 project 

 Web模型(选中struts1.2.8,会自加在web –inf中生成tld及struts-config.xml,并载入相关的类包) 

 建一个ActionForm 

 建一个Action 

 改动struts-config.xml文件 

11、怎样实现struts的validator框架?

 手动: 

 public class myForm extends ActionForm

 { 

 public ActionErrors validate() 

 { 

actionErrors.add(ActionErrors.GLOBAL_MESSAGE,new ActionMessage("properties中的键名")); 

 } 

 }

 struts-config.xml中改动action的标签validate=true 

 input="错误页面" 

 假设validate方法中的ActionErrors不为空且size>0时 

 会回到input页面。 

 自己主动 

 public class myForm extends ValidateForm

 { 

 不能覆盖validate方法。 

 //public void validate() 

 //{ 



 //} 

 }

 在struts-config.xml文件里增加插件 

 <plug-in className="org.apache.struts.validator.ValidatorPlugIn"> 

     <set-property property="pathnames" value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml" /> 

   </plug-in> 

 改动validation.xml中的内容 

 errors.required={0} is required. 

 errors.minlength={0} can not be less than {1} characters. 



 <formset> 

 <form name="loginForm"> 

 <field property="userName" depends="required"> 

 <arg0 key="userName" /> 

 </field> 

 <field property="pwd" depends="required,minlength"> 

 <arg0 key="pwd" /> 

 <arg1 key="${var:minlength}" resource="false"/> 

 <var> 

 <var-name>minlength</var-name> 

 <var-value>6</var-value> 

 </var> 

 </field> 

 </form> 

 </formset> 

 struts-config.xml中改动action的标签validate=true 

 input="/错误页面"

13、怎样实现国际化? 

国际化:不用改动代码,就适用于不同的语言国家 

本地化:假设要适应一个国家,要改动源码 

实现过程: 

在struts-config.xml中用例如以下标签说明资源文件名称,注意其仅仅是文件名称,没有语言_国家 

<message-resources parameter="struts.ApplicationResources" /> 

在资源文件相应的文件夹struts中增加适应不同语言、国家的properties文件 

ApplicationResources_zh_CN.properties 中国 

ApplicationResources_en_US.properties us 

假设不是英语要转码 

native2ascii -encoding gb2312 源 ApplicationResources_zh_CN.properties 

在jsp页面中用 

<bean:message key=""/>取出信息 

8 JSF界面控制层技术 

1、Jsf中的核心类用那些?有什么作用?    

核心类 

FacesServlet 

LiftCycle    FacesContext  

        

2、Jsf中的LiftCycle六大生命周期是什么? 

恢复视图->应用请求值->校验->更新模型->调用应用程序->呈现响应 

3、怎样管量web层中的Bean,用什么标签。怎样通过jsp页面与Bean绑定在一起进行处理? 

<managed-bean> 

    <managed-bean-name>checkNumber</managed-bean-name> 

   <managed-bean-class>jsf1.CheckNumber</managed-bean-class> 

    <managed-bean-scope>session</managed-bean-scope> 

</managed-bean> 

4、Jsf中导航的标签是什么? 

<navigation-rule> 

    <from-view-id>/main.jsp</from-view-id> 

    <navigation-case> 

     <from-outcome>success</from-outcome> 

        <to-view-id>/result.jsp</to-view-id> 

    </navigation-case> 

</navigation-rule> 

5、jsf中用户界面组件模型有几类,各代表什么? 

UI组件、事件监听、显示、类型转换、验证 

6、表格处理及取值 

import javax.faces.model.DataModel; 

import javax.faces.model.ListDataModel; 

DataModel:代表一个表格,其能够从client传上来。 

实例化: 

DataModel dm=new ListDataModel(); 

将一个list值放入到DataModel中.

dm.setWrappedData(list) 

将client当前行取出 

(LogsVO) dm.getRowData() 

对于多条的查询及增删改在模型中增加了例如以下属性:

模型的名称是bean,其下的属性是 

DataModel dm:代表返有的行数据 

VO vo:代表一行数据。 

取一行: 

vo=(VO) dm.getRowData(); 

通#{bean.vo.属性名},假设改动相应信息自己主动改动。 

添加一行: 

this.vo=new VO(); 

通#{bean.vo.属性名},显示肯定无值,但客户输入值提交后会将值勤写入 

7、jsf的标签库有哪些? 

核心:f 

校验 

<f:validateDoubleRange> 

<f:validateLength> 

转化 

<f:convertDateTime pattern="yyyy-MM-dd"/>

<f:convertNumber type="currency"/> 

选择框: 

<f:selectItem/> 

<f:selectItems/> 



html:h 

选择控件: 

<h:selectOneRadio>:一个string 

<h:selectManyCheckBox>:一个String数组 

<h:selectOneMenu>:组合框架选择一个

<h:selectManyMenu>:组合框架选择多个 

<h:selectOneList>:下拉列表选择一个

<h:selectManyList>:下拉列表选择多个 

表格: 

<h:dataTable value="集合" var="集合中的一个"> 

<h:column> 

<!--头--> 

<f:facet name=”header”> 

<h:outputText > 

</f:facet>

<!--详细的行值--> 

<h:outputText value=""/> 

<h:column>

</h:dataTable> 

9 Spring 应用框架技术 

1、Spring和Struts的差别? strusts:是一种基于MVC模式的一个web层的处理。 

Spring:提供了通用的服务,ioc/di aop,关心的不只web层,应当j2ee总体的一个服务,能够非常easy融合不同的技术struts hibernate ibatis ejb remote springJDBC springMVC 

2、什么是aop,aop的作用是什么? 

Oop:纵向的业务 

Aop:oop的一个横向的服务,是对oop进一步的补充,提供安全、事务、日志等的集中式处理,相关的装备before、around、after exception 

3、aop中的关键名词有些那些,相互关系是什么? 

拦截器: 代理 

装备(advice) 

目标对象 

关切点:条件 

连接点:方法、属性 

4、依赖注入的方式有几种,各是什么? 

Setter 

Interface 

constructor 

5、spring中的核心类有那些,各有什么作用? 

BeanFactory:产生一个新的实例,能够实现单例模式 

BeanWrapper:提供统一的get及set方法 

ApplicationContext:提供框架的实现,包含BeanFactory的全部功能 

6、ApplicationContext的作用 

beanFactory 

国际化(getMesage) 

资源管理:能够直接读取一个文件的内容(getResource) 

增加web框架中(增加一个servlet或监听器) 

事件处理 

7、怎样实现资源管理 

使用 

applicationContext.getResource(“classpath:文件名称”):在src根文件夹下,在类路径下 

applicationContext.getResource(“classpath:/chap01/文件名称”): 以src根文件夹下的基准往下走。 

applicationContext.getResource(“file:c:/a.properties”):在系统文件文件夹下。 

8、怎样实现增加web框架中 

在web.xml中增加例如以下同容,在启动webserver时载入/WEB-INF/applicationContext.xml中的内容。 

<servlet> 

<servlet-name>context</servlet-name> 

<servlet-class> 

org.springframework.web.context.ContextLoaderServlet 

</servlet-class> 

<load-on-startup>1</load-on-startup> 

</servlet> 

通过例如以下类得到ApplicationContext实例 

WebApplicationContextUtils.getWebApplicationContext 

9、怎样实现事件处理 

事件 

Extends ApplicationEvent 

监听器 

Implements ApplicationListener 

事件源 

Implements ApplicationContextAware 

在applicationContext.xml中配置事件源、监听器 

先得到事件源,调用事件源的方法,通知监听器。 

10、spring的ioc及di代表什么意思? 

Ioc:程序在执行过程中,依据配置文件动态载入所依赖的配置类 

、怎样在spring中实现国际化? 

 在applicationContext.xml载入一个bean 

<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource"> 

<property name="basename"> 

<value>message</value> 

</property> 

</bean> 

 在src文件夹下建多个properties文件 

 对于非英文的要用native2ascii -encoding gb2312 源  目转化文件相关内容 

 其命名格式是message_语言_国家。 

 页面中的中显示提示信息,键名取键值。 

 当给定国家,系统会自己主动载入相应的国家的properties信息。 

 通过applictionContext.getMessage(“键名”,”參数”,”区域”)取出相关的信息。 



12、spring的配置的主要标签是什么?有什么作用? 

<beans> 

<bean id=”” class=”” init=”” destroy=”” singleton=””> 

<property name=””> 

<value></value> 

</property> 

<property name=””> 

<ref local></ref> 

</property> 

</bean> 

</beans> 

13、spring与ejb2.0的事务管理比較的优缺点? 

測试: 

Spring:pojo 

Ejb:二个接口一个类,一堆配置文件 

事务类型 

Spring:jdbc jta  hibernate 

Ejb:jta 

成本 

   Spring:普通容器(tomcat jboss) 

   Ejb:weblogic jboss 

开发的周期: 

Spring远比ejb快. 

14、spring的jdbc与传统的jdbc有什么差别,其核心类有那些? 

Spring的jdbc:节省代码,无论连接(Connection),无论事务、无论异常、无论关闭(con.close() ps.close ) 



JdbcTemplate(dataSource):增、删、改、查 

TransactionTemplate(transactionManager):进行事务处理 

15、在spring中有几种事务管理,各自是什么? 

代码管理的事务处理 

TransactonTemplate的execute方法中的内部类TransactionCallback中的doInTransaction方法中使用。 

public void make() 

{

TransactionTemplate jtm=new TransactionTemplate(this.getTransactionManager()); 

jtm.execute(new myClass1()); 



public class myClass1 implements TransactionCallback 





public Object doInTransaction(TransactionStatus trans) 



JdbcTemplate jdbc=new JdbcTemplate(dataSource); 

jdbc.execute("insert into customer(customerName) values('b')"); 

jdbc.execute("insert into customer(customerName) values('b')"); 

return null; 

}



容器管理的事务处理 

16、在spring中怎样配代码的事务管理? 

Datasouce 

transactionManager 

userDao要注入 

Datasouce 

transactionManager 

通过例如以下类实现 

TransactionTemplate 

JdbcTemplate 

17、在spring中怎样配容器的事务管理,相关的类有那些? 

Datasouce 

transactionManager 

userDao要注入 

Datasouce 

Proxy代理 

Target:userDao:代理对象(目标对象) 

transactionAttributes(那些方法须要事务处理) 

transactionManager(事务处理服务) 

18、假设spring与hibernate结合在一起能够不须要hibernate.cfg.xml文件是否正确? 

不须要 

19、spring+hibernate的配置文件里的主要类有那些?怎样配置? 

在myeclipse中先增加spring环境再增加hibernate环境。 

假设spring与hibernate结合在一起能够不须要hibernate.cfg.xml文件是否正确? 

spring+hibernate的配置文件里的主要类有那些?怎样配置? 

dataSource 

sessionFactory:hibernate.cfg.xml 

transactionManager 

userDao (extends HibernateDaoSupport)  

sessionFactory 

facade 

proxy 

sessionFactory 

transactionManager 

facade 



20、spring+hibernate的代码实现中,对于实现类一定继承于一个类是那一个,它有什么作用。 

extends HibernateDaoSupport,能够节省代码。 

21、怎样配置spring+struts? 

 在struts-config.xml增加一个插件,通过它载入applicationContext.xml 

 在struts-config.xml改动action-mapping标记,详细action交给了DelegateActionProxy 

 通过DelegateActionProxy进入一spring的环境。 

 在spring的applicationContext.xml增加<bean name="/login" class="" singleton="false"/> 

22、怎样在web环境中配置applicationContext.xml文件? 

<listener> 

<listener-class> 

org.springframework.web.context.ContextLoaderListener 

</listener-class> 

</listener> 

或: 

<servlet> 

<servlet-name>context</servlet-name> 

<servlet-class> 

org.springframework.web.context.ContextLoaderServlet 

</servlet-class> 

<load-on-startup>1</load-on-startup> 

</servlet> 

通过例如以下方法取出applicationContext实例: 

ApplicationContext ac=WebApplicationContextUtils.getWebApplicationContext(this.getServletContext); 

24、Jsf和spring的差别? 

jsf:是一种基于MVC模式的一个web层的处理,粒度较struts较细。 

Spring:提供了通用的服务,ioc/di aop,关心的不只web层,应当j2ee总体的一个服务,能够非常easy融合不同的技术struts hibernate ibatis ejb remote springJDBC springMVC 



Ejb技术 

1、weblogic的热公布 

将ear、jar、war拷到C:\bea\user_projects\domains\mydomain\applications文件夹 

weblogic会自己主动公布 

通过jbuilder将ear或jar或war部署到server上。 

2、在ejb中实现one-to-many 

1、在many中的将外键字段属性删除 

2、在删除many中的值时要将Collection转化为ArrayList, 

   并反向遍历ArrayList,先删除ArrayList中值,依据 

   ArrayList删除反回的对象转化为many的远程接口,通过 

   远程接口将many删除 

3、ejb所用的技术: 

Jndi:java naming directory inferface 

Rmi: remote method invoke 

4、实现ejb几个接口,几个类? 

两个接口一个类 

extends EJBHome 

通过jndi得到home接口 

create方法调用服务端的ejbCreate方法,在服务端产生一个EntityBean或SessionBean实例,向client返回一个远程接口。 

通过find方法在从服务端找到一个EntityBean实例,向client返回一个远程接口。 

extends EJBObject 

在client通过rmi调用远程服务端方法。 

通过remove方法调用服务端的ejbRemove方法,将EnityBean删除 

implements SessionBean 

在服务端实现真正的处理,实现核心业务 

5、实现ejb相关的配置文件是什么? 

ejb-jar.xml:说明ejb的两个接口一个类的。 

weblogic-ejb-jar.xml:说明ejb的JNDI名 

weblogic-rdbms-ejb.xml:o-rMapping实现数据库表、字段与ejb属性相应的关系。 

ejb2.0的开发 

1、用jbuilder集成环境 

2、能够用eclipse开发,用源码凝视说明,用ant运行xdoclet,xdoclet通 

过源码凝视自己主动生相关的配置、两个接口一个类。 

/** 

* @stateLess 

* @remote

*/ 

6、ejb的分类?差别 

sessionBean 

stateless:方法间不保留(1..1) 

statefull:方法间保留(1..n) 

entityBean:持久化 

cmp:增删改容器 

bmp:增删改手动jdbc 

message driver bean 

异处的消息处理 

7、本地接口与远程接口的差别。 

EJBHome(在不同的进程或主机间调用,即不同的jvm) 

EJBObjet 

EJBLocalHome(在同一进程,同是jvm中) 

EJBLocalObject

8、请求处理的过程?

会话 

url 

factory 

通过jndi得到一个home实例 

在client通过home实例在服务端产生一个sessionBean,client返回一个接口 

client通过远程接口调用方法。 

9、statefull的生命周期 

不存在 

setSessionContext 

create--->ejbcreate 

就绪:能够调用remove方法将sessionBean删除、能够调用服务端的不论什么方法。 

ejbPassivate(从就绪到挂起) 

ejbActivate(从挂起到就绪) 

挂起

假设超时自己主动删除 

10、stateless的生命周期 

不存在 

setSessionContext 

create--->ejbcreate 

remove-->ejbremove 

就绪 

11、entityBean的生命周期: 

不存在 

setEntityContext 

create--->ejbcreate 

入池 

空房子,没载入数据 

ejbActivate 

ejbPassivate 

就绪 

remove-->ejbRemove 

载入了数据库的数据 



12、EJB需直接实现它的业务接口或Home接口吗,请简述理由。 

远程接口和Home接口不须要直接实现, 

他们的实现代码是由server产生的, 

程序执行中通过接口调用服务端产生的实例。 



13、EJB的激活机制 

以Stateful Session Bean 为例:其Cache大小决定了内存中能够同一时候存在的Bean实例的数量,依据MRU或NRU算法,实例在就绪和挂起状态之间迁移。 



就绪:从文件到内存,调用ejbActivate方法 

挂起:从内存到文件,调用ejbPassivate方法 

14、EJB是基于哪些技术实现的?并说 出SessionBean和EntityBean的差别, 

EJB包含Session Bean、Entity Bean、Message Driven Bean,基于JNDI、RMI、JTA等技术实现. 

SessionBean在J2EE应用程序中被用来完毕一些server端的业务操作。比如訪问数据库、调用其它EJB组件. 

EntityBean被用来代表应用系统中用到的数据.对于客户机, 

SessionBean是一种非持久性对象,它实现某些在server上执行的业务逻辑; 

EntityBean是一种持久性对象,它代表一个存储在持久性存储器中的实体的对象视图,或是一个由现有企业应用程序实现的实体. 

Session Bean 还能够再细分为 Stateful Session Bean 与 Stateless Session Bean .这两种的 Session Bean都能够将系统逻辑放在 method之中运行,不同的是 Stateful Session Bean 能够记录呼叫者的状态,因此通常来说,一个使用者会有一个相相应的 Stateful Session Bean 的实体.Stateless Session Bean 尽管也是逻辑组件,可是他却不负责记录使用者状态,也就是说当使用者呼叫 Stateless
Session Bean 的时候,EJB Container 并不会找寻特定的 Stateless Session Bean 的实体来运行这个 method.换言之,非常可能数个使用者在运行某个 Stateless Session Bean 的 methods 时,会是同一个 Bean 的 Instance 在运行.从内存方面来看, Stateful Session Bean 与 Stateless Session Bean 比較, Stateful Session Bean 会消耗 J2EE Server
较多的内存,然而 Stateful Session Bean 的优势却在于他能够维持使用者的状态. 



15、EJB的分类是什么?各有什么特点? 

sessionBean:主机重起消失 

Stateless:不记忆 

StateFull:一个用户多个操作可记忆 

EntityBean:持久的数据库中 

Cmp:容器通过o/r mapping实现数据的持久化,不写sql,实现方便,在速度慢。 

Bmp:通过jdbc实现持久化,实现复杂,速度快 

messageBean:提供异步处理。 



10、EJB中基本的配置文件及作用是什么? 

EJB部署时须要三个文件: 

 Ejb-jar.xml: 

 将二个接口一个类打包在一起,给EJB一个名称。 

 说明当前的sessionBean的事务是由容器处理的。 

 其在全部的server上是通用的。 

 Weblogic-ejb-jar.xml: 

 将一个EJB名称,相应一个JNDI,在仅对weblogicserver 

 Weblogic-rdbms-jar.xml: 

 实现o/r mapping的说明,相当于*.hbm.xml 

15、说出数据连接池的工作机制是什么? 

容器或相关的应用程序在其池中实例化多个边接,当应用程序在使用时,容器直接将池中的连接取出应用程序直接使用,同一时候当应用程序使用完后,容器还能够将连接收回。从而提高系统的效率。 

16、EJB2.0有哪些内容?分别用在什么场合? EJB2.0和EJB1.1的差别? 

sessionBean:是一个过程 

entityBean:是持久化,代表的是一个业务实体,有主键。 

Struts+sessionBean+entityBean 

EJB2.0增加的本地接口及本地home 

EJB1.1中仅仅有远程接口及远程home 





18、EJB与JAVA BEAN的差别? 

Java Bean 是可复用的组件,不论什么一个Java类都能够是一个Bean。但通常情况下,Java Bean是被容器所创建(如Tomcat)的,所以Java Bean具有例如以下特点: 



一个无參的构造器 

实现Serializable接口 

私有属性 

公有get set方法 



Enterprise Java Bean 是一个分布式组件,其特点是 

基于(RMI)技术的,能够被远程訪问(跨进程、跨计算机)。 

EJB必须被布署在Webspere、WebLogic容器中,不能直接訪问ejb,而是通过容器訪问ejb,容器是ejb訪问的一个代理。 

19、EJB的角色和三个对象 

六个角色组成,各自是 

EJB组件开发人员(Enterprise Bean Provider):sun 

应用组合者(Application Assembler)真正的开发商 

部署者(Deployer): 

EJB server提供者(EJB Server Provider):sun ibm 小机 

EJB 容器提供者(EJB Container Provider):weblogic jboss 

系统管理员(System Administrator):维护员 

三个对象是Remote(Local)接口、Home(LocalHome)接口,Bean类 

20、EJB容器提供的服务 

主要提供 

安全 

事务管理 

分布式 

jts 

声明周期管理 

代码产生 

持续性管理 

锁和并发行管理等服务。 

21、EJB规范规定EJB中禁止的操作有哪些? 

1.不能操作线程和线程API(线程API指非线程对象的方法如notify,wait等), 

2.不能操作awt, 

3.不能实现server功能, 

4.不能对静态属生存取, 

5.不能使用IO操作直接存取文件系统, 

6.不能载入本地库., 

7.不能将this作为变量和返回, 

8.不能循环调用。 

26、EJB的基本架构 

答:一个EJB包含三个部分: 



Remote Interface 接口的代码 

package Beans; 

import javax.ejb.EJBObject; 

import java.rmi.RemoteException; 

public interface Add extends EJBObject 



//some method declare 



Home Interface 接口的代码 

package Beans; 

import java.rmi.RemoteException; 

import jaax.ejb.CreateException; 

import javax.ejb.EJBHome; 

public interface AddHome extends EJBHome 



//some method declare 





EJB类的代码 



package Beans; 



import java.rmi.RemoteException; 

import javax.ejb.SessionBean; 

import javx.ejb.SessionContext; 

public class AddBean Implements SessionBean 



//some method declare 



30、怎样在weblogic中进行ssl配置与client的认证配置或说说j2ee(标准)进行ssl的配置 

缺省安装中使用DemoIdentity.jks和DemoTrust.jks KeyStore实现SSL,须要配置server使用Enable SSL,配置其port,在产品模式下须要从CA获取私有密钥和数字证书,创建identity和trust keystore,装载获得的密钥和数字证书。能够配置此SSL连接是单向还是双向的。 

31怎样查看在weblogic中已经公布的EJB? 

能够使用管理控制台,在它的Deployment中能够查看全部已公布的EJB 

WebService技术 

1、什么是Web Service? 

Web Service就是为了使原来各孤立的网站之间的信息可以相互通信、共享而提出的一种接口。 

使用的技术: 

HTTP、XML、SOAP(简单对象訪问协议)、WSDL 

长处: 

跨平台、跨语言、跨系统 

SOAP协议: 

SOAP协议(Simple Object Access Protocal,简单对象訪问协议) 

Tcp/iphttp->soap,soap 通过xml文件传送信息 

缺点: 

(1).WebService使用了XML对数据封装,会造成大量的数据要在网络中传输。 

(2).WebService规范没有规定不论什么与实现相关的细节,包含对象模型、编程语言,这一点,它不如CORBA。 

2、什么是Web容器? 

实现J2EE规范中web协议的应用.该协议定义了web程序的执行时环境,包含:并发性,安全性,生命周期管理等等. 

就是在tomcat、weblogic下执行jsp、servlet、struts 

3、应用server有那些? 

BEA WebLogic Server,IBM WebSphere Application Server,Oracle9i Application Server,jBoss,Tomcat 

5、怎样给weblogic指定大小的内存? 

在启动Weblogic的脚本中(位于所在Domian相应server文件夹下的startServerName),添加set MEM_ARGS=-Xms32m -Xmx200m,能够调整最小内存为32M,最大200M 

6、怎样设定的weblogic的热启动模式(开发模式)与产品公布模式? 

能够在管理控制台中改动相应server的启动模式为开发或产品模式之中的一个。或者改动服务的启动文件或者commenv文件,添加set PRODUCTION_MODE=true。 

7、怎样启动时不需输入username与password? 

改动服务启动文件,添加 WLS_USER和WLS_PW项。也能够在boot.properties文件里添加加密过的username和password. 

8、在weblogic管理制台中对一个应用域(或者说是一个站点,Domain)进行jms及ejb或连接池等相关信息进行配置后,实际保存在什么文件里? 

保存在此Domain的config.xml文件里,它是server的核心配置文件。 

9、说说weblogic中一个Domain的缺省文件夹结构?比方要将一个简单的helloWorld.jsp放入何文件夹下,然的在浏览器上就可打入 http://主机:port号//helloword.jsp就能够看到执行结果了? 又比方这当中用到了一个自己写的javaBean该怎样办? 

Domain 文件夹server文件夹applications,将应用文件夹放在此文件夹下将能够作为应用訪问,假设是Web应用,应用文件夹须要满足Web应用文件夹要求,jsp文件能够直接放在应用文件夹中,Javabean须要放在应用文件夹的WEB-INF文件夹的classes文件夹中,设置server的缺省应用将能够实如今浏览器上无需输入应用名。 

12、CORBA是什么?用途是什么? 

CORBA 标准是公共对象请求代理结构(Common Object Request Broker Architecture),由对象管理组织 (Object Management Group,缩写为 OMG)标准化。它的组成是接口定义语言(IDL), 语言绑定(binding:也译为联编)和同意应用程序间互操作的协议。其目的为:用不同的程序设计语言书写在不同的进程中执行,为不同的操作系统开发。 

13、说说在weblogic中开发消息Bean时的persistent与non-persisten的区别 

persistent方式的MDB能够保证消息传递的可靠性,也就是假设EJB容器出现故障而JMSserver依旧会将消息在此MDB可用的时候发送过来,而non-persistent方式的消息将被丢弃。 

14、WEB SERVICE名词解释。JSWDL开发包的介绍。JAXP、JAXM的解释。SOAP、UDDI,WSDL解释。 

Web ServiceWeb Service是基于网络的、分布式的模块化组件,它运行特定的任务,遵守详细的技术规范,这些规范使得Web Service能与其它兼容的组件进行互操作。 

JAXP(Java API for XML Parsing) 定义了在Java中使用DOM, SAX, XSLT的通用的接口。这样在你的程序中你仅仅要使用这些通用的接口,当你须要改变详细的实现时候也不须要改动代码。 

JAXM(Java API for XML Messaging) 是为SOAP通信提供訪问方法和传输机制的API。 

WSDL是一种 XML 格式,用于将网络服务描写叙述为一组端点,这些端点对包括面向文档信息或面向过程信息的消息进行操作。这样的格式首先对操作和消息进行抽象描写叙述,然后将其绑定到详细的网络协议和消息格式上以定义端点。相关的详细端点即组合成为抽象端点(服务)。 

SOAP即简单对象訪问协议(Simple Object Access Protocol),它是用于交换XML编码信息的轻量级协议。 

UDDI 的目的是为电子商务建立标准;UDDI是一套基于Web的、分布式的、为Web Service提供的、信息注冊中心的实现标准规范,同一时候也包括一组使企业能将自身提供的Web Service注冊,以使别的企业可以发现的訪问协议的实现标准。 

j2ee模式(MVC模式、Model1,Model2) 

1、j2ee经常使用的设计模式?说明工厂模式。 

Java中的23种设计模式: 

Factory(工厂模式), Builder(建造模式), Factory Method(工厂方法模式), 

Prototype(原始模型模式),Singleton(单例模式), Facade(门面模式), 

Adapter(适配器模式), Bridge(桥梁模式), Composite(合成模式), 

Decorator(装饰模式), Flyweight(享元模式), Proxy(代理模式), 

Command(命令模式), Interpreter(解释器模式), Visitor(訪问者模式), 

Iterator(迭代子模式), Mediator(调停者模式), Memento(备忘录模式), 

Observer(观察者模式), State(状态模式), Strategy(策略模式), 

Template Method(模板方法模式), Chain Of Responsibleity(责任链模式) 

工厂模式:工厂模式是一种常常被使用到的模式,依据工厂模式实现的类能够依据提供的数据生成一组类中某一个类的实例,通常这一组类有一个公共的抽象父类而且实现了同样的方法,可是这些方法针对不同的数据进行了不同的操作。首先须要定义一个基类,该类的子类通过不同的方法实现了基类中的方法。然后须要定义一个工厂类,工厂类能够依据条件生成不同的子类实例。当得到子类的实例后,开发者能够调用基类中的方法而不必考虑究竟返回的是哪一个子类的实例。 

2、说说你所熟悉或听说过的j2ee中的几种经常使用模式?及对设计模式的一些看法 

Session Facade Pattern:使用SessionBean訪问EntityBean 

Message Facade Pattern:实现异步调用 

EJB Command Pattern:使用Command JavaBeans代替SessionBean,实现轻量级訪问 

Data Transfer Object Factory:通过DTO Factory简化EntityBean数据提供特性 

Generic Attribute Access:通过AttibuteAccess接口简化EntityBean数据提供特性 

Business Interface:通过远程(本地)接口和Bean类实现同样接口规范业务逻辑一致性 

ejb架构的设计好坏将直接影响系统的性能、可扩展性、可维护性、组件可重用性及开发效率。项目越复杂,项目队伍越庞大则越能体现良好设计的重要性。 

3、解释以下关于J2EE的名词 

(1)JNDI:Java Naming & Directory Interface,JAVA命名文件夹服务.主要提供的功能是:提供一个文件夹系统,让其他各地的应用程序在其上面留下自己的索引,从而满足高速查找和定位分布式应用程序的功能. 

(2)JMS:Java Message Service,JAVA消息服务.主要实现各个应用程序之间的通讯.包含点对点和广播. 

(3)JTA:Java Transaction API,JAVA事务服务.提供各种分布式事务服务.应用程序仅仅需调用其提供的接口就可以. 

(4)JAF: Java Action FrameWork,JAVA安全认证框架.提供一些安全控制方面的框架.让开发人员通过各种部署和自己定义实现自己的个性安全控制策略. 

(5)RMI:Remote Method Interface,远程方法调用 



4、介绍J2EE、J2SE、J2ME的差别。 

J2ee:企业级,基本的application server的web及应用服务 

J2se:标准版, 没有application server 

J2me:手机、pda的嵌入式开发 



5、开发中都用到了那些设计模式?用在什么场合? 

每一个模式都描写叙述了一个在我们的环境中不断出现的问题,然后描写叙述了该问题的解决方式的核心。通过这样的方式,你能够无数次地使用那些已有的解决方式,无需在反复同样的工作。主要用到了MVC的设计模式。用来开发JSP/Servlet或者J2EE的相关应用。简单工厂模式等。 

6、J2EE是什么? 

J2EE 是Sun公司提出的多层(multi-diered),分布式(distributed),基于组件(component-base)的企业级应用模型 (enterpriese application model).在这种一个应用系统中,可依照功能划分为不同的组件,这些组件又可在不同计算机上,而且处于对应的层次(tier)中。所属层次包含客户层(clietn tier)组件,web层和组件,Business层和组件,企业信息系统(EIS)层。 

7、J2EE是技术还是平台还是框架? 

    J2EE本身是一个标准,一个为企业分布式应用的开发提供的标准平台。 

    J2EE也是一个框架,包含JDBC、JNDI、RMI、JMS、EJB、JTA等技术。 

其它 

1、当前主流的解析器有那些? 

DOM:文档对象模型(document object model) 

SAX 

2、Dom解析处理的过程是什么? 

package ss; 

import javax.xml.parsers.DocumentBuilderFactory; 

import javax.xml.parsers.DocumentBuilder; 

import org.w3c.dom.Document; 

import org.w3c.dom.Element; 

import org.w3c.dom.Node; 

import org.w3c.dom.Attr; 

import org.w3c.dom.NodeList; 

import javax.xml.transform.TransformerFactory; 

import javax.xml.transform.Transformer; 

import javax.xml.transform.dom.DOMSource; 

import javax.xml.transform.stream.StreamResult; 



public class XmlParser 



    public static void main(String[] args) 

            throws Exception 

    { 

        xmlwriter(); 

    } 



    public static void xmlparser() 

            throws Exception 

    { 

        DocumentBuilderFactory xdf = DocumentBuilderFactory.newInstance(); 

        DocumentBuilder db = xdf.newDocumentBuilder(); 

        Document d = db.parse("C:\\A1\\customer.xml"); 

        NodeList nl = d.getElementsByTagName("customer"); 

        for (int i = 0; i < nl.getLength(); i++) 

        { 



            Element e = (Element) nl.item(i); 

            Attr a = e.getAttributeNode("customerID"); 

            System.out.println(a.getNodeValue()); 

            NodeList nl1 = e.getElementsByTagName("customerName"); 

            System.out.println(nl1.item(0).getFirstChild().getNodeValue()); 

        } 

    } 

    public static void xmlwriter() throws Exception 

    { 

        DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance(); 

        DocumentBuilder db=dbf.newDocumentBuilder(); 

        Document d=db.parse("C:\\A1\\customer.xml"); 

        NodeList nl=d.getElementsByTagName("customerName"); 

        for(int i=0;i<nl.getLength();i++) 

        { 

           Element e=(Element) nl.item(i); 

           System.out.println(e.getFirstChild().getNodeValue()); 

           e.getFirstChild().setNodeValue(e.getFirstChild().getNodeValue()+"111111111111111"); 

        } 

        TransformerFactory tff=TransformerFactory.newInstance(); 

        Transformer tf=tff.newTransformer(); 

        tf.transform(new DOMSource(d),new StreamResult("c:\\aa.xml")); 

    } 





DocumentBuilderFactory 

DocumentBuiler db 

Document d=db.parse(“详细文件路径”); 

NodeList nl=d.getElementsByTagName(“节点名”) 

3、Sax解析处理的过程是什么? 

import org.xml.sax.helpers.DefaultHandler; 

import org.xml.sax.SAXException; 

import org.xml.sax.Attributes; 

import javax.xml.parsers.SAXParser; 

import javax.xml.parsers.SAXParserFactory; 

public class SaxParser extends DefaultHandler 



    public void characters(char[] ch, int start, int length) 

            throws SAXException 

    { 

        String temp=new String(ch,start,length); 

        System.out.println(temp); 

    } 



    public void endDocument() 

            throws SAXException 

    { 

        System.out.println("正在開始一个文档"); 

    } 



    public void endElement(String namespaceURI, String localName, String qName) 

            throws SAXException 

    { 

        System.out.println("结束元素"+qName); 

    } 



    public void startDocument() 

            throws SAXException 

    { 

        System.out.println("開始文档"); 

    } 



    public void startElement(String namespaceURI, String localName, 

                             String qName, Attributes atts) 

            throws SAXException 

    { 

         System.out.println("開始元素"+qName); 

    } 

    public static void main(String[] args) throws Exception 

    { 

        SAXParserFactory spf=SAXParserFactory.newInstance(); 

        SAXParser sp=spf.newSAXParser(); 

        sp.parse("C:\\A1\\customer.xml",new SaxParser()); 

    } 



4、Dom与Sax相比它们的优缺点是什么? 

DOM能够訪问不论什么一个节点,要将所有资源所有载入,比較耗内存,能够改动。 

SAX仅仅能顺序读,不可任意訪问,不可写,但速度快。 

Dom中的核心接口有那些? 

Node 

TextNode 

Element  

Arr 

NodeList 

Document 

5、怎样将Dom对象写入到文件里? 

TransformerFactory 

Transformer通过例如以下方法进行处理 

Transformer(DOMSource(Document d),ResultStream(OutputStream o)) 

6、用jdom解析xml文件时怎样解决中文问题? 

类文件是utf-8,xml文件头也应是utf-8 如<?xml version="1.0" encoding="UTF-8" ?> 

7、XML文档定义有几种形式?它们之间有何本质差别?解析XML文档有哪几种方式? 

a: 两种形式 dtd  schema, 

b: 本质差别:schema本身是xml的,能够被XML解析器解析(这也是从DTD上发展schema的根本目的), 

c:有DOM,SAX,STAX等 

DOM:处理大型文件时其性能下降的很厉害。这个问题是由DOM的树结构所造成的,这样的结构占用的内存较多,并且DOM必须在解析文件之前把整个文档装入内存,适合对XML的随机訪问 

SAX:不现于DOM,SAX是事件驱动型的XML解析方式。它顺序读取XML文件,不须要一次所有装载整个文件。当遇到像文件开头,文档结束,或者标签开头与标签结束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来处理XML文件,适合对XML的顺序訪问 

STAX:Streaming API for XML (StAX) 



8、标准建模语言UML中的各种图? 

静态图 

用例图、类图、对象图、构件、部署, 

动态图(行为图) 

活动图,协作图,状态、时序 

9、BS与CS的联系与差别。 

C/S是Client/Server的缩写。server通常採用高性能的PC、工作站或小型机,并採用大型数据库系统,如Oracle、Sybase、Informix或 SQL Server。client须要安装专用的client软件。 

B/S是Brower/Server的缩写,客户机上仅仅要安装一个浏览器(Browser),如Netscape Navigator或Internet Explorer,server安装Oracle、Sybase、Informix或 SQL Server等数据库。在这样的结构下,用户界面全然通过WWW浏览器实现,一部分事务逻辑在前端实现,可是主要事务逻辑在server端实现。浏览器通过Web Server 同数据库进行数据交互。 

C/S 与 B/S 差别: 

1.硬件环境不同: 

  C/S 一般建立在专用的网络上, 小范围里的网络环境, 局域网之间再通过专门server提供连接和数据交换服务. 

  B/S 建立在广域网之上的, 不必是专门的网络硬件环境,例与电话上网, 租用设备. 信息自己管理. 有比C/S更强的适应范围, 一般仅仅要有操作系统和浏览器即可 

2.对安全要求不同 

  C/S 一般面向相对固定的用户群, 对信息安全的控制能力非常强. 一般高度机密的信息系统採用C/S 结构适宜. 能够通过B/S公布部分可公开信息. 

  B/S 建立在广域网之上, 对安全的控制能力相对弱, 可能面向不可知的用户。 

3.对程序架构不同 

  C/S 程序能够更加注重流程, 能够对权限多层次校验, 对系统执行速度能够较少考虑. 

  B/S 对安全以及訪问速度的多重的考虑, 建立在须要更加优化的基础之上. 比C/S有更高的要求 B/S结构的程序架构是发展的趋势, 从MS的.Net系列的BizTalk 2000 Exchange 2000等, 全面支持网络的构件搭建的系统. SUN 和IBM推的JavaBean 构件技术等,使 B/S更加成熟. 

4.软件重用不同 

  C/S 程序能够不可避免的总体性考虑, 构件的重用性不如在B/S要求下的构件的重用性好. 

  B/S 对的多重结构,要求构件相对独立的功能. 可以相对较好的重用.就入买来的餐桌可以再利用,而不是做在墙上的石头桌子 

5.系统维护不同 

  C/S 程序因为总体性, 必须总体考察, 处理出现的问题以及系统升级. 升级难. 可能是再做一个全新的系统 

  B/S 构件组成,方面构件个别的更换,实现系统的无缝升级. 系统维护开销减到最小.用户从网上自己下载安装就能够实现升级. 

6.处理问题不同 

  C/S 程序能够处理用户面固定, 而且在同样区域, 安全要求高需求, 与操作系统相关. 应该都是同样的系统 

  B/S 建立在广域网上, 面向不同的用户群, 分散地域, 这是C/S无法作到的. 与操作系统平台关系最小. 

7.用户接口不同 

  C/S 多是建立的Window平台上,表现方法有限,对程序猿普遍要求较高 

  B/S 建立在浏览器上, 有更加丰富和生动的表现方式与用户交流. 而且大部分难度减低,减低开发成本. 

8.信息流不同 

  C/S 程序通常是典型的*集权的机械式处理, 交互性相对低 

  B/S 信息流向可变化, B-B B-C B-G等信息、流向的变化, 更像交易中心。 

10、Uml的概念是什么?基本的工具是什么 

Uml:统一建模语言 

工具:Rational Rose 

11、Uml的概念中的九大图形是什么?最重的三个图是什么?各有什么特点? 

类图 

继承 

关联:(1..n  n..1  n..n) 

依赖 

实现接口 

聚集 

组成 

类图的生命周期(开发的全部阶段都使用) 

整体设计 

具体设计 

开发:以类图进行开发 

測试 

Use-case图 

关系 

用例与用例 

包括(include):必须调用 

扩展(extends):能够调用也能够不调用 

角色与角色的关系 

泛化 

用例与角色的关系: 

用例与角色:通知 

角色与用例:调用 

元素 

用例 

角色 

系统边界 

Use-case图的生命周期 

需求 

总体设计 

測试(单元測试、集成測试、系统測试、用户验收) 

时序 

元素 

横坐标:对象 

纵坐标: 时间 

作用 

找类 

找方法 

验证系统的正确 

生命周期 

具体设计 

活动(流程图) 

作用 

分析业务 

构件图 

作用:说明组件与组件之间的关系,依赖关系 

部署 

作用:说明安装软件的主机之间的关系,系统执行时的性能的主要影响者。 

协作 

对象与对象之间的调用协作。 

状态 

一个对象状态在不同的动作下的变化。 

对象 

说明对象 

13、在类图中怎样找类? 

找名词 

                     下面为在网上找的面试题 

1 什么是Java、Java2、JDK?JDK后面的1.3、1.4.2版本又是怎么回事? 

  答:Java是一种通用的,并发的,强类型的,面向对象的编程语言(摘自Java规范第二版) JDK是Sun公司分发的免费Java开发工具,正式名称为J2SDK(Java2 Softw are Develop Kit)。 



2 什么是JRE/J2RE? 

  答:J2RE是Java2 Runtime Environment,   即Java执行环境,有时简称JRE。 

假设你仅仅须要执行Java程序或Applet, 下载并安装它就可以。假设你要自行开发Java软件,请下载JDK。在JDK中附带有J2RE。 

  注意因为Microsoft对Java的支持不全然,请不要使用IE自带的虚拟机来执行Applet,务必安装一个J2RE或JDK。 



3 学习Java用什么工具比較好? 

 答:作者建议首先使用JDK+文本编辑器,这有助你理解下列几个基础概念:path,classpath,package并熟悉基本命令:javac和java。而且下载和你的JDK版本号一致的API帮助。 

  假设你不确定类或函数的使用方法,请先查阅API而不是发贴求助。 

  当你熟悉Java之后,你能够考虑换一个IDE。非常多人推荐Jcreator,实际上Jcreator的功能还 是非常弱的。 

  作者推荐eclipse,下载网址http://www.eclipse.org ;。因eclispe是免费的. 



4 学习Java有哪些好的參考书? 

  答:作者首先推荐Thinking in Java,中文名《Java编程思想》,有中文版。该书第一章介绍了非常多面向对象的编程思想,作为新手应当认真阅读。除此以外,O´relly出版社和Wrox出版社的书也不错。作者本人不喜欢大陆作者的书。或许你认为英文太难,可是网上大多数资料都是英文的。另外,你须要常常查阅API,而那也是英文的。 



5 Java和C++哪个更好? 

  答:这个问题是一个非常不恰当的问题。你应该问:Java和C++哪个更适用于我的项目? 假设你不须要跨平台,不须要分布式,要强调程序的执行速度,C++更为适用。反之?你应当考虑Java。 



6 什么是J2SE/J2EE/J2ME?   

  答:J2SE就是一般的Java。 

  J2ME是针对嵌入式设备的,比方Java手机,它有自己的SDK。而J2EE使用J2SE的SDK。 

  J2EE规范很多其它的是对J2EEserver的要求和开发者的约束。详情见后继《J2EE FAQ》。 

7 我写了第一个Java程序,应该怎样编译/执行? 

  答:首先请将程序保存为xxx.java文件, 

  然后在dos窗体下使用javac xxx.java命令,你会发现该文件夹下多了一个xxx.class文件,再使用java xxx命令,你的java程序就開始执行了。 



8 我照你说的做了,可是出现什么"´javac´ 不是内部或外部命令,也不是可执行的程序或批处理文件。"。 

  答:你遇到了path问题。操作系统在一定的范围(path)内搜索javac.exe,可是没能找到。 

  请编辑你的操作系统环境变量,新增一个JAVA_HOME变量,设为你JDK的安装文件夹, 

  再编辑Path变量,加上一项 %JAVA_HOME%bin。 

  然后关掉并新开一个dos窗体,你就能够使用javac和java命令了。 



9 环境变量怎么设置? 

  答:请向身边会设的人咨询。 java刚開始学习的人必读-经验总结 这篇文章中比較具体的讲到 jdk开发中系统设置环境变量 以及相关 server配置等开发环境配置。 



10 javac xxx.java顺利通过了,可是java xxx的时候显示什么"NoClassDefFoundError" 

  答:你遇到了classpath问题。java命令在一定的范围(classpath)内搜索你要用的class文件,可是未能找到。 

  首先请确认你没有错敲成java xxx.class, 

  其次,检查你的CLASSPATH环境变量,假设你设置了该变量又没有包括.(代表当前文件夹)你就会遇到这个问题。请在你的CLASSPATH环境变量中增加一项. 。另 

  外參见15。 



11 我在java xxx的时候显示"Exception in thread "main" java.lang.NoSuchMethodError: main"。 

  答:首先,在你的程序中每一个java文件有且仅仅能有一个public类, 

  这个类的类名必须和文件名称的大写和小写全然一样。 

  其次,在你要执行的类中有且仅仅能有一个public static void main(String[] args)方法,这种方法就是你的主程序。 



12 package是什么意思?怎么用? 

  答:为了唯一标识每一个类并分组,java使用了package的概念。 

  每一个类都有一个全名,比如String的全名是java.lang.String,当中java.lang是包名,String是短名。 

  这样,假设你也定义了String,你能够把它放在mypackage中, 

  通过使用全名mypackage.String和java.lang.String来区分这两个类。 

  同一时候,将逻辑上相关的类放在同一个包中,能够使程序结构更为清楚。 



  你要做的就是在java文件开头加一行"package mypackage;"。 

  注意包没有嵌套或包括关系,A包和A.B包对java命令来说是并列的两个包 



13 我没有声明不论什么package会怎么样? 

  答:你的类被觉得放在默认包中。这时全名和短名是一致的。 



14 在一个类中怎么使用其它类? 

  答:假设你使用java.lang包中的类,不用做不论什么事。 

  假设你使用其它包中的类,使用import package1.class1; 或 import package2.*; 

  这里.*表示引入这个包中的全部类。然后在程序中你能够使用其它类的短名。 

  假设短名有冲突,使用全名来区分。 



15 我用了package的时候显示"NoClassDefFoundError",可是我把全部package去掉的时候能正常执行。 

  答:将你的java文件按包名存放。 

  比方你的工作文件夹是/work,你的类是package1.class1,那么将它存放为/work/package1/class1.java。 

  假设没有声明包,那么直接放在/work下。 

  在/work下运行javac package1/class1.java,再运行java package1.class1,你会发现 

  一切正常。 

  另外,你能够考虑開始使用IDE。 



16 我想把java编译成exe文件,该怎么做? 

  答:JDK仅仅能将java源文件编译为class文件。 

  class文件是一种跨平台的字节码,必须依赖平台相关的JRE来执行。Java以此来实现跨平台,有些开发工具能够将java文件编译为exe文件。作者反对这样的做法,由于这样就取消了跨平台性。 

  假设你确信你的软件仅仅在Windows平台上执行,你能够考虑使用C++/C#来编程。 



17 我在编译的时候遇到什么"deprecated API",是什么意思? 

  答:所谓deprecated是指已经?时,可是为了向前兼容起见仍然保留的方法?这些方法可能会在以后取消支持。你应当改用较新的方法。 

  一般在API里面会说明你应当用什么方法来取代之。 



Java设置环境变量 

18 我怎么给java程序加启动參数,就像dir /p/w那样? 

  答:还记得public static void main(String[] args)吗?这里的args就是你的启动參数。 

  在执行时你输入java package1.class1 -arg1 -arg2,args中就会有两个String,一个是arg1,还有一个是arg2。



19 我怎么从键盘输入一个int/double/字符串? 

  答:java的I/O操作比C++要复杂一点。假设要从键盘输入,例子代码例如以下: 

  BufferedReader cin = new BufferedReader( new InputStreamReader( System.in ) ) ; 

  String s = cin.readLine(); 

  这样你就获得了一个字符串,假设你须要数字的话再加上: 

  int n = Integer.parseInt( s ); 或者 double d = Double.parseDouble( s ); 



20 我怎么输出一个int/double/字符串? 

  答:在程序開始写: 

  PrintWriter cout = new PrintWriter( System.out ); 须要时写:cout.print(n); 或者 out.println("hello")等等。 



21 我发现有些书上直接用System.in和System.out输入输出,比你要简单得多。 

  答:java使用unicode,是双字节。而System.in和System.out是单字节的stream。 

  假设你要输入输出双字节文字比方中文,请使用作者的做法。 



22 我怎么从文件输入一个int/double/字符串? 

  答:类似于从键盘输入,仅仅只是换成 

  BufferedReader fin = new BufferedReader( new FileReader(" myFileName " ) ); 

  PrintWriter fout = new PrintWriter( new FileWriter(" myFileName " ) ); 

  另外假设你还没下载API,请開始下载并阅读java.io包中的内容。 



23 我想读写文件的指定位置,该怎么办? 

  答:你肯定没有认真看API。java.io.RandomAccessFile能够满足你的须要。 



24 怎么推断要读的文件已经到了尽头? 

  答:你肯定没有认真看API。在Reaer的read方法中明白说明返回-1表示流的结尾。 

25 java里面怎么定义宏? 

  答:java不支持宏,由于宏代换不能保证类型安全。 

  假设你须要定义常量,能够将它定义为某个类的static final成员。參见26和30。 



26 java里面没法用const。 

  答:你能够用finalkeyword。比如 final int m = 9。被声明为final的变量不能被再次赋值?final也能够用于声明方法或类,被声明为final的方法或类不能被继承 。 

  注意const是java的保留字以备扩充。 



27 java里面也不能用goto。 

  答:甚至在面向过程的语言中你也能够全然不用goto。请检查你的程序流程是否合理。 

  假设你须要从多层循环中迅速跳出,java增强了(和C++相比)break和continue的功能,支持label。 



  比如: 

  outer : 

  while( ... ) 

  { 

  inner : 

  for( ... ) 

  { 

  ... break inner; ... 

  ... continue outer; ... 

  } 

  } 

  和const一样,goto也是java的保留字以备扩充。 



28 java里面能不能重载操作符? 

  答:不能。String的+号是唯一一个内置的重载操作符。你能够通过定义接口和方法来实现类 

  似功能。 



29 我new了一个对象,可是没法delete掉它。 

  答:java有自己主动内存回收机制,即所谓Garbarge Collector。你再也不用操心指针错误 



30 我想知道为什么main方法必须被声明为public static? 

  答:声明为public是为了这种方法能够被外部调用,详情见面向对象篇37。 

  static是为了将某个成员变量/方法关联到类(class)而非实例(instance)。 

  你不须要创建一个对象就能够直接使用这个类的static成员, 

  在A类中调用B类的static成员能够使用B.staticMember的写法。 

  注意一个类的static成员变量是唯一的,被全部该类对象所共享的。 



31 throw和throws有什么不同? 

  答:throws用于声明一个方法会抛出哪些异常。而throw是在方法体中实际运行抛出异常 

  的动作。 

  假设你在方法中throw一个异常,却没有在方法声明中声明之,编译器会报错。 

  注意Error和RuntimeException的子类是例外,无需特别声明。 



32 什么是异常? 

  答:异常最早在Ada语言中引入,用于在程序中动态处理错误并恢复。 

  你能够在方法中拦截底层异常并处理之,也能够抛给更高层的模块去处理。 

  你也能够抛出自己的异常指示发生了某些不正常情况。常见的拦截处理代码例如以下: 

  try 

  { 

  ...... //下面是可能发生异常的代码 

  ...... //异常被抛出,运行流程中断并转向拦截代码。 

  ...... 

  } 





  catch(Exception1 e) //假设Exception1是Exception2的子类并要做特别处理,应排在 

  前面 

  { 

  //发生Exception1时被该段拦截 

  } 

  catch(Exception2 e) 

  { 

  //发生Exception2时被该段拦截 

  } 

  finally //这是可选的 

  { 

  //不管异常是否发生,均运行此段代码 

  } 



33 final和finally有什么不同? 

  答:final请见26。finally用于异常机制,參见32。 

34 extends和implements有什么不同? 

  答:extends用于(单)继承一个类(class),而implements用于实现一个接口(interface)。 

  interface的引入是为了部分地提供多继承的功能。 

  在interface中仅仅需声明方法头,而将方法体留给实现的class来做。 

  这些实现的class的实例全然能够当作interface的实例来对待。 

  有趣的是在interface之间也能够声明为extends(单继承)的关系。 



35 java怎么实现多继承? 

  答:java不支持显式的多继承。 

  由于在显式多继承的语言比如c++中,会出现子类*声明祖先虚基类构造函数的问题, 



  而这是违反面向对象的封装性原则的。 

  java提供了interface和implementskeyword来部分地实现多继承。參见34。 



36 abstract是什么? 

  答:被声明为abstract的方法无需给出方法体,留给子类来实现。 

  而假设一个类中有abstract方法,那么这个类也必须声明为abstract。 

  被声明为abstract的类无法实例化,虽然它能够定义构造方法供子类使用。 



37 public,protected,private有什么不同? 

  答:这些keyword用于声明类和成员的可见性。 

  public成员能够被不论什么类訪问, 

  protected成员限于自己和子类訪问, 

  private成员限于自己訪问。 

  Java还提供了第四种的默认可见性,当没有不论什么public,protected,private修饰时,成员是包内可见 

  类能够用public或默认来修饰。 



38 Override和Overload有什么不同? 

  答:Override是指父类和子类之间方法的继承关系,这些方法有着同样的名称和參数类型。 

  Overload是指同一个类中不同方法(能够在子类也能够在父类中定义)间的关系,这些方法有着同样的名称和不同的參数类型。 



39 我继承了一个方法,但如今我想调用在父类中定义的方法。 

  答:用super.xxx()能够在子类中调用父类方法。 



40 我想在子类的构造方法中调用父类的构造方法,该怎么办? 

  答:在子类构造方法的第一行调用super(...)就可以。 



41 我在同一个类中定义了好几个构造方法而且想在一个构造方法中调用还有一个。 

  答:在构造方法第一行调用this(...)。 



42 我未定义构造方法会怎么样? 

  答:自己主动获得一个无參数的构造方法。 



43 我调用无參数的构造方法失败了。 

  答:假设你至少定义了一个构造方法,就不再有自己主动提供的无參数的构造方法了。 

  你须要显式定义一个无參数的构造方法。 



44 我该怎么定义类似于C++中的析构方法(destructor)? 

  答:提供一个void finalize()方法。在Garbarge Collector回收该对象时会调用该方法。 

  注意实际上你非常难推断一个对象会在什么时候被回收。作者从未感到须要提供该方法。 



45 我想将一个父类对象转换成一个子类对象该怎么做? 

  答:强制类型转换。如 

  public void meth(A a) 

  { 

  B b = (B)a; 

  } 

  假设a实际上并非B的实例,会抛出ClassCastException。所以请确保a确实是B的实例 . 



46 事实上我不确定a是不是B的实例,能不能分情况处理? 

  答:能够使用instanceof操作符。比如 

  if( a instanceof B ) 

  { 

  B b = (B)a; 

  } 

  else 

  { 

  ... 

  } 



47 我在方法里改动了一个对象的值,可是退出方法后我发现这个对象的值没变! 

  答:非常可能你把传入參数重赋了一个新对象,比例如以下列代码就会造成这样的错误: 

  public void fun1(A a) //a是局部參数,指向了一个外在对象。 

  { 

  a = new A(); //a指向了一个新对象,和外在对象脱钩了。假设你要让a作为传 

  出变 

  量,不要写这一句。 

  a.setAttr(attr);//改动了新对象的值,外在对象没有被改动。 

  } 

  基本类型也会出现这样的情况。比如: 

  public void fun2(int a) 

  { 

  a = 10;//仅仅作用于本方法,外面的变量不会变化。 

  } 

48 java能动态分配数组吗? 

  答:能够。比如int n = 3; Language[] myLanguages = new Language[n]; 



49 我怎么知道数组的长度? 

  答:用length属性。如上例中的 myLanguages.length 就为 3。 



50 我还想让数组的长度能自己主动改变,可以添加/删除元素。 

  答:用顺序表--java.util.List接口。 

  你能够选择用ArrayList或是LinkedList,前者是数组实现,后者是链表实现。 

  比如: List list = new ArrayList(); 或是 List list = new LinkedList(); 。 



51 什么是链表?为什么要有两种实现? 

  答:请补习数据结构。 



52 我想用队列/栈。 

  答:用java.util.LinkedList。 



53 我希望不要有反复的元素。 

  答:用集合--java.util.Set接口。比如:Set set = new HashSet()。 



54 我想遍历集合/Map。 

  答:用java.util.Iterator。參见API。 



55 我还要可以排序。 

  答:用java.util.TreeSet。比如:Set set = new TreeSet()。放进去的元素会自己主动排序。 

  你须要为元素实现Comparable接口,还可能须要提供equals()方法,compareTo()方法,hashCode()方法。 



56 可是我想给数组排序。 

  答:java.util.Arrays类包括了sort等有用方法。 



57 我想按不同方法排序。 

  答:为每种方法定义一个实现了接口Comparator的类并和Arrays综合运用。 



58 Map有什么用? 

  答:存储key-value的keyword-值对,你能够通过keyword来高速存取对应的值。 



59 set方法没问题,可是get方法返回的是Object。 

  答:强制类型转换成你须要的类型。參见45。 



60 我要获得一个随机数。 

  答:使用java.util.Random类。 



61 我比較两个String总是false,可是它们明明都是"abc" ! 

  答:比較String一定要使用equals或equalsIgnoreCase方法,不要使用 == ! 

  ==比較的是两个引用(变量)是否指向了同一个对象,而不是比較其内容。 

我的一个客户不知道该选用Struts还是JSF。就像你预料的那样,我一般会问:这2中框架之间有什么差别?当然,除了我的这个客户外非常多人都面临这种选择。 

   

  总的来说,我建议在新项目中优先考虑JSF。尽管经常有一些商业上的因素迫使我们为现有的项目选择了Struts,并且那些解决方式还有待考验,可是,让我们面对一个事实:JSF比Struts好多了。 

   

  以下是我选择JSF而不选Struts的十大理由: 

   

  1.Components(组件) 

  2.Render Kits 

  3.Renderers 

  4.Value Binding Expressions(值绑定表达式) 

  5.Event Model(事件模型) 

  6.Extensibility(可扩展性) 

  7.Managed Beans(Dependency Injection 依赖注入) 

  8.POJO Action Methods 

  9.JSF is the standard Java-based web app framework (JSF是java web应用程序的标准框架) 

  10.There's only one Struts(仅仅有一个Struts) 

   

  10.There's only one Struts(仅仅有一个Struts) 

     Struts 是一个开源产品,然而JSF是一个标准。这个细节经常被新的JSF学习者忽略,事实上这是显而易见的,由于我们有多个JSF的实现。尽管JSF还非常不成熟,可是我们已经有了2个优秀的JSF实现能够选择:Sun的參考实现和Apache的MyFaces。还有一方面,我们仅仅有一个Struts。 



  9.JSF is the standard(JSF是标准) 

      J2EE 5.0要提供一个JSF的实现,这表明JSF不久将会无处不在。这可能与你无关,可是和工具供应商密切相关。如今大概有50个java web应用程序框架,工具供应商不会情愿去支持一个特别的框架,可是他们会毫不犹豫的去支持一个标准。并且不止供应商,开源项目也会迅速的聚集在JSF的四周,争先恐后的去实现同样的功能。比方说,直到我们去实现本质上和Shale的Tapestry差点儿相同的视图的时候,我才知道Facalets。(从长远来看,我相信这样的冗余是件好事,会给我们带来优点) 



  8.POJO Action Methods 

      Struts的行为是和 Struts的API绑定在一起的,可是JSF的行为方法能够在POJPO中实现。这意味着你不用在表单和模型对象之间实现一个多余的行为层。顺便说一下,在JSF里面没有行为对象,行为在模型对象中实现。可是也请注意一点:假设你愿意你也能够生成与JSF独立的行为对象。在Struts里面,你有 Form Bean和Action Bean。Form Bean包括数据而Action Bean包括逻辑。OO狂会想去合并前2者,在Struts你办不到。可是在JSF中,你能够分开数据和逻辑,也能够合并到一个对象中,一切由你决定。 



  7.Managed Beans(Dependency Injection 依赖注入) 

      和Spring一样,JSF也使用了依赖注入(DJ)(或控制反转(IoC))去实例化和初始化Bean。Struts的确为你生成了Form Bean和Action Bean,可是JSF能够为你生成各种各样的Managed Bean。 



  6.Extensibility(可扩展性) 

      这个非常重要。JSF有6个对象实现了这个框架的大部分功能,并且你能够非常easy的用你自己的实现取代原有实现。比方你想加一个自己定义參数在JSF表达式语言里面,或是加入一个自己的视图控制器以便于区分组件和HTML。其实Shale实现了上面的功能。假设你还没有满足,JSF提供了几个地方你能够轻松的控制JSF的生命周期。Shale给你的会很多其它。 



  5.Event Model(事件模型) 

      JSF的事件模型使你能够对值改变,动作,JSF生命周期阶段变换等作出反应。在JSF1.1中,那些事件都是在server端处理的,这肯定是一个缺陷,好在JSF2.0计划支持client事件,拭目以待吧。 



  4.Value Binding Expressions(值绑定表达式) 

      在Struts 中,你负责把数据从Form传递到模型对象。你实现的Action的execute方法是把Form作为一个參数。然后你再手动的把数据从Form Bean里面取出放到模型对象里面。你要为应用里面的每一个Form做这些事情,然而在JSF里面,你仅仅需像这样:#{model.property} 就够了,其它的交给JSF来处理。 



  3.Renderers 

      你有看过Struts的标签的源码吗?它直接生成HTML。JSF组件标签什么都不生成,它和server上的一对component-renderer相应。Component维护组件状态,rendered负责获得视图。重点是renderers是可插拔的,即你能够依据自己需求实现然后替代掉默认实现。比方说我在NFJS上面的Felix谈话中举例说明了怎么去实现一个自己定义的label renderer。你仅仅须要配置你的renderer,JSF就会自己主动在你的应用程序里面使用他。 



  2.Render Kits 

      在几年前我以前有份Struts咨询工作,我们必须同一时候支持浏览器和无线设备,很痛苦。可是用JSF来完毕那个任务很easy,由于你能够生成你自己的render kit-为一种特定显示技术的renderers的集合-然后配置到JSF里面。 



  1.Components(组件) 

      组件是Struts和JSF之间最大的差别。就像Swing一样,JSF提供丰富的底层构件去开发组件然后加入到标准的组件集。那些底层构件让你非常easy的生成自己的组件而且和别人共享。如今我们到处都能看到自己定义组件跳出来,比方说Oracle的ADF和MyFaces,两者都提供了丰富的组件集,就像 javascript日历,tree等等。当然,组件仅仅是一部分。典型的是,组件都和一个独立的renderer相应,这给我们带来了真正的优点(看第3 条)。可是和JSF中的非常多东西一样,你不一定要墨守成规。仅仅要你愿意,你能够实现render自己的组件,尽管这样你会失去给组件加入别的
renderer的能力。 



java版本号的escape和unescape函数 

大 | 中 | 小   [2006/02/27 15:33 | 分类: Java,J2EE | by NetFetch ] 

Ad0.cn整理 



java.net.URLDecoder / java.net.URLEncoder 

相应:javascript的 encodeURI/decodeURI 和encodeURIComponent/decodeURIComponent 



java版本号的escape和unescape函数 

相应:javascript 的escape/unescape 



http://blog.ad0.cn 







class EscapeUnescape{ 

  public static String escape (String src) { 

    int i; 

    char j; 

    StringBuffer tmp = new StringBuffer(); 

    tmp.ensureCapacity(src.length()*6); 

    for (i=0;i      j = src.charAt(i); 

      if(Character.isDigit(j) || Character.isLowerCase(j) || Character.isUpperCase(j)) 

        tmp.append(j); 

      else 

        if(j<256){ 

          tmp.append(\"%\"); 

          if(j<16) 

            tmp.append(\"0\"); 

          tmp.append(Integer.toString(j,16)); 

        }  

        else{ 

          tmp.append(\"%u\"); 

          tmp.append(Integer.toString(j,16)); 

        } 

    } 

    return tmp.toString(); 

  } 

  

  public static String unescape (String src) { 

    StringBuffer tmp = new StringBuffer(); 

    tmp.ensureCapacity(src.length()); 

    int lastPos=0,pos=0; 

    char ch; 

    while (lastPos      pos = src.indexOf(\"%\",lastPos); 

      if(pos == lastPos)  { 

        if(src.charAt(pos+1)=='u') { 

          ch = (char)Integer.parseInt(src.substring(pos+2,pos+6),16); 

          tmp.append(ch); 

          lastPos = pos+6; 

        } 

        else{ 

          ch = (char)Integer.parseInt(src.substring(pos+1,pos+3),16); 

          tmp.append(ch); 

          lastPos = pos+3; 

        } 

      } 

      else{ 

        if(pos == -1){ 

          tmp.append(src.substring(lastPos)); 

          lastPos=src.length(); 

        } 

        else{ 

          tmp.append(src.substring(lastPos,pos)); 

          lastPos=pos; 

        } 

      } 

    } 

    return tmp.toString(); 

  } 

  

  public static void main(String[] args) { 

    String tmp=\"~!@#$%^&*()_+|=-,./?><;'][{}\"\"; 

    System.out.println(\"testing escape : \"+tmp); 

    tmp =escape(tmp); 

    System.out.println(tmp); 

    System.out.println(\"testing unescape :\"+tmp); 

    System.out.println(unescape(tmp)); 

  } 





Struts+Spring+Hibernate练习(完整) 

大 | 中 | 小   [2006/03/04 17:18 | 分类: Java,J2EE | by NetFetch ] 

Struts+Spring+Hibernate练习(完整) 

很多其它 Struts+Spring+Hibernate 相关的文章: 

选择JSF不选Struts的十大理由 

Struts+Spring+Hibernate练习(完整) 

struts+spring+hibernate之间的关系与区别(转) 

史上最简单的struts+spring+hibernate配置实例(修订版) 



Struts+Spring+Hibernate练习 工具: 

    Eclipse3.1、MyEclipse4.03、Tomcat5.5.9、Properties Editor插件、MySql4.1.13 

新建project:名称为 login 

创建Struts框架 



创建 index.jsp,添加一链接指向 login.jsp 

按下Ctrl + N,创建 login.jsp、LoginAction,使用MyEclipse的向导就能够了,记得选对正确的版本号 



在ActionForm配置页中选择类型为动态Form,并继承于DynaValidatorForm,新增两个属性:username、password,在创建jsp文件打上钩,将路径改为/login.jsp,然后下一步,改LoginAction的Input source改为/login.jsp,点击完毕 



按下Ctrl + N 创建一个forwards,记得选对正确的版本号 

name 输入 indexGo 

路径选择 /index.jsp 



配置validator 

先加入Struts插件,使用向导 

Plugin class : org.apache.struts.validator.ValidatorPlugIn 

Property : pathnames 

Value : /WEB-INF/validator-rules.xml,/WEB-INF/validation.xml 

这里须要两个xml文件 

如今创建“validation.xml” 文件 



在这里说明一点,我使用MyEclipse创建的Struts框架中缺少了validator-rules.xml文件,须要动复制到WEB-INF文件夹中 

此文件能够到http://struts.apache.org/下载 



文件内容例如以下: 



编辑资源文件“ApplicationResources.properties” 

添加下面内容 

prompt.username=User Name 

prompt.password=User Password 

errors.required={0} is required. 

再创建中文件资源文件“ApplicationResources_zh_CN.properties” 

添加下面内容 

prompt.username=用户名称 

prompt.password=登陆password 

errors.required={0} 必需填写! 

改动struts-config.xml文件 

在下面位置添加绿色字体部份 



          attribute="loginForm" 

      input="/login.jsp" 

      name="loginForm" 

      path="/login" 

      scope="request" 

      validate="true" 

      type="com.test.struts.action.LoginAction" /> 

这里说明提交的数据必需经过验证,而验证则是通过validator框架进行的。 



改动LoginAction.java文件的execute方法,内容例如以下 

public ActionForward execute( 

  ActionMapping mapping, 

  ActionForm form, 

  HttpServletRequest request, 

  HttpServletResponse response) { 

  DynaValidatorForm loginForm = (DynaValidatorForm) form; 

  String username=loginForm.getString("username"); 

  String password=loginForm.getString("password"); 

  if(username.equals("test")||password.equals("test")){ 

   return mapping.findForward("indexGo"); 

  }else{ 

   return mapping.getInputForward(); 

  } 



如今再改动一下login.jsp 

添加下面绿色字体部份: 

当中charset=UTF-8 是使用UTF-8的字符编码,这也是为了支持国际化而使用的。 



好了,如今能够启动Tomcat进行測试了 

http://localhost/login/ 这里说明一下,我的Tomcat已经装port号改为80了,所以就不必使用http://localhost:8080/login/这个方案了。 



假设不输入不论什么数据而直接提交表单的话就能够看到效果了。 



好了,假设没有什么问题的话就继续往下看吧,假设有问题的话就得往上看了^_^ 



如今创建Spring框架了,在这里我将Spring所有的包所有载入进去,由于我还不知道详细用到哪些类,所有加进去方便点 



单选框选第二个,这种话全部的类库和标签等都将复制到项目中去,这样方便以后的布署 

下一步后是创建配置文件,将文件放到“WebRoot/WEB-INF”文件夹下,文件名为“applicationContext.xml” 





配置struts-config.xml文件,加入(spring)的插件 

  

改动LoginAction配置 



原: 

      attribute="loginForm" 

      input="/login.jsp" 

      name="loginForm" 

      path="/login" 

      scope="request" 

      validate="true" 

      type="com.test.struts.action.LoginAction" /> 

改为: 

      attribute="loginForm" 

      input="/login.jsp" 

      name="loginForm" 

      path="/login" 

      scope="request" 

      validate="true" 

      type="org.springframework.web.struts.DelegatingActionProxy" /> 

绿色字体部份为改动内容 

这里将使用spring的代理器来对Action进行控制 



当提交到/login.do是将控制权交给了spring,然后由spring来决定是否转回到struts的Action 

如今来配置spring 

绿色字体是关于转交控制权的配置内容 



属性singleton="false",指明了Action 的实例获取方式为每次又一次创建。攻克了Struts中令人诟病的线程安全问题(Struts中,由一个Action实例处理全部的请求,这就导致了类公用资源在并发请求中的线程同步问题。)(摘自spring开发指南) 



这时假设你要进行測试也是能够的,只是为了省点时间就不进行測试了。 

  

建立数据库在 这里我使用的是mysql4.1.13 



Create TABLE `user` ( 

  `ID` int(11) NOT NULL auto_increment, 

  `USERNAME` varchar(50) NOT NULL default '', 

  `PASSWORD` varchar(50) NOT NULL default '', 

  PRIMARY KEY  (`ID`) 

) ENGINE=MyISAM DEFAULT CHARSET=latin1; 



加入记录 insert into user (USERNAME,PASSWORD) values ('test','test') 



创建Hibernate框架 

在配置界面中配置数据库的连接部份,重要的是点击链接将jdbc复制到lib文件夹中 

使用MyEclipse的数据Database Explorer工具创建User.hmb.xml、AbstractUser.java、User.java映射文件 

创建完毕后能够将自己主动生成的hibernate.cfg.xml删除 



创建UserDAO.java、UserDAOImp.java 

UserDAO.java 



public interface UserDAO { 



   public abstract boolean isValidUser(String username, String password); 









UserDAOImp.java 

import java.util.List; 

import org.springframework.orm.hibernate3.support.HibernateDaoSupport; 

import com.test.Hibernate.SessionFactory; 

public class UserDAOImp extends HibernateDaoSupport implements UserDAO { 

    private SessionFactory sessionFactory; 

    private static String hql = "from User u where u.username=? "; 

    public boolean isValidUser(String username, String password) { 

       List userList = this.getHibernateTemplate().find(hql, username); 

       if (userList.size() > 0) { 

           return true; 

       } 



       return false; 

    } 









改动LoginAction.java文件,使用userDao的方法来进行用户验证 

package com.test.struts.action; 



import javax.servlet.http.HttpServletRequest; 

import javax.servlet.http.HttpServletResponse; 



import org.apache.struts.action.Action; 

import org.apache.struts.action.ActionForm; 

import org.apache.struts.action.ActionForward; 

import org.apache.struts.action.ActionMapping; 

import org.apache.struts.validator.DynaValidatorForm; 



import com.test.UserDAO; 



public class LoginAction extends Action { 

private UserDAO userDAO; 

public UserDAO getUserDAO() { 

  return userDAO; 





public void setUserDAO(UserDAO userDAO) { 

  this.userDAO = userDAO; 





public ActionForward execute(ActionMapping mapping, ActionForm form, 

   HttpServletRequest request, HttpServletResponse response) { 

  DynaValidatorForm loginForm = (DynaValidatorForm) form; 

  // TODO Auto-generated method stub 

  String username = (String) loginForm.get("username"); 

  String password = (String) loginForm.get("password"); 

  loginForm.set("password", null); 

  if (userDAO.isValidUser(username,password)) { 

   return mapping.findForward("indexGo"); 

  } else { 

   return mapping.getInputForward(); 

  } 





绿色字体为改动部份 



如今剩下最后的spring配置了 

  

   com.mysql.jdbc.Driver  

  

   jdbc:mysql://localhost/test 

    

   root 

    

   root 

  

    com/test/Hibernate/User.hbm.xml 

    

    org.hibernate.dialect.MySQLDialect 

    true 

    

    PROPAGATION_REQUIRED 

    PROPAGATION_REQUIRED,readOnly 

    PROPAGATION_REQUIRED,readOnly 





如今能够进行測试了! 



在编写代码有配置内容时一定要注意 hibernate 和 hibernate3 ,这两个包的名字就仅仅差一个字,千万不要有错,否则找错误但是非常难的。 



 问题描写叙述: 



  为管理岗位业务培训信息,建立3个表: 

  S (S#,SN,SD,SA) S#,SN,SD,SA 分别代表学号、学员姓名、所属单位、学员年龄 

  C (C#,CN ) C#,CN 分别代表课程编号、课程名称 

  SC ( S#,C#,G ) S#,C#,G 分别代表学号、所选修的课程编号、学习成绩 

  1. 使用标准SQL嵌套语句查询选修课程名称为’税收基础’的学员学号和姓名 



  --实现代码: 



  Select SN,SD FROM S Where [S#] IN( Select [S#] FROM C,SC Where C.[C#]=SC.[C#] AND CN=N'税收基础')  



  2. 使用标准SQL嵌套语句查询选修课程编号为’C2’的学员姓名和所属单位 



  --实现代码: 



  Select S.SN,S.SD FROM S,SC Where S.[S#]=SC.[S#] AND SC.[C#]='C2' 



  3. 使用标准SQL嵌套语句查询不选修课程编号为’C5’的学员姓名和所属单位 



  --实现代码: 



  Select SN,SD FROM S Where [S#] NOT IN( Select [S#] FROM SC 

 Where [C#]='C5') 



  4. 使用标准SQL嵌套语句查询选修所有课程的学员姓名和所属单位 

http://www.ad0.cn/netfetch/ 

  --实现代码: 



  Select SN,SD FROM S Where [S#] IN( Select [S#] FROM SC RIGHT JOIN 

 C ON SC.[C#]=C.[C#] GROUP BY [S#] HAVING COUNT(*)=COUNT([S#])) 



  5. 查询选修了课程的学员人数 



  --实现代码: 



  Select 学员人数=COUNT(DISTINCT [S#]) FROM SC 



  6. 查询选修课程超过5门的学员学号和所属单位 



  --实现代码: 

  Select SN,SD FROM S Where [S#] IN( Select [S#] FROM SC GROUP BY [S#] HAVING COUNT(DISTINCT [C#])>5) 

      题目2 



  问题描写叙述: 

  已知关系模式: 

  S (SNO,SNAME) 学生关系。SNO 为学号,SNAME 为姓名 

  C (CNO,CNAME,CTEACHER) 课程关系。CNO 为课程号,CNAME 为课程名,CTEACHER 为任课教师 

  SC(SNO,CNO,SCGRADE) 选课关系。SCGRADE 为成绩 

   

1. 找出没有选修过“李明”老师讲授课程的全部学生姓名 



  --实现代码: 



  Select SNAME FROM S Where NOT EXISTS( Select * FROM SC,C Where SC.CNO=C.CNO  AND CNAME='李明' AND SC.SNO=S.SNO) 



  2. 列出有二门以上(含两门)不及格课程的学生姓名及其平均成绩 



  --实现代码: 



  Select S.SNO,S.SNAME,AVG_SCGRADE=AVG(SC.SCGRADE)  FROM S,SC,( 

 Select SNO FROM SC Where SCGRADE<60 GROUP BY SNO HAVING COUNT(DISTINCT CNO)>=2 )A Where S.SNO=A.SNO AND SC.SNO=A.SNO GROUP BY S.SNO,S.SNAME 



  3. 列出既学过“1”号课程,又学过“2”号课程的全部学生姓名 



  --实现代码: 



  Select S.SNO,S.SNAME FROM S,( Select SC.SNO FROM SC,C Where SC.CNO=C.CNO AND C.CNAME IN('1','2') GROUP BY SNO HAVING COUNT(DISTINCT CNO)=2 )SC Where S.SNO=SC.SNO 



  4. 列出“1”号课成绩比“2”号同学该门课成绩高的全部学生的学号 



  --实现代码: 

  Select S.SNO,S.SNAME FROM S,( Select SC1.SNO FROM SC SC1,C C1,SC SC2,C C2 Where SC1.CNO=C1.CNO AND C1.NAME='1' AND SC2.CNO=C2.CNO AND C2.NAME='2' AND SC1.SCGRADE>SC2.SCGRADE )SC Where S.SNO=SC.SNO 



  5. 列出“1”号课成绩比“2”号课成绩高的全部学生的学号及其“1”号课和“2”号课的成绩 



  --实现代码: 



  Select S.SNO,S.SNAME,SC.[1号课成绩],SC.[2号课成绩] FROM S,( 

 Select SC1.SNO,[1号课成绩]=SC1.SCGRADE,[2号课成绩]=SC2.SCGRADE FROM SC SC1,C C1,SC SC2,C C2 Where SC1.CNO=C1.CNO AND C1.NAME='1' AND SC2.CNO=C2.CNO AND C2.NAME='2' AND SC1.SCGRADE>SC2.SCGRADE 

 )SC Where S.SNO=SC.SNO 

上一篇:lokijs


下一篇:设置DIV隐藏与显示,表格滑动条