zoukankan      html  css  js  c++  java
  • 超长知识总结

    一、java基础

      1  Java面向对象
      2 1.        super()与this()的区别?
      3 This():当前类的对象,super父类对象。
      4 
      5 Super():在子类访问父类的成员和行为,必须受类继承规则的约束
      6 
      7 而this他代表当前对象,当然所有的资源都可以访问.
      8 
      9 在构造函数中,如果第一行没有写super(),编译器会自动插入.但是如果父类没有不带参数的构造函数,或这个函数被私有化了(用private修饰).此时你必须加入对父类的实例化构造.而this就没有这个要求,因为它本身就进行实例化的构造.
     10 而在方法中super和this使用的方法就差不多了.只不过super 要考虑是否能访问其父类的资源.
     11 
     12  
     13 
     14 2.        作用域public,protected,private,以及不写时的区别?
     15 ?         Public:不同包、同一包、类内都可用
     16 
     17 ?         Private:类内
     18 
     19 ?         Protected: 不同包的子类、同一包、类内都可用
     20 
     21 ?         不写时:同一包内、类内
     22 
     23 3.        编程输出如下图形。
     24 * * * * *
     25 
     26 * * * *
     27 
     28 * * *
     29 
     30 * *
     31 
     32 *
     33 
     34 代码如下:
     35 
     36 public class Print {
     37 
     38     public static void main(String[] args) {
     39 
     40        for (int i = 0; i < 5; i++) {
     41 
     42            for (int j = 5; j > i; j--) {
     43 
     44               System.out.print("*");
     45 
     46            }
     47 
     48            System.out.println();
     49 
     50        }
     51 
     52     }
     53 
     54 }
     55 
     56 4.        JAVA的事件委托机制和垃圾回收机制
     57 java 事件委托机制的概念,一个源产生一个事件并将它送到一个或多个监听器那里。在这种方案中,监听器简单的等待,直到它收到一个事件。一旦事件被接受,监听器将处理这个事件,然后返回。
     58 
     59 垃圾回收机制 垃圾收集是将分配给对象但不再使用的内存回收或释放的过程。如果一个对象没有指向它的引用或者其赋值为null,则次对象适合进行垃圾回收
     60 
     61  
     62 
     63 5.        在JAVA中,如何跳出当前的多重嵌套循环?
     64 用break; return 方法。
     65 
     66 6.        什么是java序列化,如何实现java序列化?(写一个实例)
     67 序列化:
     68 
     69     可以将一个对象保存到一个文件,所以可以通过流的方式在网络上传输,可以将文件的内容读取,转化为一个对象。
     70 
     71  
     72 
     73  
     74 
     75 处理对象流的机制,所谓对象流也就是将对象的内容进行流化。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了解决在对对象流进行读写操作时所引发的问题。
     76 
     77 序列化的实现:
     78 
     79 将需要被序列化的类实现Serializable接口,该接口没有需要实现的方法,implements Serializable只是为了标注该对象是可被序列化的,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。
     80 
     81  
     82 
     83 7.        一个".java"源文件中是否可以包括多个类(不是内部类)?有什么限制?
     84 可以。如果这个类的修饰符是public,其类名与文件名必须相同。
     85 
     86 8.        排序都有哪几种方法?请列举。用JAVA实现一个快速排序?
     87 排序的方法有:插入排序(直接插入排序、希尔排序),交换排序(冒泡排序、快速排序),选择排序(直接选择排序、堆排序),归并排序,分配排序(箱排序、基数排序)
     88 
     89 快速排序的伪代码。
     90 
     91 9.        Overload和Override的区别。Overloaded的方法是否可以改变返回值的类型?
     92 方法的
     93 
     94 重写Override,子类覆盖父类的方法,将子类传与父类的引用调用的还是子类的方法。
     95 
     96 重载Overloading 一个类多个方法,名称相同,参数个数类型不同。
     97 
     98 两者都是Java多态性的不同表现。
     99 
    100 Overloaded的方法是可以改变返回值的类型。
    101 
    102  
    103 
    104 1, public class Ctest()
    105 
    106 {
    107 
    108     Public static void main()
    109 
    110 {
    111 
    112 System.out.prinln(8+8+”88”+8+8);
    113 
    114 }
    115 
    116 }
    117 
    118  
    119 
    120 168888
    121 
    122 10.    Final类有什么特点?
    123        属性常量
    124 
    125        方法不可以overridding
    126 
    127        类不可以继承
    128 
    129 11.    继承时候类的执行顺序问题,一般都是选择题,问你将会打印出什么? 
    130 答:父类: 
    131 
    132 package test; 
    133 
    134 public class FatherClass 
    135 
    136 { 
    137 
    138 public FatherClass() 
    139 
    140 { 
    141 
    142 System.out.println("FatherClass Create"); 
    143 
    144 } 
    145 
    146 } 
    147 
    148 子类: 
    149 
    150 package test; 
    151 
    152 import test.FatherClass; 
    153 
    154 public class ChildClass extends FatherClass 
    155 
    156 { 
    157 
    158 public ChildClass() 
    159 
    160 { 
    161 
    162 System.out.println("ChildClass Create"); 
    163 
    164 } 
    165 
    166 public static void main(String[] args) 
    167 
    168 { 
    169 
    170 FatherClass fc = new FatherClass(); 
    171 
    172 ChildClass cc = new ChildClass(); 
    173 
    174 } 
    175 
    176 } 
    177 
    178 输出结果: 
    179 
    180 C:>java test.ChildClass 
    181 
    182 FatherClass Create 
    183 
    184 FatherClass Create 
    185 
    186 ChildClass Create
    187 
    188 12.    内部类的实现方式? 
    189 答:示例代码如下: 
    190 
    191 package test; 
    192 
    193 public class OuterClass 
    194 
    195 { 
    196 
    197 private class InterClass 
    198 
    199 { 
    200 
    201 Public Interlass() 
    202 
    203 { 
    204 
    205 System.out.println("InterClass Create"); 
    206 
    207 } 
    208 
    209 } 
    210 
    211 public OuterClass() 
    212 
    213 { 
    214 
    215 InterClass ic = new InterClass(); 
    216 
    217 System.out.println("OuterClass Create"); 
    218 
    219 } 
    220 
    221 public static void main(String[] args) 
    222 
    223 { 
    224 
    225 OuterClass oc = new OuterClass(); 
    226 
    227 } 
    228 
    229 } 
    230 
    231 输出结果: 
    232 
    233 C:>java test/OuterClass 
    234 
    235 InterClass Create 
    236 
    237 OuterClass Create 
    238 
    239 13.    用JAVA实现一种排序,JAVA类实现序列化的方法(二种)?
    240 14.     如在COLLECTION框架中,实现比较要实现什么样的接口? 
    241 15.  用插入法进行排序代码如下 
    242 package test; 
    243 
    244 import java.util.*; 
    245 
    246 class InsertSort 
    247 
    248 { 
    249 
    250 ArrayList al; 
    251 
    252 public InsertSort(int num,int mod) 
    253 
    254 { 
    255 
    256 al = new ArrayList(num); 
    257 
    258 Random rand = new Random(); 
    259 
    260 System.out.println("The ArrayList Sort Before:"); 
    261 
    262 for (int i=0;i<num ;i++ ) 
    263 
    264 { 
    265 
    266 al.add(new Integer(Math.abs(rand.nextInt()) % mod + 1)); 
    267 
    268 System.out.println("al["+i+"]="+al.get(i)); 
    269 
    270 } 
    271 
    272 } 
    273 
    274 public void SortIt() 
    275 
    276 { 
    277 
    278 Integer tempInt; 
    279 
    280 int MaxSize=1; 
    281 
    282 for(int i=1;i<al.size();i++) 
    283 
    284 { 
    285 
    286 tempInt = (Integer)al.remove(i); 
    287 
    288 if(tempInt.intValue()>=((Integer)al.get(MaxSize-1)).intValue()) 
    289 
    290 { 
    291 
    292 al.add(MaxSize,tempInt); 
    293 
    294 MaxSize++; 
    295 
    296 System.out.println(al.toString()); 
    297 
    298 } else { 
    299 
    300 for (int j=0;j<MaxSize ;j++ ) 
    301 
    302 { 
    303 
    304 if 
    305 
    306  
    307 
    308 (((Integer)al.get(j)).intValue()>=tempInt.intValue()) 
    309 
    310 { 
    311 
    312 al.add(j,tempInt); 
    313 
    314 MaxSize++; 
    315 
    316 System.out.println(al.toString()); 
    317 
    318 break; 
    319 
    320 } 
    321 
    322 } 
    323 
    324 } 
    325 
    326 } 
    327 
    328 System.out.println("The ArrayList Sort After:"); 
    329 
    330 for(int i=0;i<al.size();i++) 
    331 
    332 { 
    333 
    334 System.out.println("al["+i+"]="+al.get(i)); 
    335 
    336 } 
    337 
    338 } 
    339 
    340 public static void main(String[] args) 
    341 
    342 { 
    343 
    344 InsertSort is = new InsertSort(10,100); 
    345 
    346 is.SortIt(); 
    347 
    348 } 
    349 
    350 } 
    351 
    352  
    353 
    354  
    355 
    356 JAVA类实现序例化的方法是实现java.io.Serializable接口 
    357 
    358 Collection框架中实现比较要实现Comparable 接口和 Comparator 接口
    359 
    360  
    361 
    362 16.    编程:编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。 但是要保证汉字不被截半个,如"我ABC"4,应该截为"我AB",输入"我ABC汉DEF",6,应该输出为"我ABC"而不是"我ABC+汉的半个"363 答:代码如下: 
    364 
    365 public static void split(String source,int num) throws Exception
    366 
    367     {
    368 
    369         int k=0;
    370 
    371         String temp="";
    372 
    373         for (int i = 0; i <source.length(); i++)
    374 
    375         {   
    376 
    377             byte[] b=(source.charAt(i)+"").getBytes();
    378 
    379             k=k+b.length;
    380 
    381             if(k>num)
    382 
    383             {
    384 
    385                 break;
    386 
    387             }
    388 
    389             temp=temp+source.charAt(i);         
    390 
    391         }   
    392 
    393         System.out.println(temp);
    394 
    395     }
    396 
    397  
    398 
    399 15、Java编程,打印昨天的当前时刻
    400 public class YesterdayCurrent{
    401 
    402 public void main(String[] args){
    403 
    404 Calendar cal = Calendar.getInstance();
    405 
    406 cal.add(Calendar.DATE, -1);
    407 
    408 System.out.println(cal.getTime());
    409 
    410 }
    411 
    412 } 
    413 
    414 16、文件读写,实现一个计数器
    415 public int getNum(){
    416 
    417 int i = -1;
    418 
    419 try{
    420 
    421 String stri="";
    422 
    423 BufferedReader in = new BufferedReader(new FileReader(f));
    424 
    425 while((stri=in.readLine())!=null){
    426 
    427 i = Integer.parseInt(stri.trim());
    428 
    429 }
    430 
    431 in.close();
    432 
    433 }catch(Exception e){
    434 
    435 e.printStackTrace();
    436 
    437 }
    438 
    439 return i;
    440 
    441 }
    442 
    443 public void setNum(){
    444 
    445 int i = getNum();
    446 
    447 i++; 
    448 
    449 try{
    450 
    451 PrintWriter out=new PrintWriter(new BufferedWriter(new FileWriter(f,false))); 
    452 
    453 out.write(String.valueOf(i)); //可能是编码的原因,如果直接写入int的话,将出现java编码和windows编码的混乱,因此此处写入的是String
    454 
    455 out.close() ;
    456 
    457 }catch(Exception e){
    458 
    459 e.printStackTrace();
    460 
    461 }
    462 
    463 } 
    464 
    465  
    466 
    467 17、指出下面程序的运行结果。
    468 class A{
    469 static{
    470 System.out.print("1");
    471 }
    472 public A(){
    473 System.out.print("2");
    474 }
    475 }
    476 class B extends A{
    477 static{
    478 System.out.print("a");
    479 }
    480 public B(){
    481 System.out.print("b");
    482 } 
    483 }
    484 public class Hello{
    485 public static void main(String[] ars){
    486 A ab = new B(); //执行到此处,结果: 1a2b
    487 ab = new B(); //执行到此处,结果: 1a2b2b
    488 }
    489 }
    490 
    491   注:类的static 代码段,可以看作是类首次加载(被虚拟机加载)执行的代码,而对于类的加载,首先要执行其基类的构造,再执行其本身的构造
    492 
    493 18、抽象类和接口的区别?
    494 (1)接口可以被多重implements,抽象类只能被单一extends
    495 
    496 (2)接口只有定义,抽象类可以有定义和实现
    497 
    498 (3)接口的字段定义默认为:public static final, 抽象类字段默认是"friendly"(本包可见)
    499 
    500 当功能需要累积时用抽象类,不需要累积时用接口。
    501 
    502 19、什么是类的返射机制?
    503 通过类(Class对象),可以得出当前类的fields、method、construtor、interface、superClass、modified等,同是可以通过类实例化一个实例、设置属性、唤醒方法。Spring中一切都是返射、struts、hibernate都是通过类的返射进行开发的。
    504 
    505 20、类的返射机制中的包及核心类?
    506 ?  java.lang.Class
    507 
    508 ?  java.lang.refrection.Method
    509 
    510 ?  java.lang.refrection.Field
    511 
    512 ?  java.lang.refrection.Constructor
    513 
    514 ?  java.lang.refrection.Modifier
    515 
    516 ?  java.lang.refrection.Interface
    517 
    518 21、得到Class的三个过程是什么?
    519 对象.getClass()
    520 
    521         类.class或Integer.type(int)  Integer.class(java.lang.Integer)
    522 
    523         Class.forName();
    524 
    525 22、如何唤起类中的一个方法?
    526 产生一个Class数组,说明方法的参数
    527 
    528 通过Class对象及方法参数得到Method
    529 
    530 通过method.invoke(实例,参数值数组)唤醒方法
    531 
    532 23、如何将数值型字符转换为数字(Integer,Double)?
    533 Integer.parseInt(“1234”)
    534 
    535 Double.parseDouble(“123.2”)
    536 
    537 24、如何将数字转换为字符?
    538 1+””
    539 
    540 1.0+””
    541 
    542 25、如何去小数点前两位,并四舍五入。
    543 double d=1256.22d;
    544 
    545 d=d/100;
    546 
    547 System.out.println(Math.round(d)*100);
    548 
    549 26、如何取得年月日,小时分秒?
    550 Calendar c=Calendar.getInstance();
    551 
    552         c.set(Calendar.YEAR,2004);
    553 
    554         c.set(Calendar.MONTH,0);
    555 
    556         c.set(Calendar.DAY_OF_MONTH,31);
    557 
    558         System.out.println(c.get(Calendar.YEAR)+"  "+(c.get(Calendar.MONTH)+1)+"  "+c.get(Calendar.DAY_OF_MONTH));
    559 
    560 27、如何取得从1970年到现在的毫秒数
    561 Java.util.Date dat=new Date();
    562 
    563 long now=dat.getTime();
    564 
    565 28、如何获取某个日期是当月的最后一天?
    566 当前日期加一天,若当前日期与结果的月份不相同,就是最后一天。
    567 
    568  
    569 
    570 取下一个月的第一天,下一个月的第一天-1
    571 
    572  
    573 
    574 public static void main(String[] args)
    575 
    576     {
    577 
    578         Calendar c=Calendar.getInstance();
    579 
    580         c.set(Calendar.YEAR,2004);
    581 
    582         c.set(Calendar.MONTH,0);
    583 
    584         c.set(Calendar.DAY_OF_MONTH,30);
    585 
    586         Calendar c1=(Calendar)c.clone();
    587 
    588         System.out.println(c.get(Calendar.YEAR)+"  "+(c.get(Calendar.MONTH)+1)+"  "+c.get(Calendar.DAY_OF_MONTH));
    589 
    590         
    591 
    592         c.add(Calendar.DAY_OF_MONTH,1);
    593 
    594         if(c.get(Calendar.MONTH)!=c1.get(Calendar.MONTH))
    595 
    596         {
    597 
    598             System.out.println("是最后一天");
    599 
    600         }
    601 
    602         else
    603 
    604         {
    605 
    606             System.out.println("不是取后一天");
    607 
    608             
    609 
    610         }
    611 
    612     } 
    613 
    614 29、如何格式化日期?
    615 Import java.text. SimpleDateFormat;
    616 
    617 SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
    618 
    619 Date dat=new Date();
    620 
    621 //把日期转化为字符串
    622 
    623 String str=sdf.format(dat);
    624 
    625 System.out.println(str);
    626 
    627 //将字符串转化为日期
    628 
    629 Java.util.Date d1=sdf.parse(“yyyy-mm-dd”);
    630 
    631 30、编码转换,怎样实现将GB2312编码的字符串转换为ISO-8859-1编码的字符串。
    632 String a=new String("中".getBytes("gb2312"),"iso-8859-1");
    633 
    634  
    635 
    636  
    637 
    638 String a=new String("中".getBytes("iso-8859-1"));
    639 
    640  
    641 
    642 32、String s = new String("xyz");创建了几个String Object?
    643 New了一个,”XYZ”本来又是一个
    644 
    645 两个
    646 
    647 33、float型float f=3.4是否正确?
    648 ?  报错,应当是float f=3.4f
    649 
    650 ?  如果是float f=3(整数)正确
    651 
    652 35、说出一些常用的类,包,接口,请各举5个
    653 常用的类:BufferedReader  BufferedWriter  FileReader  FileWirter  String  Integer
    654 
    655 常用的包:java.lang  java.awt  java.io  java.util  java.sql javax.xml javax.sevlet javax.ejb.  java.net  javax.faces  
    656 
    657 常用的接口: List  Map  Document  NodeList EjbObject EjbHome SessionBean  EntityBean
    658 
    659 36、java中会存在内存泄漏吗,请简单描述。
    660 会。如:int i,i2;  return (i-i2);   //when i为足够大的正数,i2为足够大的负数。结果会造成溢位,导致错误。
    661 
    662 37、java中实现多态的机制是什么?
    663        静态的多态:方法名相同,参数个数或类型不相同。(overloading)
    664 
    665        动态的多态:
    666 
    667               子类覆盖父类的方法,将子类的实例传与父类的引用调用的是子类的方法
    668 
    669               实现接口的实例传与接口的引用调用的实现类的方法。       
    670 
    671 38、垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?
    672 动态内存
    673 
    674         存放类实例
    675 
    676 静态内存
    677 
    678 类本身
    679 
    680 垃圾收集主要针对的是动态内存,一般当内存不够用时会进行垃圾收集。
    681 
    682 或通过System.gc()手动收集,但不保证一定执行。 
    683 
    684 39、静态变量和实例变量的区别?
    685 static i = 10; //常量
    686 
    687   class A a;  a.i =10;//可变
    688 
    689 静态方法可以调用静态变量。
    690 
    691 实现方法可以调用静态变量、实例变量
    692 
    693 41、是否可以从一个static方法内部发出对非static方法的调用?
    694 不可以,如果其中包含对象的method();不能保证对象初始化.
    695 
    696 42、写clone()方法时,通常都有一行代码,是什么?
    697 Clone 有缺省行为,super.clone();他负责产生正确大小的空间,并逐位复制。
    698 
    699 43、JAVA语言如何进行异常处理,关键字:throws,throw,try,catch,finally分别代表什么意义?在try块中可以抛出异常吗?
    700 Try:执行部分,产生异常
    701 
    702 Catch:捕捉异常
    703 
    704 Finally:不管有没有异常都执行
    705 
    706 Throws:在方法声明处声明要抛出的异常,调用者必须对其进行处理。
    707 
    708 Throw:抛出一个异常
    709 
    710  
    711 
    712 在try中可以抛出异常,一般与声明的异常相同。
    713 
    714  
    715 
    716 自定义异常要继承于Exception或Exception的子类
    717 
    718 45、冒泡排序法
    719 //相邻两个数比较,将最小或最大的放到后面,最后面数的不参与比较
    720 
    721 public class BubbleSort {
    722 
    723     private static int al[] = new int[10];
    724 
    725     public BubbleSort() {
    726 
    727        al[0]=2;
    728 
    729        al[1]=3;
    730 
    731        al[2]=23;
    732 
    733        al[3]=45;
    734 
    735        al[4]=1;
    736 
    737        al[5]=67;
    738 
    739        al[6]=23;
    740 
    741        al[7]=80;
    742 
    743        al[8]=35;
    744 
    745        al[9]=72;
    746 
    747     }
    748 
    749     public static void main(String[] args) {
    750 
    751        BubbleSort bs = new BubbleSort();
    752 
    753        System.out.println("排序前:");
    754 
    755        display(al);
    756 
    757        
    758 
    759        for(int i=0;i<al.length;i++) {
    760 
    761        
    762 
    763            for (int j = 0; j < al.length-i-1; j++) {
    764 
    765               
    766 
    767               if(al[j]>al[j+1]) {
    768 
    769                   swap(j,j+1);
    770 
    771               }
    772 
    773            }
    774 
    775        }
    776 
    777        System.out.println();
    778 
    779        System.out.println("排序后:");
    780 
    781        display(al);
    782 
    783     }
    784 
    785     private static void display(int[] al2) {
    786 
    787        for (int i = 0; i < al2.length; i++) {
    788 
    789            System.out.print(al2[i]+"  ");
    790 
    791        }
    792 
    793     }
    794 
    795     private static void swap(int i, int j) {
    796 
    797        int temp = al[i];
    798 
    799        al[i]= al[j];
    800 
    801        al[j] = temp;
    802 
    803     }
    804 
    805 }
    806 
    807 46、String and StringBuffer的区别?
    808 String:长度给定不可变,当多个字符串联合时要先转为StringBuffer,再联合,速度慢。
    809 
    810 StringBuffer:长度可变,可以将多个字符串值直接联合,效率高
    811 
    812 47、用java代码编写堆栈
    813 public class Stack {
    814 
    815  
    816 
    817     int[] data;
    818 
    819     int maxSize;
    820 
    821     int top;
    822 
    823     public Stack(int maxSize) {
    824 
    825        this.maxSize = maxSize;
    826 
    827        data = new int[maxSize];
    828 
    829        top = -1;
    830 
    831     }
    832 
    833     
    834 
    835     /**
    836 
    837      * 依次加入数据
    838 
    839      * @param data 要加入的数据
    840 
    841      * @return 添加是否成功
    842 
    843      */
    844 
    845     public boolean push(int data) {
    846 
    847        if(top+1== maxSize) {
    848 
    849            System.out.println("栈已满!");
    850 
    851            return false;
    852 
    853        }
    854 
    855        this.data[++top] = data;
    856 
    857        return true;
    858 
    859     }
    860 
    861     
    862 
    863     /**
    864 
    865      * 从栈中取出数据
    866 
    867      * @return 取出的数据
    868 
    869      */
    870 
    871     public int pop() throws Exception{
    872 
    873        if(top==-1) {
    874 
    875            throw new Exception("栈已空!");
    876 
    877        }
    878 
    879        return this.data[top--];
    880 
    881     }
    882 
    883     
    884 
    885     public static void main(String[] args) throws Exception {
    886 
    887        Stack stack=new Stack(1000);
    888 
    889        stack.push(1);
    890 
    891        stack.push(2);
    892 
    893        stack.push(3);
    894 
    895        stack.push(4);
    896 
    897        stack.push(5);
    898 
    899        while(stack.top>=0)
    900 
    901        {
    902 
    903            System.out.println(stack.pop());
    904 
    905        }      
    906 
    907     }
    908 
    909 }
    910 
    911 48、集合的作用是什么?
    912 数据的传送 增、删、改、查、constainsAll,可以存放不同类型的对象。
    913 
    914 49、集合的通用方法有那些?通用方法是什么?(操作)
    915 集合List 的遍历方法有:
    916 
    917 Iterator:
    918 
    919 Enumeration
    920 
    921 For
    922 
    923 Get
    924 
    925 set
    926 
    927 Collection的通用方法有:
    928 
    929     Iterator()
    930 
    931     Add()
    932 
    933     Clear();
    934 
    935     remove()
    936 
    937     
    938 
    939 50、说出ArrayList,Vector, LinkedList的存储性能和特性HashMap和Hashtable的区别
    940 ArrayList Vector:以数组的方式存储,增、删慢,查、改快
    941 
    942     ArrayList:线程不安全,速度快
    943 
    944     ArrayList:线程安全,速度慢(synchoronized)
    945 
    946 LikedList: 以单链表的方式存储,增、删快,查、改慢
    947 
    948  
    949 
    950 HashMap与Hashtable都实现的Map接口,HashTable线程安全,HashMap线程不安全。
    951 
    952 51、Collection 和 Collections的区别。
    953 Collection是集合的根接口,其下有set及list
    954 
    955 Collections是集合的算法。
    956 
    957 52、Set里的元素是不能重复的,那么用什么方法来区分重复与否呢? 是用==还是equals()? 它们有何区别?用contains来区分是否有重复的对象。还是都不用。
    958  
    959 
    960 在比较时先调用hashCode方法,如果不相同,证明不相等。
    961 
    962 如果相同,再调用equals方法,如果equals方法相同,证明相等,不相同,证明不相等。
    963 
    964  
    965 
    966 ==:主要用在基本数据类型及引用
    967 
    968 Equals:主要是对象或对象引用的比较。
    969 
    970  
    971 
    972 集合中是否包含某一个元素用contains来判断。
    973 
    974 53、List, Set, Map是否继承自Collection接口?
    975 List,set继承于Collection
    976 
    977 Map没有继承于Collection,其相对是独立的。
    978 
    979 属于Collection类型的对象,可以通过构造函数将一个集合构造成另外一个集合。
    View Code

    附加

       1 1 什么是Java、Java2、JDK?JDK后面的1.3、1.4.2版本号又是怎么回事? 
       2 
       3   答:Java是一种通用的,并发的,强类型的,面向对象的编程语言(摘自Java规范第二版) JDK是Sun公司分发的免费Java开发工具,正式名称为J2SDK(Java2 Softw are Develop Kit)。 
       4 
       5  
       6 
       7 2 什么是JRE/J2RE? 
       8 
       9   答:J2RE是Java2 Runtime Environment,   即Java运行环境,有时简称JRE。 
      10 
      11 如果你只需要运行Java程序或Applet, 下载并安装它即可。如果你要自行开发Java软件,请下载JDK。在JDK中附带有J2RE。
      12 
      13   注意由于Microsoft对Java的支持不完全,请不要使用IE自带的虚拟机来运行Applet,务必安装一个J2RE或JDK。 
      14 
      15  
      16 
      17 3 学习Java用什么工具比较好? 
      18 
      19  答:作者建议首先使用JDK+文本编辑器,这有助你理解下列几个基础概念:path,classpath,package并熟悉基本命令:javac和java。并且下载和你的JDK版本一致的API帮助。 
      20 
      21   如果你不确定类或函数的用法,请先查阅API而不是发贴求助。 
      22 
      23   当你熟悉Java之后,你可以考虑换一个IDE。很多人推荐Jcreator,实际上Jcreator的功能还 是很弱的。 
      24 
      25   作者推荐eclipse,下载网址http://www.eclipse.org ;。因eclispe是免费的. 
      26 
      27  
      28 
      29 4 学习Java有哪些好的参考书? 
      30 
      31   答:作者首先推荐Thinking in Java,中文名《Java编程思想》,有中文版。该书第一章介绍了很多面向对象的编程思想,作为新手应当认真阅读。除此以外,O′relly出版社和Wrox出版社的书也不错。作者本人不喜欢大陆作者的书。也许你觉得英文太难,但是网上大多数资料都是英文的。另外,你需要经常查阅API,而那也是英文的。 
      32 
      33  
      34 
      35 5 Java和C++哪个更好? 
      36 
      37   答:这个问题是一个很不恰当的问题。你应该问:Java和C++哪个更适用于我的项目? 如果你不需要跨平台,不需要分布式,要强调程序的运行速度,C++更为适用。反之?你应当考虑Java。 
      38 
      39  
      40 
      41 6 什么是J2SE/J2EE/J2ME?   
      42 
      43   答:J2SE就是一般的Java。 
      44 
      45   J2ME是针对嵌入式设备的,比如Java手机,它有自己的SDK。而J2EE使用J2SE的SDK。 
      46 
      47   J2EE规范更多的是对J2EE服务器的要求和开发人员的约束。详情见后继《J2EE FAQ》。
      48 
      49 7 我写了第一个Java程序,应该如何编译/运行? 
      50 
      51   答:首先请将程序保存为xxx.java文件, 
      52 
      53   然后在dos窗口下使用javac xxx.java命令,你会发现该目录下多了一个xxx.class文件,再使用java xxx命令,你的java程序就开始运行了。 
      54 
      55  
      56 
      57 8 我照你说的做了,但是出现什么"′javac′ 不是内部或外部命令,也不是可运行的程序或批处理文件。"  58 
      59   答:你遇到了path问题。操作系统在一定的范围(path)内搜索javac.exe,但是没能找到。 
      60 
      61   请编辑你的操作系统环境变量,新增一个JAVA_HOME变量,设为你JDK的安装目录, 
      62 
      63   再编辑Path变量,加上一项 %JAVA_HOME%bin。 
      64 
      65   然后关掉并新开一个dos窗口,你就可以使用javac和java命令了。 
      66 
      67  
      68 
      69 9 环境变量怎么设置? 
      70 
      71   答:请向身边会设的人咨询。 java初学者必读-经验总结 这篇文章中比较详细的讲到 jdk开发中系统环境变量设置 以及相关 服务器配置等开发环境配置。
      72 
      73  
      74 
      75 10 javac xxx.java顺利通过了,但是java xxx的时候显示什么"NoClassDefFoundError"
      76 
      77   答:你遇到了classpath问题。java命令在一定的范围(classpath)内搜索你要用的class文件,但是未能找到。 
      78 
      79   首先请确认你没有错敲成java xxx.class  80 
      81   其次,检查你的CLASSPATH环境变量,如果你设置了该变量又没有包含.(代表当前目录)你就会遇到这个问题。请在你的CLASSPATH环境变量中加入一项. 。另 
      82 
      83   外参见15。 
      84 
      85  
      86 
      87 11 我在java xxx的时候显示"Exception in thread "main" java.lang.NoSuchMethodError: main"  88 
      89   答:首先,在你的程序中每个java文件有且只能有一个public类, 
      90 
      91   这个类的类名必须和文件名的大小写完全一样。 
      92 
      93   其次,在你要运行的类中有且只能有一个public static void main(String[] args)方法,这个方法就是你的主程序。 
      94 
      95  
      96 
      97 12 package是什么意思?怎么用? 
      98 
      99   答:为了唯一标识每个类并分组,java使用了package的概念。 
     100 
     101   每个类都有一个全名,例如String的全名是java.lang.String,其中java.lang是包名,String是短名。 
     102 
     103   这样,如果你也定义了String,你可以把它放在mypackage中, 
     104 
     105   通过使用全名mypackage.String和java.lang.String来区分这两个类。 
     106 
     107   同时,将逻辑上相关的类放在同一个包中,可以使程序结构更为清楚。 
     108 
     109  
     110 
     111   你要做的就是在java文件开头加一行"package mypackage;" 112 
     113   注意包没有嵌套或包含关系,A包和A.B包对java命令来说是并列的两个包
     114 
     115  
     116 
     117 13 我没有声明任何package会怎么样? 
     118 
     119   答:你的类被认为放在默认包中。这时全名和短名是一致的。 
     120 
     121  
     122 
     123 14 在一个类中怎么使用其他类? 
     124 
     125   答:如果你使用java.lang包中的类,不用做任何事。 
     126 
     127   如果你使用其他包中的类,使用import package1.class1; 或 import package2.*; 
     128 
     129   这里.*表示引入这个包中的所有类。然后在程序中你可以使用其他类的短名。 
     130 
     131   如果短名有冲突,使用全名来区分。 
     132 
     133  
     134 
     135 15 我用了package的时候显示"NoClassDefFoundError",但是我把所有package去掉的时候能正常运行。 
     136 
     137   答:将你的java文件按包名存放。 
     138 
     139   比如你的工作目录是/work,你的类是package1.class1,那么将它存放为/work/package1/class1.java。
     140 
     141   如果没有声明包,那么直接放在/work下。 
     142 
     143   在/work下执行javac package1/class1.java,再执行java package1.class1,你会发现 
     144 
     145   一切正常。
     146 
     147   另外,你可以考虑开始使用IDE。 
     148 
     149  
     150 
     151 16 我想把java编译成exe文件,该怎么做? 
     152 
     153   答:JDK只能将java源文件编译为class文件。 
     154 
     155   class文件是一种跨平台的字节码,必须依赖平台相关的JRE来运行。Java以此来实现跨平台,有些开发工具可以将java文件编译为exe文件。作者反对这种做法,因为这样就取消了跨平台性。 
     156 
     157   如果你确信你的软件只在Windows平台上运行,你可以考虑使用C++/C#来编程。 
     158 
     159  
     160 
     161 17 我在编译的时候遇到什么"deprecated API",是什么意思? 
     162 
     163   答:所谓deprecated是指已经?时,但是为了向前兼容起见仍然保留的方法?这些方法可能会在以后取消支持。你应当改用较新的方法。 
     164 
     165   一般在API里面会说明你应当用什么方法来代替之。 
     166 
     167  
     168 
     169 Java环境变量设置
     170 
     171 18 我怎么给java程序加启动参数,就像dir /p/w那样? 
     172 
     173   答:还记得public static void main(String[] args)吗?这里的args就是你的启动参数。 
     174 
     175   在运行时你输入java package1.class1 -arg1 -arg2,args中就会有两个String,一个是arg1,另一个是arg2。 
     176 
     177  
     178 
     179 19 我怎么从键盘输入一个int/double/字符串? 
     180 
     181   答:java的I/O操作比C++要复杂一点。如果要从键盘输入,样例代码如下: 
     182 
     183   BufferedReader cin = new BufferedReader( new InputStreamReader( System.in ) ) ; 
     184 
     185   String s = cin.readLine(); 
     186 
     187   这样你就获得了一个字符串,如果你需要数字的话再加上: 
     188 
     189   int n = Integer.parseInt( s ); 或者 double d = Double.parseDouble( s ); 
     190 
     191  
     192 
     193 20 我怎么输出一个int/double/字符串? 
     194 
     195   答:在程序开始写: 
     196 
     197   PrintWriter cout = new PrintWriter( System.out ); 需要时写:cout.print(n); 或者 out.println("hello")等等。 
     198 
     199  
     200 
     201 21 我发现有些书上直接用System.in和System.out输入输出,比你要简单得多。 
     202 
     203   答:java使用unicode,是双字节。而System.in和System.out是单字节的stream。 
     204 
     205   如果你要输入输出双字节文字比如中文,请使用作者的做法。 
     206 
     207  
     208 
     209 22 我怎么从文件输入一个int/double/字符串? 
     210 
     211   答:类似于从键盘输入,只不过换成 
     212 
     213   BufferedReader fin = new BufferedReader( new FileReader(" myFileName " ) ); 
     214 
     215   PrintWriter fout = new PrintWriter( new FileWriter(" myFileName " ) ); 
     216 
     217   另外如果你还没下载API,请开始下载并阅读java.io包中的内容。 
     218 
     219  
     220 
     221 23 我想读写文件的指定位置,该怎么办? 
     222 
     223   答:你肯定没有认真看API。java.io.RandomAccessFile可以满足你的需要。 
     224 
     225  
     226 
     227 24 怎么判断要读的文件已经到了尽头? 
     228 
     229   答:你肯定没有认真看API。在Reaer的read方法中明确说明返回-1表示流的结尾。 
     230 
     231 25 java里面怎么定义宏? 
     232 
     233   答:java不支持宏,因为宏代换不能保证类型安全。 
     234 
     235   如果你需要定义常量,可以将它定义为某个类的static final成员。参见26和30。 
     236 
     237  
     238 
     239 26 java里面没法用const。 
     240 
     241   答:你可以用final关键字。例如 final int m = 9。被声明为final的变量不能被再次赋值?final也可以用于声明方法或类,被声明为final的方法或类不能被继承 。 
     242 
     243   注意const是java的保留字以备扩充。 
     244 
     245  
     246 
     247 27 java里面也不能用goto。 
     248 
     249   答:甚至在面向过程的语言中你也可以完全不用goto。请检查你的程序流程是否合理。 
     250 
     251   如果你需要从多层循环中迅速跳出,java增强了(和C++相比)break和continue的功能,支持label。 
     252 
     253  
     254 
     255   例如: 
     256 
     257   outer : 
     258 
     259   while( ... ) 
     260 
     261   { 
     262 
     263   inner : 
     264 
     265   for( ... ) 
     266 
     267   { 
     268 
     269   ... break inner; ... 
     270 
     271   ... continue outer; ... 
     272 
     273   } 
     274 
     275   } 
     276 
     277   和const一样,goto也是java的保留字以备扩充。 
     278 
     279  
     280 
     281 28 java里面能不能重载操作符? 
     282 
     283   答:不能。String的+号是唯一一个内置的重载操作符。你可以通过定义接口和方法来实现类 
     284 
     285   似功能。 
     286 
     287  
     288 
     289 29 我new了一个对象,但是没法delete掉它。 
     290 
     291   答:java有自动内存回收机制,即所谓Garbarge Collector。你再也不用担心指针错误
     292 
     293  
     294 
     295 30 我想知道为什么main方法必须被声明为public static 296 
     297   答:声明为public是为了这个方法可以被外部调用,详情见面向对象篇37。 
     298 
     299   static是为了将某个成员变量/方法关联到类(class)而非实例(instance)。 
     300 
     301   你不需要创建一个对象就可以直接使用这个类的static成员, 
     302 
     303   在A类中调用B类的static成员可以使用B.staticMember的写法。 
     304 
     305   注意一个类的static成员变量是唯一的,被所有该类对象所共享的。 
     306 
     307  
     308 
     309 31 throw和throws有什么不同? 
     310 
     311   答:throws用于声明一个方法会抛出哪些异常。而throw是在方法体中实际执行抛出异常 
     312 
     313   的动作。 
     314 
     315   如果你在方法中throw一个异常,却没有在方法声明中声明之,编译器会报错。 
     316 
     317   注意Error和RuntimeException的子类是例外,无需特别声明。 
     318 
     319  
     320 
     321 32 什么是异常? 
     322 
     323   答:异常最早在Ada语言中引入,用于在程序中动态处理错误并恢复。 
     324 
     325   你可以在方法中拦截底层异常并处理之,也可以抛给更高层的模块去处理。 
     326 
     327   你也可以抛出自己的异常指示发生了某些不正常情况。常见的拦截处理代码如下: 
     328 
     329   try 
     330 
     331   { 
     332 
     333   ...... //以下是可能发生异常的代码 
     334 
     335   ...... //异常被抛出,执行流程中断并转向拦截代码。 
     336 
     337   ...... 
     338 
     339   } 
     340 
     341  
     342 
     343  
     344 
     345   catch(Exception1 e) //如果Exception1是Exception2的子类并要做特别处理,应排在 
     346 
     347   前面 
     348 
     349   { 
     350 
     351   //发生Exception1时被该段拦截 
     352 
     353   } 
     354 
     355   catch(Exception2 e) 
     356 
     357   { 
     358 
     359   //发生Exception2时被该段拦截 
     360 
     361   } 
     362 
     363   finally //这是可选的 
     364 
     365   { 
     366 
     367   //无论异常是否发生,均执行此段代码 
     368 
     369   } 
     370 
     371  
     372 
     373 33 final和finally有什么不同? 
     374 
     375   答:final请见26。finally用于异常机制,参见32。 
     376 
     377 34 extends和implements有什么不同? 
     378 
     379   答:extends用于(单)继承一个类(class),而implements用于实现一个接口(interface)。 
     380 
     381   interface的引入是为了部分地提供多继承的功能。 
     382 
     383   在interface中只需声明方法头,而将方法体留给实现的class来做。 
     384 
     385   这些实现的class的实例完全可以当作interface的实例来对待。 
     386 
     387   有趣的是在interface之间也可以声明为extends(单继承)的关系。 
     388 
     389  
     390 
     391 35 java怎么实现多继承? 
     392 
     393   答:java不支持显式的多继承。 
     394 
     395   因为在显式多继承的语言例如c++中,会出现子类被迫声明祖先虚基类构造函数的问题, 
     396 
     397  
     398 
     399   而这是违反面向对象的封装性原则的。 
     400 
     401   java提供了interface和implements关键字来部分地实现多继承。参见34。 
     402 
     403  
     404 
     405 36 abstract是什么? 
     406 
     407   答:被声明为abstract的方法无需给出方法体,留给子类来实现。 
     408 
     409   而如果一个类中有abstract方法,那么这个类也必须声明为abstract。 
     410 
     411   被声明为abstract的类无法实例化,尽管它可以定义构造方法供子类使用。 
     412 
     413  
     414 
     415 37 public,protected,private有什么不同? 
     416 
     417   答:这些关键字用于声明类和成员的可见性。 
     418 
     419   public成员可以被任何类访问, 
     420 
     421   protected成员限于自己和子类访问, 
     422 
     423   private成员限于自己访问。 
     424 
     425   Java还提供了第四种的默认可见性,当没有任何public,protected,private修饰时,成员是包内可见
     426 
     427   类可以用public或默认来修饰。 
     428 
     429  
     430 
     431 38 Override和Overload有什么不同? 
     432 
     433   答:Override是指父类和子类之间方法的继承关系,这些方法有着相同的名称和参数类型。 
     434 
     435   Overload是指同一个类中不同方法(可以在子类也可以在父类中定义)间的关系,这些方法有着相同的名称和不同的参数类型。 
     436 
     437  
     438 
     439 39 我继承了一个方法,但现在我想调用在父类中定义的方法。 
     440 
     441   答:用super.xxx()可以在子类中调用父类方法。 
     442 
     443  
     444 
     445 40 我想在子类的构造方法中调用父类的构造方法,该怎么办? 
     446 
     447   答:在子类构造方法的第一行调用super(...)即可。 
     448 
     449  
     450 
     451 41 我在同一个类中定义了好几个构造方法并且想在一个构造方法中调用另一个。 
     452 
     453   答:在构造方法第一行调用this(...)。 
     454 
     455  
     456 
     457 42 我没有定义构造方法会怎么样? 
     458 
     459   答:自动获得一个无参数的构造方法。 
     460 
     461  
     462 
     463 43 我调用无参数的构造方法失败了。 
     464 
     465   答:如果你至少定义了一个构造方法,就不再有自动提供的无参数的构造方法了。 
     466 
     467   你需要显式定义一个无参数的构造方法。 
     468 
     469  
     470 
     471 44 我该怎么定义类似于C++中的析构方法(destructor)? 
     472 
     473   答:提供一个void finalize()方法。在Garbarge Collector回收该对象时会调用该方法。 
     474 
     475   注意实际上你很难判断一个对象会在什么时候被回收。作者从未感到需要提供该方法。 
     476 
     477  
     478 
     479 45 我想将一个父类对象转换成一个子类对象该怎么做? 
     480 
     481   答:强制类型转换。如 
     482 
     483   public void meth(A a) 
     484 
     485   { 
     486 
     487   B b = (B)a; 
     488 
     489   } 
     490 
     491   如果a实际上并不是B的实例,会抛出ClassCastException。所以请确保a确实是B的实例 .
     492 
     493  
     494 
     495 46 其实我不确定a是不是B的实例,能不能分情况处理? 
     496 
     497   答:可以使用instanceof操作符。例如 
     498 
     499   if( a instanceof B ) 
     500 
     501   { 
     502 
     503   B b = (B)a; 
     504 
     505   } 
     506 
     507   else 
     508 
     509   { 
     510 
     511   ... 
     512 
     513   } 
     514 
     515  
     516 
     517 47 我在方法里修改了一个对象的值,但是退出方法后我发现这个对象的值没变! 
     518 
     519   答:很可能你把传入参数重赋了一个新对象,例如下列代码就会造成这种错误: 
     520 
     521   public void fun1(A a) //a是局部参数,指向了一个外在对象。 
     522 
     523   { 
     524 
     525   a = new A(); //a指向了一个新对象,和外在对象脱钩了。如果你要让a作为传 
     526 
     527   出变 
     528 
     529   量,不要写这一句。 
     530 
     531   a.setAttr(attr);//修改了新对象的值,外在对象没有被修改。 
     532 
     533   } 
     534 
     535   基本类型也会出现这种情况。例如: 
     536 
     537   public void fun2(int a) 
     538 
     539   { 
     540 
     541   a = 10;//只作用于本方法,外面的变量不会变化。 
     542 
     543   } 
     544 
     545 48 java能动态分配数组吗? 
     546 
     547   答:可以。例如int n = 3; Language[] myLanguages = new Language[n]; 
     548 
     549  
     550 
     551 49 我怎么知道数组的长度? 
     552 
     553   答:用length属性。如上例中的 myLanguages.length 就为 3 554 
     555  
     556 
     557 50 我还想让数组的长度能自动改变,能够增加/删除元素。 
     558 
     559   答:用顺序表--java.util.List接口。 
     560 
     561   你可以选择用ArrayList或是LinkedList,前者是数组实现,后者是链表实现。 
     562 
     563   例如: List list = new ArrayList(); 或是 List list = new LinkedList(); 。 
     564 
     565  
     566 
     567 51 什么是链表?为什么要有两种实现? 
     568 
     569   答:请补习数据结构。 
     570 
     571  
     572 
     573 52 我想用队列/栈。 
     574 
     575   答:用java.util.LinkedList。 
     576 
     577  
     578 
     579 53 我希望不要有重复的元素。 
     580 
     581   答:用集合--java.util.Set接口。例如:Set set = new HashSet()。 
     582 
     583  
     584 
     585 54 我想遍历集合/Map。 
     586 
     587   答:用java.util.Iterator。参见API。 
     588 
     589  
     590 
     591 55 我还要能够排序。 
     592 
     593   答:用java.util.TreeSet。例如:Set set = new TreeSet()。放进去的元素会自动排序。 
     594 
     595   你需要为元素实现Comparable接口,还可能需要提供equals()方法,compareTo()方法,hashCode()方法。 
     596 
     597  
     598 
     599 56 但是我想给数组排序。 
     600 
     601   答:java.util.Arrays类包含了sort等实用方法。 
     602 
     603  
     604 
     605 57 我想按不同方法排序。 
     606 
     607   答:为每种方法定义一个实现了接口Comparator的类并和Arrays综合运用。 
     608 
     609  
     610 
     611 58 Map有什么用? 
     612 
     613   答:存储key-value的关键字-值对,你可以通过关键字来快速存取相应的值。 
     614 
     615  
     616 
     617 59 set方法没问题,但是get方法返回的是Object。 
     618 
     619   答:强制类型转换成你需要的类型。参见45。 
     620 
     621  
     622 
     623 60 我要获得一个随机数。 
     624 
     625   答:使用java.util.Random类。 
     626 
     627  
     628 
     629 61 我比较两个String总是false,但是它们明明都是"abc" 630 
     631   答:比较String一定要使用equals或equalsIgnoreCase方法,不要使用 == 632 
     633   ==比较的是两个引用(变量)是否指向了同一个对象,而不是比较其内容。
     634 
     635 我的一个客户不知道该选用Struts还是JSF。就像你预料的那样,我通常会问:这2中框架之间有什么区别?当然,除了我的这个客户外很多人都面临这样的选择。
     636 
     637   
     638 
     639   总的来说,我建议在新项目中优先考虑JSF。虽然常常有一些商业上的因素迫使我们为现有的项目选择了Struts,而且那些解决方案还有待考验,但是,让我们面对一个事实:JSF比Struts好多了。
     640 
     641   
     642 
     643   下面是我选择JSF而不选Struts的十大理由:
     644 
     645   
     646 
     647   1.Components(组件)
     648 
     649   2.Render Kits
     650 
     651   3.Renderers
     652 
     653   4.Value Binding Expressions(值绑定表达式)
     654 
     655   5.Event Model(事件模型)
     656 
     657   6.Extensibility(可扩展性)
     658 
     659   7.Managed Beans(Dependency Injection 依赖注入)
     660 
     661   8.POJO Action Methods
     662 
     663   9.JSF is the standard Java-based web app framework (JSF是java web应用程序的标准框架)
     664 
     665   10.There's only one Struts(只有一个Struts)
     666 
     667   
     668 
     669   10.There's only one Struts(只有一个Struts)
     670 
     671      Struts 是一个开源产品,然而JSF是一个标准。这个细节常常被新的JSF学习者忽略,其实这是显而易见的,因为我们有多个JSF的实现。虽然JSF还很不成熟,但是我们已经有了2个优秀的JSF实现可以选择:Sun的参考实现和Apache的MyFaces。另一方面,我们只有一个Struts。
     672 
     673  
     674 
     675   9.JSF is the standard(JSF是标准) 
     676 
     677       J2EE 5.0要提供一个JSF的实现,这表明JSF不久将会无处不在。这可能与你无关,但是和工具供应商密切相关。现在大概有50个java web应用程序框架,工具供应商不会情愿去支持一个特别的框架,但是他们会毫不犹豫的去支持一个标准。而且不止供应商,开源项目也会迅速的聚集在JSF的四周,争先恐后的去实现相同的功能。比如说,直到我们去实现本质上和Shale的Tapestry差不多的视图的时候,我才知道Facalets。(从长远来看,我相信这种冗余是件好事,会给我们带来好处)
     678 
     679  
     680 
     681   8.POJO Action Methods 
     682 
     683       Struts的行为是和 Struts的API绑定在一起的,但是JSF的行为方法可以在POJPO中实现。这意味着你不用在表单和模型对象之间实现一个多余的行为层。顺便说一下,在JSF里面没有行为对象,行为在模型对象中实现。但是也请注意一点:如果你愿意你也可以生成与JSF独立的行为对象。在Struts里面,你有 Form Bean和Action Bean。Form Bean包含数据而Action Bean包含逻辑。OO狂会想去合并前2者,在Struts你办不到。但是在JSF中,你可以分开数据和逻辑,也可以合并到一个对象中,一切由你决定。
     684 
     685  
     686 
     687   7.Managed Beans(Dependency Injection 依赖注入) 
     688 
     689       和Spring一样,JSF也使用了依赖注入(DJ)(或控制反转(IoC))去实例化和初始化Bean。Struts的确为你生成了Form Bean和Action Bean,但是JSF可以为你生成各种各样的Managed Bean。
     690 
     691  
     692 
     693   6.Extensibility(可扩展性) 
     694 
     695       这个很重要。JSF有6个对象实现了这个框架的大部分功能,而且你可以很容易的用你自己的实现代替原有实现。比如你想加一个自定义参数在JSF表达式语言里面,或是添加一个自己的视图控制器以便于区分组件和HTML。事实上Shale实现了上面的功能。如果你还没有满足,JSF提供了几个地方你可以轻松的控制JSF的生命周期。Shale给你的会更多。
     696 
     697  
     698 
     699   5.Event Model(事件模型)
     700 
     701       JSF的事件模型使你可以对值改变,动作,JSF生命周期阶段变换等作出反应。在JSF1.1中,那些事件都是在服务器端处理的,这肯定是一个缺陷,好在JSF2.0计划支持客户端事件,拭目以待吧。
     702 
     703  
     704 
     705   4.Value Binding Expressions(值绑定表达式) 
     706 
     707       在Struts 中,你负责把数据从Form传递到模型对象。你实现的Action的execute方法是把Form作为一个参数。然后你再手动的把数据从Form Bean里面取出放到模型对象里面。你要为应用里面的每个Form做这些事情,然而在JSF里面,你只需像这样:#{model.property} 就够了,其他的交给JSF来处理。
     708 
     709  
     710 
     711   3.Renderers 
     712 
     713       你有看过Struts的标签的源代码吗?它直接生成HTML。JSF组件标签什么都不生成,它和服务器上的一对component-renderer对应。Component维护组件状态,rendered负责获得视图。重点是renderers是可插拔的,即你可以根据自己需求实现然后替代掉默认实现。比如说我在NFJS上面的Felix谈话中举例说明了怎么去实现一个自定义的label renderer。你只需要配置你的renderer,JSF就会自动在你的应用程序里面使用他。
     714 
     715  
     716 
     717   2.Render Kits 
     718 
     719       在几年前我曾经有份Struts咨询工作,我们必须同时支持浏览器和无线设备,非常痛苦。但是用JSF来完成那个任务非常容易,因为你可以生成你自己的render kit-为一种特定显示技术的renderers的集合-然后配置到JSF里面。
     720 
     721  
     722 
     723   1.Components(组件)
     724 
     725       组件是Struts和JSF之间最大的区别。就像Swing一样,JSF提供丰富的底层构件去开发组件然后添加到标准的组件集。那些底层构件让你很容易的生成自己的组件并且和别人共享。现在我们到处都能看到自定义组件跳出来,比如说Oracle的ADF和MyFaces,两者都提供了丰富的组件集,就像 javascript日历,tree等等。当然,组件只是一部分。典型的是,组件都和一个独立的renderer对应,这给我们带来了真正的好处(看第3 条)。但是和JSF中的很多东西一样,你不一定要墨守成规。只要你愿意,你可以实现render自己的组件,虽然这样你会失去给组件加入别的 renderer的能力。
     726 
     727  
     728 
     729 java版本的escape和unescape函数 
     730 
     731  大 | 中 | 小   [2006/02/27 15:33 | 分类: Java,J2EE | by NetFetch ] 
     732 
     733 Ad0.cn整理
     734 
     735  
     736 
     737 java.net.URLDecoder / java.net.URLEncoder 
     738 
     739 对应:javascript的 encodeURI/decodeURI 和encodeURIComponent/decodeURIComponent 
     740 
     741  
     742 
     743 java版本的escape和unescape函数
     744 
     745 对应:javascript 的escape/unescape 
     746 
     747  
     748 
     749 http://blog.ad0.cn
     750 
     751  
     752 
     753  
     754 
     755  
     756 
     757 class EscapeUnescape{
     758 
     759   public static String escape (String src) {
     760 
     761     int i;
     762 
     763     char j;
     764 
     765     StringBuffer tmp = new StringBuffer();
     766 
     767     tmp.ensureCapacity(src.length()*6);
     768 
     769     for (i=0;i      j = src.charAt(i);
     770 
     771       if(Character.isDigit(j) || Character.isLowerCase(j) || Character.isUpperCase(j))
     772 
     773         tmp.append(j);
     774 
     775       else
     776 
     777         if(j<256){
     778 
     779           tmp.append("%");
     780 
     781           if(j<16)
     782 
     783             tmp.append("0");
     784 
     785           tmp.append(Integer.toString(j,16));
     786 
     787         }  
     788 
     789         else{
     790 
     791           tmp.append("%u");
     792 
     793           tmp.append(Integer.toString(j,16));
     794 
     795         }
     796 
     797     }
     798 
     799     return tmp.toString();
     800 
     801   }
     802 
     803   
     804 
     805   public static String unescape (String src) {
     806 
     807     StringBuffer tmp = new StringBuffer();
     808 
     809     tmp.ensureCapacity(src.length());
     810 
     811     int lastPos=0,pos=0;
     812 
     813     char ch;
     814 
     815     while (lastPos      pos = src.indexOf("%",lastPos);
     816 
     817       if(pos == lastPos)  {
     818 
     819         if(src.charAt(pos+1)=='u') {
     820 
     821           ch = (char)Integer.parseInt(src.substring(pos+2,pos+6),16);
     822 
     823           tmp.append(ch);
     824 
     825           lastPos = pos+6;
     826 
     827         }
     828 
     829         else{
     830 
     831           ch = (char)Integer.parseInt(src.substring(pos+1,pos+3),16);
     832 
     833           tmp.append(ch);
     834 
     835           lastPos = pos+3;
     836 
     837         }
     838 
     839       }
     840 
     841       else{
     842 
     843         if(pos == -1){
     844 
     845           tmp.append(src.substring(lastPos));
     846 
     847           lastPos=src.length();
     848 
     849         }
     850 
     851         else{
     852 
     853           tmp.append(src.substring(lastPos,pos));
     854 
     855           lastPos=pos;
     856 
     857         }
     858 
     859       }
     860 
     861     }
     862 
     863     return tmp.toString();
     864 
     865   }
     866 
     867   
     868 
     869   public static void main(String[] args) {
     870 
     871     String tmp="~!@#$%^&*()_+|=-,./?><;'][{}"";
     872 
     873     System.out.println("testing escape : "+tmp);
     874 
     875     tmp =escape(tmp);
     876 
     877     System.out.println(tmp);
     878 
     879     System.out.println("testing unescape :"+tmp);
     880 
     881     System.out.println(unescape(tmp));
     882 
     883   }
     884 
     885 }
     886 
     887  
     888 
     889 Struts+Spring+Hibernate练习(完整) 
     890 
     891  大 | 中 | 小   [2006/03/04 17:18 | 分类: Java,J2EE | by NetFetch ] 
     892 
     893 Struts+Spring+Hibernate练习(完整)
     894 
     895 更多 Struts+Spring+Hibernate 相关的文章:
     896 
     897 选择JSF不选Struts的十大理由
     898 
     899 Struts+Spring+Hibernate练习(完整)
     900 
     901 struts+spring+hibernate之间的关系与差别(转)
     902 
     903 史上最简单的struts+spring+hibernate配置实例(修订版)
     904 
     905  
     906 
     907 Struts+Spring+Hibernate练习 工具:
     908 
     909     Eclipse3.1、MyEclipse4.03、Tomcat5.5.9、Properties Editor插件、MySql4.1.13 
     910 
     911 新建工程:名称为 login
     912 
     913 创建Struts框架
     914 
     915  
     916 
     917 创建 index.jsp,增加一链接指向 login.jsp
     918 
     919 按下Ctrl + N,创建 login.jsp、LoginAction,使用MyEclipse的向导就可以了,记得选对正确的版本
     920 
     921  
     922 
     923 在ActionForm配置页中选择类型为动态Form,并继承于DynaValidatorForm,新增两个属性:username、password,在创建jsp文件打上钩,将路径改为/login.jsp,然后下一步,改LoginAction的Input source改为/login.jsp,点击完成
     924 
     925  
     926 
     927 按下Ctrl + N 创建一个forwards,记得选对正确的版本
     928 
     929 name 输入 indexGo
     930 
     931 路径选择 /index.jsp
     932 
     933  
     934 
     935 配置validator
     936 
     937 先添加Struts插件,使用向导
     938 
     939 Plugin class : org.apache.struts.validator.ValidatorPlugIn
     940 
     941 Property : pathnames
     942 
     943 Value : /WEB-INF/validator-rules.xml,/WEB-INF/validation.xml
     944 
     945 这里需要两个xml文件
     946 
     947 现在创建“validation.xml” 文件
     948 
     949  
     950 
     951 在这里说明一点,我使用MyEclipse创建的Struts框架中缺少了validator-rules.xml文件,需要动拷贝到WEB-INF目录中
     952 
     953 此文件可以到http://struts.apache.org/下载
     954 
     955  
     956 
     957 文件内容如下:
     958 
     959  
     960 
     961 编辑资源文件“ApplicationResources.properties”
     962 
     963 增加以下内容
     964 
     965 prompt.username=User Name
     966 
     967 prompt.password=User Password
     968 
     969 errors.required={0} is required.
     970 
     971 再创建中文件资源文件“ApplicationResources_zh_CN.properties”
     972 
     973 增加以下内容 
     974 
     975 prompt.username=用户名称
     976 
     977 prompt.password=登录密码
     978 
     979 errors.required={0} 必需填写!
     980 
     981 修改struts-config.xml文件
     982 
     983 在以下位置增加绿色字体部份
     984 
     985  
     986 
     987           attribute="loginForm"
     988 
     989       input="/login.jsp"
     990 
     991       name="loginForm"
     992 
     993       path="/login"
     994 
     995       scope="request"
     996 
     997       validate="true"
     998 
     999       type="com.test.struts.action.LoginAction" />
    1000 
    1001 这里说明提交的数据必需经过验证,而验证则是通过validator框架进行的。
    1002 
    1003  
    1004 
    1005 修改LoginAction.java文件的execute方法,内容如下
    1006 
    1007 public ActionForward execute(
    1008 
    1009   ActionMapping mapping,
    1010 
    1011   ActionForm form,
    1012 
    1013   HttpServletRequest request,
    1014 
    1015   HttpServletResponse response) {
    1016 
    1017   DynaValidatorForm loginForm = (DynaValidatorForm) form;
    1018 
    1019   String username=loginForm.getString("username");
    1020 
    1021   String password=loginForm.getString("password");
    1022 
    1023   if(username.equals("test")||password.equals("test")){
    1024 
    1025    return mapping.findForward("indexGo");
    1026 
    1027   }else{
    1028 
    1029    return mapping.getInputForward();
    1030 
    1031   }
    1032 
    1033 }
    1034 
    1035 现在再修改一下login.jsp
    1036 
    1037 增加以下绿色字体部份:
    1038 
    1039 其中charset=UTF-8 是使用UTF-8的字符编码,这也是为了支持国际化而使用的。
    1040 
    1041  
    1042 
    1043 好了,现在可以启动Tomcat进行测试了
    1044 
    1045 http://localhost/login/ 这里说明一下,我的Tomcat已经装端口号改为80了,所以就不必使用http://localhost:8080/login/这样的方法了。
    1046 
    1047  
    1048 
    1049 如果不输入任何数据而直接提交表单的话就可以看到效果了。
    1050 
    1051  
    1052 
    1053 好了,如果没有什么问题的话就继续往下看吧,如果有问题的话就得往上看了^_^
    1054 
    1055  
    1056 
    1057 现在创建Spring框架了,在这里我将Spring所有的包全部加载进去,因为我还不知道具体用到哪些类,全部加进去方便点
    1058 
    1059  
    1060 
    1061 单选框选第二个,这样的话所有的类库和标签等都将拷贝到项目中去,这样方便以后的布署
    1062 
    1063 下一步后是创建配置文件,将文件放到“WebRoot/WEB-INF”目录下,文件名称为“applicationContext.xml”
    1064 
    1065  
    1066 
    1067  
    1068 
    1069 配置struts-config.xml文件,添加(spring)的插件
    1070 
    1071   
    1072 
    1073 修改LoginAction配置
    1074 
    1075  
    1076 
    1077 原:
    1078 
    1079       attribute="loginForm"
    1080 
    1081       input="/login.jsp"
    1082 
    1083       name="loginForm"
    1084 
    1085       path="/login"
    1086 
    1087       scope="request"
    1088 
    1089       validate="true"
    1090 
    1091       type="com.test.struts.action.LoginAction" />
    1092 
    1093 改为:
    1094 
    1095       attribute="loginForm"
    1096 
    1097       input="/login.jsp"
    1098 
    1099       name="loginForm"
    1100 
    1101       path="/login"
    1102 
    1103       scope="request"
    1104 
    1105       validate="true"
    1106 
    1107       type="org.springframework.web.struts.DelegatingActionProxy" />
    1108 
    1109 绿色字体部份为修改内容
    1110 
    1111 这里将使用spring的代理器来对Action进行控制
    1112 
    1113  
    1114 
    1115 当提交到/login.do是将控制权交给了spring,然后由spring来决定是否转回到struts的Action
    1116 
    1117 现在来配置spring
    1118 
    1119 绿色字体是关于转交控制权的配置内容
    1120 
    1121  
    1122 
    1123 属性singleton="false",指明了Action 的实例获取方式为每次重新创建。解决了Struts中令人诟病的线程安全问题(Struts中,由一个Action实例处理所有的请求,这就导致了类公用资源在并发请求中的线程同步问题。)(摘自spring开发指南)
    1124 
    1125  
    1126 
    1127 这时如果你要进行测试也是可以的,不过为了省点时间就不进行测试了。
    1128 
    1129   
    1130 
    1131 建立数据库在 这里我使用的是mysql4.1.13
    1132 
    1133  
    1134 
    1135 Create TABLE `user` (
    1136 
    1137   `ID` int(11) NOT NULL auto_increment,
    1138 
    1139   `USERNAME` varchar(50) NOT NULL default '',
    1140 
    1141   `PASSWORD` varchar(50) NOT NULL default '',
    1142 
    1143   PRIMARY KEY  (`ID`)
    1144 
    1145 ) ENGINE=MyISAM DEFAULT CHARSET=latin1; 
    1146 
    1147  
    1148 
    1149 添加记录 insert into user (USERNAME,PASSWORD) values ('test','test')
    1150 
    1151  
    1152 
    1153 创建Hibernate框架
    1154 
    1155 在配置界面中配置数据库的连接部份,重要的是点击链接将jdbc拷贝到lib目录中
    1156 
    1157 使用MyEclipse的数据Database Explorer工具创建User.hmb.xml、AbstractUser.java、User.java映射文件
    1158 
    1159 创建完成后可以将自动生成的hibernate.cfg.xml删除
    1160 
    1161  
    1162 
    1163 创建UserDAO.java、UserDAOImp.java
    1164 
    1165 UserDAO.java
    1166 
    1167  
    1168 
    1169 public interface UserDAO {
    1170 
    1171  
    1172 
    1173    public abstract boolean isValidUser(String username, String password);
    1174 
    1175  
    1176 
    1177 }
    1178 
    1179  
    1180 
    1181  
    1182 
    1183 UserDAOImp.java
    1184 
    1185 import java.util.List;
    1186 
    1187 import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
    1188 
    1189 import com.test.Hibernate.SessionFactory;
    1190 
    1191 public class UserDAOImp extends HibernateDaoSupport implements UserDAO {
    1192 
    1193     private SessionFactory sessionFactory;
    1194 
    1195     private static String hql = "from User u where u.username=? ";
    1196 
    1197     public boolean isValidUser(String username, String password) {
    1198 
    1199        List userList = this.getHibernateTemplate().find(hql, username);
    1200 
    1201        if (userList.size() > 0) {
    1202 
    1203            return true;
    1204 
    1205        }
    1206 
    1207  
    1208 
    1209        return false;
    1210 
    1211     }
    1212 
    1213  
    1214 
    1215 }
    1216 
    1217  
    1218 
    1219  
    1220 
    1221 修改LoginAction.java文件,使用userDao的方法来进行用户验证
    1222 
    1223 package com.test.struts.action;
    1224 
    1225  
    1226 
    1227 import javax.servlet.http.HttpServletRequest;
    1228 
    1229 import javax.servlet.http.HttpServletResponse;
    1230 
    1231  
    1232 
    1233 import org.apache.struts.action.Action;
    1234 
    1235 import org.apache.struts.action.ActionForm;
    1236 
    1237 import org.apache.struts.action.ActionForward;
    1238 
    1239 import org.apache.struts.action.ActionMapping;
    1240 
    1241 import org.apache.struts.validator.DynaValidatorForm;
    1242 
    1243  
    1244 
    1245 import com.test.UserDAO;
    1246 
    1247  
    1248 
    1249 public class LoginAction extends Action {
    1250 
    1251 private UserDAO userDAO;
    1252 
    1253 public UserDAO getUserDAO() {
    1254 
    1255   return userDAO;
    1256 
    1257 }
    1258 
    1259  
    1260 
    1261 public void setUserDAO(UserDAO userDAO) {
    1262 
    1263   this.userDAO = userDAO;
    1264 
    1265 }
    1266 
    1267  
    1268 
    1269 public ActionForward execute(ActionMapping mapping, ActionForm form,
    1270 
    1271    HttpServletRequest request, HttpServletResponse response) {
    1272 
    1273   DynaValidatorForm loginForm = (DynaValidatorForm) form;
    1274 
    1275   // TODO Auto-generated method stub
    1276 
    1277   String username = (String) loginForm.get("username");
    1278 
    1279   String password = (String) loginForm.get("password");
    1280 
    1281   loginForm.set("password", null);
    1282 
    1283   if (userDAO.isValidUser(username,password)) {
    1284 
    1285    return mapping.findForward("indexGo");
    1286 
    1287   } else {
    1288 
    1289    return mapping.getInputForward();
    1290 
    1291   }
    1292 
    1293 }
    1294 
    1295 }
    1296 
    1297 绿色字体为修改部份
    1298 
    1299  
    1300 
    1301 现在剩下最后的spring配置了
    1302 
    1303   
    1304 
    1305    com.mysql.jdbc.Driver  
    1306 
    1307   
    1308 
    1309    jdbc:mysql://localhost/test
    1310 
    1311     
    1312 
    1313    root
    1314 
    1315     
    1316 
    1317    root
    1318 
    1319   
    1320 
    1321     com/test/Hibernate/User.hbm.xml
    1322 
    1323     
    1324 
    1325     org.hibernate.dialect.MySQLDialect
    1326 
    1327     true
    1328 
    1329     
    1330 
    1331     PROPAGATION_REQUIRED
    1332 
    1333     PROPAGATION_REQUIRED,readOnly
    1334 
    1335     PROPAGATION_REQUIRED,readOnly
    View Code

    二、Jsp&Servlet技术

      1 54、面向对象的特征有哪些方面  
      2 1.抽象:
      3 
      4     找共性,将共有的属性、方法放到父类中
      5 
      6 2.继承:
      7 
      8     子类继承于父类,具有父类的所有属性与方法,可以重用,也可以覆盖。 
      9 
     10 3.封装:
     11 
     12     一个类包括多个属性及方法。
     13 
     14 4. 多态性:
     15 
     16     动态:
     17 
     18     静态:
     19 
     20 55、String是最基本的数据类型吗?
     21 基本数据类型包括byte、intcharlongfloatdouble、boolean和short。
     22 
     23  
     24 
     25 java.lang.String类是final类型的,因此不可以继承这个类、不能修改这个类。为了提高效率节省空间,我们应该用StringBuffer类
     26 
     27 56、int 和 Integer 有什么区别?
     28        Int是基本数据类型,不是对象,占一个内存空间,没有方法。与其同类的有long,char,doble
     29 
     30        Integer是封装类,具有方法及属性。与其同类的有Long,Double.Float
     31 
     32 57、运行时异常与一般异常有何异同?
     33     运行时异常:java JVM抛出的异常,代码中不用处理。
     34 
     35     
     36 
     37     一般异常:用户抛出的异常,如果用throws 声明了,调用这个方法的代码必须对其处理。
     38 
     39 58、&和&&的区别?
     40        &:与: 左边若为false右边还执行。
     41 
     42        &&:短路与,左边若为false右边不执行。
     43 
     44 59、final, finally, finalize的区别?
     45 final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。
     46 
     47 finally是异常处理语句结构的一部分,表示总是执行。
     48 
     49 finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等。
     50 
     51 算符可以用来决定某对象的类是否实现了接口。
     52 
     53 62、heap和stack有什么区别?
     54 栈是一种线形集合,其添加和删除元素的操作应在同一段完成。栈按照后进先出的方式进行处理。
     55 
     56 堆是栈的一个组成元素
     57 
     58  
     59 
     60 63、Static Nested Class 和 Inner Class的不同?
     61 Static Nested Class是被声明为静态(static)的内部类,它可以不依赖于外部类实例被实例化。而通常的内部类需要在外部类实例化后才能实例化。 
     62 
     63 64、什么时候用assert?
     64 assertion (断言)在软件开发中是一种常用的调试方式,很多开发语言中都支持这种机制。在实现中,assertion就是在程序中的一条语句,它对一个 boolean表达式进行检查,一个正确程序必须保证这个boolean表达式的值为true;如果该值为false,说明程序已经处于不正确的状态下,系统将给出警告或退出。一般来说,assertion用于保证程序最基本、关键的正确性。assertion检查通常在开发和测试时开启。为了提高性能,在软件发布后,assertion检查通常是关闭的。
     65 
     66 65、GC是什么? 为什么要有GC? 
     67 GC是垃圾收集的意思(Gabage Collection),内存处理是编程人员容易出现问题的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃,Java提供的GC功能可以自动监测对象是否超过作用域从而达到自动回收内存的目的,Java语言没有提供释放已分配内存的显示操作方法。
     68 
     69 66、short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
     70 short s1 = 1; s1 = s1 + 1; (s1+1运算结果是int型,需要强制转换类型) short s1 = 1; s1 += 1;(可以正确编译)
     71 
     72 67、Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
     73  Math.round(11.5)==12 Math.round(-11.5)==-11 round方法返回与参数最接近的长整数,参数加1/2后求其floor.
     74 
     75  
     76 
     77 68、Java有没有goto?
     78  java中的保留字,现在没有在java中使用。
     79 
     80  
     81 
     82 69、给我一个你最常见到的runtime exception
     83 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
     84 
     85  
     86 
     87 一般异常:
     88 
     89     IOException
     90 
     91     FileNotFoundException
     92 
     93     SqlException
     94 
     95     
     96 
     97 70、接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是否可继承实体类(concrete class)?
     98 接口可以继承接口。抽象类可以实现(implements)接口,抽象类是否可继承实体类。
     99 
    100 71、abstract的method是否可同时是static,是否可同时是native,是否可同时是synchronized?
    101     都不能
    102 
    103 72、数组有没有length()这个方法? String有没有length()这个方法?
    104        数组没有length()这个方法,有length这个属性
    105 
    106 String有length()这个方法.
    107 
    108 73、构造器Constructor是否可被override?
    109 构造器Constructor不能被继承,因此不能重写Overriding,但可以被重载Overloading。 
    110 
    111 74、是否可以继承String类?
    112 String类是final类故不可以继承。
    113 
    114 75、swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
    115 switch(expr1)中,expr1是一个整数表达式。因此传递给 switchcase 语句的参数应该是 intshortchar 或者 bytelong,string 都不能作用于swtich。
    116 
    117 76、try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,在return前还是后?
    118 会执行,在return前执行。
    119 
    120 77、编程题: 用最有效率的方法算出2乘以8等於几?
    121 2 << 3
    122 
    123 78、两个对象值相同(x.equals(y) == true),但却可有不同的hash code,这句话对不对?
    124 对,有相同的hash code。
    125 
    126 79、当一个对象被当作参数传递到一个方法后,此方法可改变这个对象的属性,并可返回变化后的结果,那么这里到底是值传递还是引用传递?
    127 是引用传递
    128 
    129 基本数据类型:值
    130 
    131 对象: 引用
    132 
    133 80、四种会话跟踪技术
    134 Cookie
    135 
    136 Session
    137 
    138 Hidden
    139 
    140 url 重写
    141 
    142 81、编程题: 写一个Singleton出来。
    143 Singleton模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在。
    144 
    145 一般Singleton模式通常有几种种形式:
    146 
    147 第一种形式: 定义一个类,它的构造函数为private的,它有一个static的private的该类变量,在类初始化时实例话,通过一个public的getInstance方法获取对它的引用,继而调用其中的方法。
    148 
    149 public class Singleton {
    150 
    151 private Singleton(){}
    152 
    153       //在自己内部定义自己一个实例,是不是很奇怪?
    154 
    155       //注意这是private 只供内部调用
    156 
    157       private static Singleton instance = new Singleton();
    158 
    159       //这里提供了一个供外部访问本class的静态方法,可以直接访问  
    160 
    161       public static Singleton getInstance() {
    162 
    163         return instance;   
    164 
    165       }
    166 
    167     }
    168 
    169     第二种形式:
    170 
    171 public class Singleton {
    172 
    173   private static Singleton instance = null;
    174 
    175   public static synchronized Singleton getInstance() {
    176 
    177   //这个方法比上面有所改进,不用每次都进行生成对象,只是第一次    
    178 
    179   //使用时生成实例,提高了效率!
    180 
    181   if (instance==null)
    182 
    183     instance=new Singleton();
    184 
    185 return instance;   }
    186 
    187 }
    188 
    189 其他形式:
    190 
    191 定义一个类,它的构造函数为private的,所有方法为static的。
    192 
    193 一般认为第一种形式要更加安全些
    194 
    195 83、Java中的异常处理机制的简单原理和应用。
    196 原理
    197 
    198     有错直接转到异常处理部分或向上抛出。
    199 
    200 应用:
    201 
    202 JAVA的异常就是错误,有两种一种是运行时,编码可以不用捕捉。一种是一般异常,如果throws声明了,必须进行处理。
    203 
    204 84、垃圾回收的优点和原理。并考虑2种回收机制。
    205 优点:
    206 
    207     程序员不用管内存,jvm自动完成,开发方便。运行优先非常低,程序无法清楚实例什么时候被消毁。
    208 
    209  
    210 
    211 85、描述一下JVM加载class文件的原理机制?
    212 JVM中类的装载是由ClassLoader和它的子类来实现的,Java ClassLoader 是一个重要的Java运行时系统组件。它负责在运行时查找和装入类文件的类。
    213 
    214 86、char型变量中能不能存贮一个中文汉字?为什么?
    215 能够定义成为一个中文的,因为java中以unicode编码,一个char占16个字节,所以放一个中文是没问题的
    216 
    217  
    218 
    219 88、写一个程序,从文件(c:	est.txt)中查出字符串”mobnet”出现的次数?
    220  
    221 
    222 
    223 
    224  
    225 
    226 java基础类库(io流,集合类,线程,Socket,AWT,Swing,sql)
    227 1、java中有几种类型的流?JDK为每种类型的流提供了一些抽象类以供继承,请说出他们分别是哪些类?
    228 字节流,字符流。字节流继承于InputStream OutputStream,字符流继承于Reader Writer。在java.io包中还有许多其他的流,低层流与调层流,高层流主要是为了提高性能和使用方便。
    229 
    230 2、启动一个线程是用run()还是start()?
    231 启动一个线程是调用start()方法,启动线程并调用run方法。
    232 
    233 3、线程的基本概念、线程的基本状态以及状态之间的关系
    234 线程是进程内的并发,没有自已内存空间,共享进程的,线程间的通信成本较低。
    235 
    236 Java中的线程有四种状态分别是:运行、就绪、挂起、结束。
    237 
    238 4、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么? 用什么关键字修饰同步方法? stop()和suspend()方法为何不推荐使用?
    239 Extends Thread
    240 
    241 Implements Runnable
    242 
    243 同步
    244 
    245 Public synchronized aa()
    246 
    247 {
    248 
    249  
    250 
    251 }
    252 
    253  
    254 
    255  
    256 
    257 Public void cc(object aa)
    258 
    259 {
    260 
    261     synchronized(aa)
    262 
    263 {
    264 
    265 }
    266 
    267 }
    268 
    269  
    270 
    271 用synchoronized修饰同步方法。
    272 
    273  
    274 
    275 答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
    276 
    277 同步的实现方面有两种,分别是synchronized,wait与notify
    278 
    279 反对使用stop(),是因为它不安全。它会解除由线程获取的所有锁定,而且如果对象处于一种不连贯状态,那么其他线程能在那种状态下检查和修改它们。结果很难检查出真正的问题所在。suspend()方法容易发生死锁。调用suspend()的时候,目标线程会停下来,但却仍然持有在这之前获得的锁定。此时,其他任何线程都不能访问锁定的资源,除非被"挂起"的线程恢复运行。对任何线程来说,如果它们想恢复目标线程,同时又试图使用任何一个锁定的资源,就会造成死锁。所以不应该使用suspend(),而应在自己的Thread类中置入一个标志,指出线程应该活动还是挂起。若标志指出线程应该挂起,便用wait()命其进入等待状态。若标志指出线程应当恢复,则用一个notify()重新启动线程。
    280 
    281 5、集合框架有什么?
    282 Collection                                                              Map
    283 
    284     List             set                                     HashMap
    285 
    286 ArrayList  linkedList  HashSet  TreeSet
    287 
    288  
    289 
    290 12、设计4个线程,其中两个线程每次对j增加1,另外两个线程对j每次减少1。写出程序
    291  
    292 
    293 public class TestThread
    294 
    295 {
    296 
    297     private int j;
    298 
    299     public synchronized void inc()
    300 
    301     {
    302 
    303         j++;
    304 
    305         System.out.println(Thread.currentThread().getName() + "-inc:" + j);
    306 
    307     }
    308 
    309     public synchronized void dec()
    310 
    311     {
    312 
    313         j--;
    314 
    315         System.out.println(Thread.currentThread().getName() + "-dec:" + j);
    316 
    317     }
    318 
    319     public static void main(String[] args)
    320 
    321     {
    322 
    323         TestThread t=new TestThread();
    324 
    325         for (int i = 0; i < 2; i++)
    326 
    327         {
    328 
    329             Thread inc=new Thread(new Inc(t));
    330 
    331             Thread dec=new Thread(new Dec(t));
    332 
    333             inc.start();
    334 
    335             dec.start();
    336 
    337         }
    338 
    339     }
    340 
    341 }
    342 
    343     
    344 
    345     class Inc implements Runnable
    346 
    347     {
    348 
    349         private TestThread obj;
    350 
    351         public Inc(TestThread obj)
    352 
    353         {
    354 
    355             this.obj=obj;
    356 
    357         }
    358 
    359         public void run()
    360 
    361         {
    362 
    363 //          for (int i = 0; i < 100; i++)
    364 
    365 //          {
    366 
    367                 this.obj.inc();
    368 
    369 //          }
    370 
    371         }
    372 
    373     }
    374 
    375     class Dec implements Runnable
    376 
    377     {
    378 
    379         private TestThread obj;
    380 
    381         public Dec(TestThread obj)
    382 
    383         {
    384 
    385             this.obj=obj;
    386 
    387         }
    388 
    389         public void run()
    390 
    391         {
    392 
    393 //          for (int i = 0; i < 100; i++)
    394 
    395 //          {
    396 
    397                 this.obj.dec();
    398 
    399 //          }
    400 
    401         }
    402 
    403     }
    404 
    405  
    406 
    407 13、同步和异步有和异同,在什么情况下分别使用他们?举例说明。
    408 同步:上一段代码没的完成,下一段必须等到上一段代码完成后才可以执行。如买票排队
    409 
    410 异步:上一段代码没的完成,下一段不必等到上一段代码完成就可以执行。如手机发送短信。
    411 
    412 14、sleep() 和 wait() 有什么区别?
    413 Sleep是指休眠给定的时间,当这个时间达到之后,线程会再次醒来。
    414 
    415 Wait是等待状态,多长时间不清楚,由另一个线程将其唤醒。
    416 
    417  
    418 
    419 15、当一个线程进入一个对象的一个synchronized方法后,其它线程是否可进入此对象的其它方法?
    420 如只其它方法是同步方法,不可以进入。如果不是可以进入。
    421 
    422 17、输入输出流的理解:
    423     在java使用流的机制进行数据的传送,从文件到内存是输入流,从内存到文件是输出流,输入流可以通过 read读取,输出流以write或print写入,对于流可以是分为高层流和低层流,低层以一个字节或字符为单位进行处理,高层流以一批数据为单位进行处理。
    424 
    425      FileInputStream(System.in)至InputSteamReader至BufferReader
    426 
    427      OutputSteam(System.out)至printStream
    428 
    429      FileReader至BufferedReader
    430 
    431      FileWriter 至 PrintWriter或bufferWriter
    432 
    433 分类:
    434 
    435     字节(二进制)
    436 
    437             FileInputStream(低层输入流)
    438 
    439             FileOutputStream(低层输出流)
    440 
    441  
    442 
    443             PrintStream(高层流)  System.out.println() 
    444 
    445     字符(一个char)
    446 
    447             FileReader
    448 
    449             FileWriter
    450 
    451  
    452 
    453 18、请写一个程序的读写,要求用两种方式一种是低层流另一种是高层流。
    454  
    455 
    456 import java.io.FileWriter;
    457 
    458 import java.io.InputStream;
    459 
    460 import java.io.BufferedWriter;
    461 
    462 import java.io.InputStreamReader;
    463 
    464 import java.io.BufferedReader;
    465 
    466 import java.io.FileReader;
    467 
    468  
    469 
    470  
    471 
    472 public class Untitled1 {
    473 
    474     public static void writeFileChar() throws Exception {
    475 
    476         FileWriter f = new FileWriter("c:\aa.txt");
    477 
    478         InputStream is = System.in;
    479 
    480         int c = is.read();
    481 
    482         while (((char) c) != 'x') {
    483 
    484             f.write(c);
    485 
    486             c = is.read();
    487 
    488         }
    489 
    490         f.close();
    491 
    492         is.close();
    493 
    494     }
    495 
    496  
    497 
    498     public static void writeFileString() throws Exception {
    499 
    500         FileWriter f = new FileWriter("c:\aa.txt");
    501 
    502         BufferedWriter bwr=new BufferedWriter(f);
    503 
    504         BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
    505 
    506         String c = bf.readLine();
    507 
    508         while (!c.equals("stop")) {
    509 
    510             bwr.write(c+"
    ");
    511 
    512             c = bf.readLine();
    513 
    514         }
    515 
    516         bwr.close();
    517 
    518         f.close();
    519 
    520         bf.close();
    521 
    522     }
    523 
    524     
    525 
    526     public static void readFileChar() throws Exception {
    527 
    528        FileReader f = new FileReader("c:\aa.txt");
    529 
    530        int c = f.read();
    531 
    532        while (c!=-1) {
    533 
    534            System.out.print((char)c);
    535 
    536            c=f.read();
    537 
    538        }
    539 
    540        f.close();
    541 
    542    }
    543 
    544  
    545 
    546    public static void readFileString() throws Exception {
    547 
    548        BufferedReader bf = new BufferedReader(new FileReader("c:\aa.txt"));
    549 
    550        String c = bf.readLine();
    551 
    552        while (c!=null) 
    553 
    554        {
    555 
    556            System.out.println(c);
    557 
    558            c=bf.readLine();
    559 
    560        }
    561 
    562        bf.close();
    563 
    564    }
    565 
    566  
    567 
    568  
    569 
    570     public static void main(String[] args) throws Exception {
    571 
    572         readFileString();
    573 
    574     }
    575 
    576 }
    577 
    578 19、如何列出某个目录下的所有文件
    579 Import java.io.File;
    580 
    581 File f=new File("C:\");
    582 
    583         File[] f1=f.listFiles();
    584 
    585         for(int i=0;i<f1.length;i++)
    586 
    587         {
    588 
    589             if(f1[i].isDirectory())
    590 
    591             {
    592 
    593                 System.out.println("dirctory is"+f1[i].getName());
    594 
    595             }
    596 
    597             else
    598 
    599             {
    600 
    601                 System.out.println("file is"+f1[i].getName());
    602 
    603             }
    604 
    605         }
    606 
    607     }
    608 
    609 1.      如何列出某个目录下的所有子目录
    610 
    611 public static void main(String[] args) throws Exception 
    612 
    613 {
    614 
    615        getFile(new File("C:\entityBean"),"	");
    616 
    617 }
    618 
    619 public static void getFile(File f,String sem) throws Exception
    620 
    621 {
    622 
    623         System.out.println(sem+f.getName());
    624 
    625         File fl[]=f.listFiles();
    626 
    627         if(fl.length>=1)
    628 
    629         {
    630 
    631             for(int i=0;i<fl.length;i++)
    632 
    633             {
    634 
    635                 if(fl[i].isDirectory())
    636 
    637                 {
    638 
    639                     getFile(fl[i],sem+"	");
    640 
    641                 }
    642 
    643             }
    644 
    645         }
    646 
    647     }
    648 
    649 2.      判断一个文件或目录是否存在
    650 
    651   File f=new File("C:\entityBean");
    652 
    653    if(f.exists())
    654 
    655    {
    656 
    657           System.out.println("exist");
    658 
    659    }
    660 
    661     else
    662 
    663     {
    664 
    665         System.out.println("not exist");
    666 
    667     }
    668 
    669 Socket
    670 
    671 20、用socket通讯写出客户端和服务器端的通讯,要求客户发送数据后能够回显相同的数据?
    672 public class ServerSocket_1
    673 
    674 {
    675 
    676     public static void main(String[] args)
    677 
    678             throws Exception
    679 
    680     {
    681 
    682         ServerSocket ss = new ServerSocket(4001);
    683 
    684         Socket s = ss.accept();
    685 
    686         BufferedReader br = new BufferedReader(new InputStreamReader(s.
    687 
    688                 getInputStream()));
    689 
    690         PrintStream ps=new PrintStream(s.getOutputStream());
    691 
    692         String temp = br.readLine();
    693 
    694         while (true)
    695 
    696         {
    697 
    698             System.out.println("客户端:"+temp);
    699 
    700             ps.println(temp);
    701 
    702             if (temp.equals("stop"))
    703 
    704             {
    705 
    706                 break;
    707 
    708             }
    709 
    710             temp = br.readLine();
    711 
    712         }
    713 
    714         br.close();
    715 
    716         ps.close();
    717 
    718         ss.close();
    719 
    720     }
    721 
    722 }
    723 
    724  
    725 
    726 public class ClientSocket
    727 
    728 {
    729 
    730   public static void main(String[] args) throws Exception
    731 
    732   {
    733 
    734       Socket s = new Socket("localhost", 4001);
    735 
    736       PrintStream ps = new PrintStream(s.getOutputStream());
    737 
    738       BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    739 
    740       BufferedReader br_server = new BufferedReader(new InputStreamReader(s.
    741 
    742               getInputStream()));
    743 
    744       String temp = br.readLine();
    745 
    746       while (true)
    747 
    748       {
    749 
    750           ps.println(temp);
    751 
    752           temp = br_server.readLine();
    753 
    754           System.out.println("服务器的信息:" + temp);
    755 
    756           if (temp.equals("stop"))
    757 
    758           {
    759 
    760               break;
    761 
    762           }
    763 
    764           temp = br.readLine();
    765 
    766       }
    767 
    768       s.close();
    769 
    770       br.close();
    771 
    772       br_server.close();
    773 
    774   }
    775 
    776 }
    777 
    778  
    779 
    780 23、介绍JAVA中的Collection FrameWork(包括如何写自己的数据结构)? 
    781 答:Collection FrameWork如下: 
    782 
    783 Collection 
    784 
    785 ├List 
    786 
    787 │├LinkedList 
    788 
    789 │├ArrayList 
    790 
    791 │└Vector 
    792 
    793 │ └Stack 
    794 
    795 └Set 
    796 
    797 Map 
    798 
    799 ├Hashtable 
    800 
    801 ├HashMap 
    802 
    803 └WeakHashMap 
    804 
    805 Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements) 
    806 
    807 Map提供key到value的映射
    808 
    809  
    810 
    811 24、请说出你所知道的线程同步的方法
    812 HashTable中的put,get,remove
    813 
    814 Vector的相关方法。
    815 
    816  
    817 
    818 jdbc数据访问技术
    819 1、JDBC如何做事务处理?
    820        Con.setAutoCommit(false)
    821 
    822        Con.commit();
    823 
    824        Con.rollback();
    825 
    826 2、写出几个在Jdbc中常用的接口
    827 preparedStatement,callableStatement,statement,Connection,ResultSet
    828 
    829 3、简述你对Statement,PreparedStatement,CallableStatement的理解
    830 statement用于执行静态 SQL 语句并返回它所生成结果的对象,在执行时确定sql。
    831 
    832  
    833 
    834  
    835 
    836  
    837 
    838 PreparedStatement表示预编译的 SQL 语句的对象。 SQL 语句被预编译并且存储在 PreparedStatement 对象中。然后可以使用此对象高效地多次执行该语句,可以传参数,在得到PreparedStatement对象时确定sql.
    839 
    840 CallableStatement用于执行 SQL 存储过程的接口。如果有输出参数要注册说明是输出参数。
    841 
    842  
    843 
    844 4、Java中访问数据库的步骤?
    845 1连接Oracle数据库
    846 
    847 Class.forName(“oracle.jdbc.driver.OracleDriver”);
    848 
    849 Connection con=DriverManager.openConnection(“jdbc:oracle:thin:@localhost:1521:DataBase ”,” UserName”,”Password ”)
    850 
    851 1.      利用JDBC检索出表中的数据
    852 
    853 Class.forName(“”);
    854 
    855 Connection con=DriverManager.openConnection(“ ”,” ”,” ”)
    856 
    857 preparedStatment  ps=Con.preparedStatment(“select * from [table]”);
    858 
    859 ResultSet rs=ps.executeQuery();
    860 
    861 While(rs.next)
    862 
    863 {
    864 
    865     Rs.getString(1) 或rs.getString(“字段名”)
    866 
    867 }
    868 
    869 5、JDBC中的核心类及其作用是什么?
    870 DriverManager
    871 
    872                             Class.forName();
    873 
    874                             DriverManager.openConnection(“”,”sa”,””)
    875 
    876               Connection   
    877 
    878               PreparedStatement(Statement) 
    879 
    880                             ResultSet  rs=executeQuery()  dql
    881 
    882                                           While(rs.next())
    883 
    884                                           {
    885 
    886  
    887 
    888 }
    889 
    890                             executeUpdate()  dml ddl
    891 
    892 6、执行存储过程用那一个类,如何操作输出参数?(操作)  
    893 CallableStatement c=con. prepareCall ("{call getCustomerName(?,?)}");
    894 
    895 c.setString(1,"1");
    896 
    897 c.registerOutParameter(2,java.sql.Types.VARCHAR);
    898 
    899 c.execute();
    900 
    901 c.getString(2);
    902 
    903 8、可能会让你写一段Jdbc连Oracle的程序.
    904 Class.forName("oracle.jdbc.driver.OracleDriver");
    905 
    906         Connection con=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:accp","system","system");
    907 
    908 9、Class.forName的作用?为什么要用?
    909 注册一个数据库驱动,将驱动加载到当前的JVM中。
    910 
    911 10、Jdo是什么?       
    912 JDO是Java对象持久化的新的规范,为java data object的简称,也是一个用于存取某种数据仓库中的对象的标准化API。JDO提供了透明的对象存储,因此对开发人员来说,存储数据对象完全不需要额外的代码(如JDBC API的使用)。这些繁琐的例行工作已经转移到JDO产品提供商身上,使开发人员解脱出来,从而集中时间和精力在业务逻辑上。另外,JDO很灵活,因为它可以在任何数据底层上运行。JDBC只是面向关系数据库(RDBMS)JDO更通用,提供到任何数据底层的存储功能,比如关系数据库、文件、XML以及对象数据库(ODBMS)等等,使得应用可移植性更强。(o/rMapping工具 集合处理)
    913 
    914 11、在ORACLE大数据量下的分页解决方法。一般用截取ID方法,还有是三层嵌套方法    
    915 create or replace package myPack
    916 
    917 is
    918 
    919     type c_type is ref cursor;
    920 
    921     procedure getPage(v_sql varchar2,pageSize number,pageIndex number,c out c_type);
    922 
    923 end;
    924 
    925  
    926 
    927 create or replace  package  body myPack
    928 
    929 is
    930 
    931     procedure getPage(v_sql varchar2,pageSize number,pageIndex number,c out c_type)
    932 
    933   is
    934 
    935     pageTotal int:=0;
    936 
    937     pageFirstRow int:=0;
    938 
    939     pageLastRow int:=0;
    940 
    941     rowTotal int:=0;
    942 
    943   begin
    944 
    945     execute immediate 'select count(*)  from ('||v_sql||')' into rowTotal;
    946 
    947     pageTotal:=ceil(rowTotal/pageSize);
    948 
    949     if(pageIndex<1) then
    950 
    951            raise_application_error(-20001,'页数不能小于1');
    952 
    953     end if;
    954 
    955     if(pageIndex>pageTotal) then
    956 
    957            raise_application_error(-20001,'页数太大,不能读取');
    958 
    959     end if;
    960 
    961     pageFirstRow:=(pageIndex-1)*pageIndex+1;
    962 
    963     pageLastRow:=pageFirstRow+pageSize;
    964 
    965     open c for ' select * from '||v_sql||' where rownum<'||
    966 
    967          pageLastRow||'minus select * from '||v_sql
    968 
    969          ||' where rownum<'||pageFirstRow;    
    970 
    971   end;
    972 
    973 end;
    View Code

    三、web

      1 1、简单说说tomcat的配置?
      2 JAVA_HOME=JDK的根目录
      3 
      4 CATALINA_HOME=tomcat的根目录
      5 
      6  
      7 
      8 CATALINA-HOMEconfserver.xml:可以配置tomcat的端口,可以配置tomcat中下连接池。
      9 
     10 CATALINA-HOMEcommonlib:存放公用的类包
     11 
     12  
     13 
     14 在My eclipse中如何配置tomcat
     15 
     16 在eclipse中,选择windows->preference->MyEclipse->ApplicationServer->Tomcat
     17 
     18 选择Tomcat 的安装目录,并选择TomCat所需的jdk,选择enable,确定即可。
     19 
     20 2、JSP中动态INCLUDE与静态INCLUDE的区别?
     21 jsp:include:在运行时调用另一个页面,变量是可以重复的。
     22 
     23 <%@include file=””%>:在转译时合在一起,会成为同一个类,变量不可以重复。
     24 
     25 3、forward和redirect的区别?
     26 forward: 转发,在下一个页面中,request保留上一个页面中的request的所有值
     27 
     28     
     29 
     30 redirect: 跳转,不传递request对象。
     31 
     32 4、Servlet的体系结构是什么? 
     33 Servlet
     34 
     35 GenericServlet
     36 
     37 HttpServlet
     38 
     39 自定义
     40 
     41 5、如何实现一个自定义的servlet? 
     42 extends HttpServlet 并覆盖doPost或doGet方法
     43 
     44  
     45 
     46 在web.xml中进行部署
     47 
     48 6、Servlet的生命周期是什么?
     49 Init 
     50 
     51 多次执行doGet或doPost  
     52 
     53 destroy
     54 
     55 7、jsp就是一个servlet是否正确?
     56  57 
     58 8、请罗列jsp中的脚本、指令及动作? 
     59 脚本
     60 
     61             <%%>  <%=%>  <%!%> <%----%>
     62 
     63         指令
     64 
     65             <%@page contentType=”text/html;charset=utf-8” language=”java” import=””%>
     66 
     67             <%@include file=””%>
     68 
     69             <%@taglib uri=”” prefix=””%>
     70 
     71         动作:
     72 
     73             <jsp:useBean class=”” id=”” scope=””>  在scope中如果没有实例化一个对象,如果有直接用以前的。
     74 
     75             <jsp:getProperty name=”” property=””>  向一个bean中设置属性值
     76 
     77             <jsp:forward >  jsp页的转发
     78 
     79             <jsp:include page=””>  导入一个jsp页面
     80 
     81 9、JSP的内置对象及方法
     82 Request  request表示HttpServletRequest对象。取客户端表单域信息及cookie, header, 和session 
     83 
     84 response response表示HttpServletResponse对象,对客户端的响应返回文本、写cookies。
     85 
     86 out out 向客户端打印html文本. 
     87 
     88 pageContext :当前jsp页面的上下文环境,可以得到session、request、application等内置对象,在自定义标签中使用的很多。
     89 
     90 session session表示一个请求的javax.servlet.http.HttpSession对象。Session一个用户多个页面共享同一变量。
     91 
     92 application applicaton 表示一个javax.servle.ServletContext对象。存放容器级的变量。
     93 
     94 config config表示一个javax.servlet.ServletConfig对象。该对象用于存取servlet实例的初始化参数。 
     95 
     96 page page表示从该页面产生的一个servlet实例
     97 
     98 exception:异常,当iserrorpage=true
     99 
    100 10、说出在JSP页面里是怎么分页的?
    101 页面需要保存以下参数:(数据库的分页及比较)
    102 
    103 总行数:根据sql语句得到总行数
    104 
    105 每页显示行数:设定值
    106 
    107 当前页数:请求参数
    108 
    109 页面根据当前页数和每页行数计算出当前页第一行行数,定位结果集到此行,对结果集取出每页显示行数的行即可。
    110 
    111  
    112 
    113 数据库:
    114 
    115 Sqlserver:
    116 
    117         SELECT TOP 页大小 *
    118 
    119 FROM TestTable
    120 
    121  
    122 
    123 WHERE (ID NOT IN
    124 
    125         (SELECT TOP 页大小*(页数-1) id
    126 
    127          FROM 表
    128 
    129          ORDER BY id))
    130 
    131 ORDER BY ID
    132 
    133  
    134 
    135  
    136 
    137 --pageSize=5  页大小
    138 
    139 --pageIndex=2 所要的页
    140 
    141 --如果有主键可以,没以及键不行
    142 
    143 select top 5 * 
    144 
    145 from aa where a1 not in
    146 
    147 (select top 5 a1 from aa order by a1)
    148 
    149 order by a1;
    150 
    151  
    152 
    153 oracle:
    154 
    155     select * from '||v_sql||' where rownum<'||
    156 
    157          pageLastRow||'minus select * from '||v_sql
    158 
    159          ||' where rownum<'||pageFirstRow;
    160 
    161  
    162 
    163  
    164 
    165 Session
    166 
    167     先取出数据中的所有信息封装到对象并保存在session中,转发到jsp页面做如下处理。
    168 
    169     <table border="1">
    170 
    171     <tr>
    172 
    173       <td>a1</td>
    174 
    175       <td>a2</td>
    176 
    177     </tr>
    178 
    179 <%
    180 
    181      List l=(List)session.getAttribute("as");
    182 
    183      //一页显示多少行
    184 
    185      int pageSize=3;
    186 
    187      //总页数
    188 
    189      int pageCount=0;
    190 
    191      int currentPage=1;
    192 
    193      if(l!=null && l.size()>0)
    194 
    195      {
    196 
    197      pageCount=(l.size()/pageSize)+(l.size()%pageSize==0?0:1);
    198 
    199      if(request.getParameter("page")!=null)
    200 
    201      {
    202 
    203        currentPage=Integer.parseInt(request.getParameter("page"));
    204 
    205      }
    206 
    207      if(currentPage<1)
    208 
    209      {
    210 
    211        currentPage=1;
    212 
    213      }
    214 
    215      if(currentPage>pageCount)
    216 
    217      {
    218 
    219        currentPage=pageCount;
    220 
    221      }
    222 
    223      for (int i = (currentPage-1)*pageSize; i <(currentPage-1)*pageSize+pageSize; i++)
    224 
    225      {
    226 
    227        if(i>=l.size())
    228 
    229        {
    230 
    231          break;
    232 
    233        }
    234 
    235        Aa aa=(Aa)l.get(i);
    236 
    237        %>
    238 
    239         <tr>
    240 
    241       <td><%=aa.getA1()%></td>
    242 
    243       <td><%=aa.getA2()%></td>
    244 
    245     </tr>
    246 
    247        <%
    248 
    249        }
    250 
    251      }
    252 
    253 %>
    254 
    255 <tr>
    256 
    257   <td colspan="2">
    258 
    259     <%
    260 
    261     if(currentPage!=1)
    262 
    263     {
    264 
    265     %>
    266 
    267     <a href="page.jsp?page=1">首页</a>&nbsp;&nbsp;
    268 
    269     <a href="page.jsp?page=<%=currentPage-1%>">上一页</a>&nbsp;&nbsp;
    270 
    271     <%
    272 
    273     }
    274 
    275     if(currentPage!=pageCount)
    276 
    277     {
    278 
    279     %>
    280 
    281     <a href="page.jsp?page=<%=currentPage+1%>">下一页</a>&nbsp;&nbsp;
    282 
    283     <a href="page.jsp?page=<%=pageCount%>">最后一页</a>&nbsp;&nbsp;
    284 
    285     <%
    286 
    287     }
    288 
    289     %>
    290 
    291   </td>
    292 
    293 </tr>
    294 
    295   </table>
    296 
    297     
    298 
    299 11、include的两种实现方式的区别?
    300 <@include file>:在将jsp生成servlet类前将两个文件和在一起,生成一个java类,一起运行的。所以是一家子,当中的变量名不能重名。
    301 
    302 <jsp:include page>:是两个类,是一个调用关系,在运行时动态的调用,不是一家子,可以重复变量。
    303 
    304 12、jsp页面中两种跳转方式分别是什么?有什么区别?
    305 转发: 保留上次的request
    306 
    307         <jsp:forward>
    308 
    309         actionMapping.findForWard(“”);
    310 
    311         pageContext.forward();
    312 
    313         request.getRequestDispacher(“a.jsp”).forward(request,response)
    314 
    315 跳转:不保留上次的request
    316 
    317         Response.setRedirect(“”)
    318 
    319 13、描述JSP和Servlet的区别、共同点、各自应用的范围
    320 Jsp主要在于页面的显示动态生成页面,可以与html标记一起使用,其还是要生成为一个servlet。
    321 
    322 Servlet:主要是控制的处理,如调用业务层,跳转不同的jsp页面。
    323 
    324 Mvc:
    325 
    326         Jsp:v
    327 
    328         Servlet:c
    329 
    330 14、在JSP中如何读取客户端的请求,如何确定某个Jsp文件的真实路径?
    331 Request.getparameter(“”)
    332 
    333 <%=application.getRealPath("aa.jsp") %>
    334 
    335 15、描述Cookie和Session的作用,区别和各自的应用范围,Session工作原理。
    336 Cookie:主要用在保存客户端,其值在客户端与服务端之间传送,不安全,存储的数据量有限。
    337 
    338 Session:保存在服务端,每一个session在服务端有一个sessionID作一个标识。存储的数据量大,安全性高。占用服务端的内存资源。
    339 
    340 16、说明Jsp中errorPage的作用,应用范围。
    341 正常页面中
    342 
    343 %@page erropage=”error.jsp”%
    344 
    345         错误页面
    346 
    347             <%@page iserrorpage=”true”%>
    348 
    349                  有一内置对象:exception
    350 
    351 17、介绍在Jsp中如何使用JavaBeans
    352 <jsp:useBean class=”” id=”” scope=””/>
    353 
    354 <%
    355 
    356     New 类();
    357 
    358 %>
    359 
    360 19、简单介绍JSP的标记库
    361 做一个标记处理类 extends TagSupport
    362 
    363 通过tld说明标记处理的类的前缀及后缀
    364 
    365 在web.xml中说明tld文件 
    366 
    367 <taglib>
    368 
    369         <taglib-uri>
    370 
    371         <taglib-location>
    372 
    373 <taglib>
    374 
    375 在jsp页面是引用tld<%@taglib uri=”” prefix=””%>
    376 
    377 20、Servlet中的核心类有那些,各有什么特点?
    378 ServletContext:容器,放置全局变量
    379 
    380     setAtribute()
    381 
    382     getAttribute()
    383 
    384 ServletConfig:一个servlet的配置
    385 
    386     getInitParameter(”名称”)
    387 
    388 HttpServletRequest:封装的所有的请求
    389 
    390     getParameterValue(”名称”)
    391 
    392     getParameterValues(”称”)
    393 
    394 getSession();
    395 
    396     getAttribute(” 名称”);
    397 
    398     getRequestDispatch(”a.jsp”).forward(request,response)
    399 
    400 HttpServletResponse:响应
    401 
    402     getOut();
    403 
    404     sendRedirect(””)                        
    405 
    406 HttpSession:一个用户多个页面共享同一变量
    407 
    408     setAttribute(””,””)
    409 
    410 21、Servlet中重要的包有那些,有什么区别?
    411 javax.servlet.*;javax.servlet.http.*;
    412 
    413 22、说出Servlet的生命周期,并说出Servlet和CGI的区别?
    414 Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。
    415 
    416  
    417 
    418 与cgi的区别在于servlet处理服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。
    419 
    420 23、什么情况下调用doGet()和doPost()?
    421 Jsp页面中的form标签里的method属性为get时调用doGet(),为post时调用doPost()。 
    422 
    423 25、如何现实servlet的单线程模式
    424 在doGet及doPost方法前加入synchoronized
    425 
    426 JSP:
    427 
    428 <%@ page isThreadSafe="true"%>
    429 
    430 27、Request对象的主要方法:
    431 setAttribute(String name,Object):设置名字为name的request的参数值
    432 
    433 getAttribute(String name):返回由name指定的属性值
    434 
    435 getAttributeNames():返回request对象所有属性的名字集合,结果是一个枚举的实例
    436 
    437 getCookies():返回客户端的所有Cookie对象,结果是一个Cookie数组
    438 
    439 getCharacterEncoding():返回请求中的字符编码方式
    440 
    441 getContentLength():返回请求的Body的长度
    442 
    443 实例
    444 
    445 getInputStream():返回请求的输入流,用于获得请求中的数据
    446 
    447 getMethod():获得客户端向服务器端传送数据的方法
    448 
    449 getParameter(String name):获得客户端传送给服务器端的有name指定的参数值
    450 
    451 getParameterNames():获得客户端传送给服务器端的所有参数的名字,结果是一个枚举的实例
    452 
    453 getParameterValues(String name):获得有name指定的参数的所有值
    454 
    455 getProtocol():获取客户端向服务器端传送数据所依据的协议名称
    456 
    457 getQueryString():获得查询字符串
    458 
    459 getRequestURI():获取发出请求字符串的客户端地址
    460 
    461 getRemoteAddr():获取客户端的IP地址
    462 
    463 getRemoteHost():获取客户端的名字
    464 
    465 getSession([Boolean create]):返回和请求相关Session
    466 
    467 getServerName():获取服务器的名字
    468 
    469 getServletPath():获取客户端所请求的脚本文件的路径
    470 
    471 getServerPort():获取服务器的端口号
    472 
    473 removeAttribute(String name):删除请求中的一个属性
    474 
    475 28、我们在web应用开发过程中经常遇到输出某种编码的字符,如iso8859-1等,如何输出一个某种编码的字符串?
    476   Public String translate (String str) {
    477 
    478     String tempStr = "";
    479 
    480     try {
    481 
    482       tempStr = new String(str.getBytes("ISO-8859-1"), "GBK");
    483 
    484       tempStr = tempStr.trim();
    485 
    486     }
    487 
    488     catch (Exception e) {
    489 
    490       System.err.println(e.getMessage());
    491 
    492     }
    493 
    494     return tempStr;
    495 
    496   }
    497 
    498  
    499 
    500 30、Servlet执行时一般实现哪几个方法?
    501 public void init(ServletConfig config)
    502 
    503 public ServletConfig getServletConfig()
    504 
    505 public String getServletInfo()
    506 
    507 public void service(ServletRequest request,ServletResponse response)
    508 
    509 public void destroy()
    View Code

    四、框架

       1 5 Hibernate持久层技术
       2 1、在myeclipse加入hibernate环境的全过程是什么?
       3 Db-browers加入配置连接
       4 
       5 新建工程
       6 
       7 加入hibernate环境,指定*.hbm.xml及HibernateSessionFactory文件所在的位置
       8 
       9 2、hibernate的核心配置文件是什么及其作用?
      10 Hibernate.cfg.xml:数据库连接、指定相关的映射文件
      11 
      12     *.hbm.xml:具体的o/r mapping说明
      13 
      14 3、hibernate的核心类是什么,它们的相互关系是什么?重要的方法是什么?
      15 Configuration
      16 
      17 SessionFactory
      18 
      19         Session如下方法
      20 
      21             Save
      22 
      23             load
      24 
      25             Update
      26 
      27             Delete
      28 
      29             Query q=CreateQuery(“from Customer where customerName=:customerName”)
      30 
      31             beginTransaction
      32 
      33             close
      34 
      35             Transaction
      36 
      37             Commit()        
      38 
      39 4、关联:
      40     one-to-many
      41 
      42     inverse:主控方,外键的关系有谁控制
      43 
      44         inverse=false 是主控方,外键是由它控制的            
      45 
      46         inverse=true 是被控方,外键与它没关系
      47 
      48         要想实现主控方的控制必须将被控方作为主控方的属性
      49 
      50     cascade:级联
      51 
      52         主表增从表增
      53 
      54         主表修从表修
      55 
      56         主表删从表删
      57 
      58     lazy:延迟
      59 
      60         lazy=false:一下将所有的内容取出,不延时(常用)
      61 
      62         lazy=true:取出部分内容,其余内容动态去取
      63 
      64         通过get可以取出对方的所有内容      
      65 
      66 5、hibernate中的one-to-many或many-to-one中常用的方式是什么? 
      67 主控方在many这边,不及连删除
      68 
      69 6、Criteria 的作用?
      70     Criteria c=session.createCriteria(Customer.class);
      71 
      72     //设置条件
      73 
      74     c.add(Expression.ge(“字段名”,”值对象”))
      75 
      76         ge:>=
      77 
      78         gt:>
      79 
      80         le:<=
      81 
      82         lt:<
      83 
      84         eq:=
      85 
      86     //排序
      87 
      88         c.addOrder(Order.asc(“字段名”))
      89 
      90     //分页
      91 
      92         c.setFirstResult(1)//从第2行开始提取
      93 
      94         c.setMaxResults(5)//返回5行
      95 
      96 7、DetachedCriteria的作用?
      97 产生时不需要session
      98 
      99     DetachedCriteria dc= DetachedCriteria.forClass(Customer.class)
     100 
     101     Criteria c=Dc.getExecutableCriteria(session)
     102 
     103 8、Query
     104 1 个或多个属性查询:
     105 
     106     Query query=session.createQuery(”select customername,customerid from Customer”)
     107 
     108     List l=query.list();
     109 
     110     For(int i=0;i<l.size();i++)
     111 
     112 {
     113 
     114     Obejct[] object=(Object[])l.get(i);
     115 
     116     Object[0]  object[1]
     117 
     118 }
     119 
     120 }
     121 
     122 分组: "select count(*),productname from Product group by productname order by productname"
     123 
     124 取值与属性一样
     125 
     126 配置的查询,在*.hbm.xml中
     127 
     128     <query name="sql">
     129 
     130     <![CDATA[
     131 
     132         from Product where productid=:productid
     133 
     134     ]]>
     135 
     136 </query>
     137 
     138     Query query=session.getNamedQuery(sql);
     139 
     140 联接1
     141 
     142     "from Customer as customer join fetch customer.buySet":将多的放到buySet属性中,得出的结是Customer有一个,Buy有多个
     143 
     144 联接2 
     145 
     146 "from Customer as customer join customer.buySet":得出的对象,customer与buy是1对1
     147 
     148 子查询:
     149 
     150     "from Customer as customer where (select count(*) from customer.buySet)>1"
     151 
     152 9、继承关系的实现
     153     1、两个表,子类重复父类的属性。
     154 
     155     2、一个表,子类父类共用一个表
     156 
     157           <class name="Users" table="users" discriminator-value="Users">
     158 
     159             <discriminator column="DISCRIMINATOR_USERTYPE" type="string"/>
     160 
     161 <subclass name="admin" discriminator-value="admin">
     162 
     163                     <property name="adminRemark" column="admin_remark" type="string" />
     164 
     165               </subclass>
     166 
     167           </class>
     168 
     169     3、两个表,子类引用父类的主键,享用公共的字段或属性。
     170 
     171     <class name="Users" table="users">
     172 
     173         <id name="userid" column="USERID" type="string">
     174 
     175             <generator class="assigned"/>
     176 
     177         </id>
     178 
     179         <property name="pwd" column="pwd" type="string" />
     180 
     181         <joined-subclass name="Guest" table="guest">
     182 
     183             <key column="USERID"/> 
     184 
     185             <property name="guestRemark" column="guest_remark" type="string" />
     186 
     187         </joined-subclass>
     188 
     189 </class>
     190 
     191 批量删除
     192 
     193     Query query=session.createQuery("update"或"delete");
     194 
     195     query.executeUpdate();
     196 
     197  
     198 
     199 10、tomcat连接池:在容器中预先产生了n个连接实例,客户端不用重新实例化,可以直接取。
     200     6.1、在tomcat-5.0confserver.xml中</host>前面加入如下内容
     201 
     202     <Context path="/app1" docBase="app1" debug="0"    reloadable="true" crossContext="true">   
     203 
     204     <Resource name="jdbc/sa" auth="Container" type="javax.sql.DataSource"/>   
     205 
     206               <ResourceParams name="jdbc/sa">   
     207 
     208             <parameter>     
     209 
     210                 <name>factory</name>        
     211 
     212                 <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>       
     213 
     214             </parameter>              
     215 
     216         <parameter>     
     217 
     218                         <name>driverClassName</name>        
     219 
     220                 <value>com.microsoft.jdbc.sqlserver.SQLServerDriver</value>     
     221 
     222             </parameter>            
     223 
     224         <parameter> 
     225 
     226                 <name>url</name>        
     227 
     228                   <value>jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=jspdev;SelectMethod=cursor</value>   
     229 
     230         </parameter>        
     231 
     232             <parameter>             
     233 
     234             <name>username</name>       
     235 
     236                     <value>sa</value>             
     237 
     238         </parameter>        
     239 
     240             <parameter>             
     241 
     242             <name>password</name>               
     243 
     244             <value></value> 
     245 
     246             </parameter>        
     247 
     248             <parameter>             
     249 
     250             <name>maxActive</name>              
     251 
     252                 <value>20</value>             
     253 
     254         </parameter>
     255 
     256             <parameter>     
     257 
     258                 <name>maxIdle</name>                
     259 
     260             <value>10</value>             
     261 
     262         </parameter>              
     263 
     264         <parameter> 
     265 
     266                 <name>maxWait</name>                
     267 
     268             <value>-1</value>             
     269 
     270         </parameter>        
     271 
     272             </ResourceParams>     
     273 
     274     </Context>
     275 
     276     6.2、将sql-server包拷贝到C:	omcat-5commonlib
     277 
     278     6.3、jdbc测试代码
     279 
     280         Context initCtx = new InitialContext();
     281 
     282         Context envCtx = (Context)initCtx.lookup("java:comp/env");
     283 
     284         ds = (DataSource)envCtx.lookup("jdbc/sa");
     285 
     286         Connection conn = ds.getConnection();
     287 
     288     6.4、hibernate通过连接池实现连接
     289 
     290         <session-factory name="foo">
     291 
     292             <property name="connection.datasource">java:comp/env/jdbc/sa</property>  <!--指定tomcat连接池-->
     293 
     294             <property name="show_sql">true</property> <!--是否显示sql-->
     295 
     296             <property name="dialect">org.hibernate.dialect.SQLServerDialect</property> <!--hibernate的驱动管理器-->
     297 
     298             <mapping resource="com/accp/t15/Customer.hbm.xml"/>
     299 
     300         </session-factory>
     301 
     302  
     303 
     304 11、对象的三大状态
     305     自由(transient)
     306 
     307         与session无关
     308 
     309     持久(persistent)
     310 
     311         由session来管理
     312 
     313         在持久状态中通过get方法取出对方
     314 
     315     游离(detached)
     316 
     317         被session抛弃  
     318 
     319 12、hibernate常见优化策略
     320     用最新版本的hibernate
     321 
     322     制定合理的缓存策略
     323 
     324     采用合理的session管理机制
     325 
     326     尽量使用延迟加载
     327 
     328         many
     329 
     330         大文本、大文件
     331 
     332     设定合理的批处理参数(batch-size)
     333 
     334     如有可能,选用uuid作为主键生成器
     335 
     336     如有可能,选用基于version的乐观锁替代悲观锁
     337 
     338     开发过程中,打开hibernate的SQl日志输出(hibernate.show_sql=true),通过观察hibernate生成的sql语句进一步了解其实现原理,从而指事实上更好的实现策略。  
     339 
     340 6.               iBatis持久层技术
     341  
     342 
     343 用ibatis的原因:
     344        只对开发团队提供几条Select SQL(或存储过程)以获取所需数据,具体的表结构不予公开。
     345 
     346        开发规范中要求,所有牵涉到业务逻辑部分的数据库操作,必须在数据库层由存储过程实现
     347 
     348        系统数据处理量巨大,性能要求极为苛刻,这往往意味着我们必须通过经过高度优化的SQL语句
     349 
     350        (或存储过程)才能达到系统性能设计指标。
     351 
     352 jdbc、hibernate、ibatis的区别
     353        jdbc:手动
     354 
     355               手动写sql
     356 
     357               delete、insert、update要将对象的值一个一个取出传到sql中,不能直接传入一个对象。
     358 
     359               select:返回的是一个resultset,要从ResultSet中一行一行、一个字段一个字段的取出,然后封装到一个对象中,不直接返回一个对象。
     360 
     361        ibatis的特点:半自动化
     362 
     363               sql要手动写
     364 
     365               delete、insert、update:直接传入一个对象
     366 
     367               select:直接返回一个对象                   
     368 
     369        hibernate:全自动
     370 
     371               不写sql,自动封装
     372 
     373               delete、insert、update:直接传入一个对象
     374 
     375               select:直接返回一个对象
     376 
     377 ibatis的核心配置文件:
     378        sqlmapclient.xml:数据库连接及相关o/rMapping的映射文件(hibernate.cfg.xml)
     379 
     380        sqlmapBuy.xml:具体的o/rmapping映射(*.hbm.xml)  
     381 
     382               四大标记:
     383 
     384                      select
     385 
     386                      update
     387 
     388                      delete
     389 
     390                      insert
     391 
     392                      procedure
     393 
     394 ibatis的核心类:
     395        SqlMapClientBuilder:加载配置文件,返回一个会话。
     396 
     397        SqlMapClient:具体的会话
     398 
     399               List list=queryForList("标签名",object);
     400 
     401               Object obj=queryForObject("标签名",object);
     402 
     403               delete("标签名",object)
     404 
     405               update("标签名",object)
     406 
     407               insert("标签名",object)
     408 
     409 工程的使用:
     410 
     411        将ibatisfactory拷贝到工程目录下
     412 
     413        将ms的3个包及ibatis的三个包拷贝到/WEB-INF/lib下
     414 
     415        修改ibatisfactory中的abatorConfig.xml文件
     416 
     417        进入ibatisfactory目录运行java -jar  abator.jar abatorConfig.xml true
     418 
     419        将sql标记、select、update、insert、delete的副本删除
     420 
     421 spring&ibatis:
     422 
     423        dataSource
     424 
     425        sqlMapClient:SqlMapClientFactoryBean
     426 
     427               configLocation
     428 
     429                      classpath:sqlMapClient.xml
     430 
     431                      /WEB-INF/sqlMapClient.xml
     432 
     433               dataSource
     434 
     435        transactionManager:DataSourceTransactionManager
     436 
     437               dataSource
     438 
     439        customerDao extends SqlMapClientDaoSupport
     440 
     441               sqlMapClient
     442 
     443        buyDao
     444 
     445               sqlMapClient
     446 
     447        Facade
     448 
     449               buyDao
     450 
     451               customerDao
     452 
     453        abstractProxy:TransactionProxyFactoryBean
     454 
     455               transactionManager
     456 
     457               transactionAttributes
     458 
     459        facadeProxy
     460 
     461               target:fa?ade
     462 
     463 7 Structs界面控制层技术
     464 1、请说出struts框架的几大组件?
     465               1、MVC
     466 
     467               2、标签库
     468 
     469               3、校验框架
     470 
     471               4、国际化
     472 
     473               5、tiles
     474 
     475 3、struts的核心类有那些,在MVC模式中其对应的关系是什么?
     476 C
     477 
     478 ActionServlet
     479 
     480        RequestProcessor
     481 
     482        Action
     483 
     484        actionMapping(struts-config.xml)
     485 
     486        actionFormard
     487 
     488 V
     489 
     490 ActionForm
     491 
     492 Jsp
     493 
     494 M
     495 
     496     Dao
     497 
     498        Manager(facade)
     499 
     500 4、Struts的处理请求的全过程是什么?
     501 url-> ActionServlet(process)-> RequestProcessor(process)->实例化form ->填充form值->进行校验->实例化action->调用execute
     502 
     503 5、在struts中如何通过一个url找到一个action,它的核心配置文件是什么?
     504 配置文件是struts-config.xml
     505 
     506 6、为什么使用MVC,其主要目的是什么? 
     507 让v与M强制解耦,提高可重用性(旅馆的服务员(C))
     508 
     509 7、对于MVC在action中对应有类有几种,各有什么作用?
     510 ?  Action:
     511 
     512 1)  基本的
     513 
     514 ?  DispatchAction:
     515 
     516 2)  存在多个方法,根据页面传入的表单域的值调用不同的方法,表单域的名称在<action param=””/>标记中进行配置
     517 
     518 ?  LookupDispatchAction
     519 
     520 3)  多个按钮用同一个action的不同方法。实现getMap方法,说明每一个按钮在*.properties中的键名及键值,在struts-config.xml通过parameter说明按钮的名称,按钮的值对应*.properties的值,通过值找键名,通过键名找Map中的键名找到值就是相应的方法。
     521 
     522 ?  MappingDispatchAction:未知
     523 
     524 ?  forwordAction:直接跳转到不同页面不执行逻辑(???)
     525 
     526 ?  类所在的包:org.apache.struts.actions.ForwardAction
     527 
     528 8、struts的标记有几类,请列举并说明其作用?     
     529 Bean:
     530 
     531 <bean:define scope=”” name=”” property=”” id=””/>
     532 
     533 <bean:write  name=”customer” property=”customerName”/>       
     534 
     535 <bean:message key=””/>国际化
     536 
     537 Logic:
     538 
     539 <logic:iteator>  //将集合的内容取出
     540 
     541 <logic:present> //
     542 
     543 <logic:equals> //
     544 
     545 Html:
     546 
     547 <html:file>上传文件
     548 
     549 <html:select property=”sex”>
     550 
     551         <html:options collection=”” property=”” labelProperty=””/>
     552 
     553 </html:select>
     554 
     555 9、如何在struts中配置数据源在,什么文件?用什么标签?如何取出DataSource? 
     556 Struts-config.xml
     557 
     558  
     559 
     560 <data-sources>
     561 
     562         <data-source key="data" type="org.apache.commons.dbcp.BasicDataSource">
     563 
     564             <set-property property="driverClassName"   value="com.microsoft.jdbc.sqlserver.SQLServerDriver" />
     565 
     566              <set-property property="url"     value="jdbc:microsoft:sqlserver://localhost:1433;databaseName=t23" />
     567 
     568              <set-property property="username" value="sa" />
     569 
     570              <set-property property="password" value="" />          
     571 
     572         </data-source>
     573 
     574     </data-sources>
     575 
     576  
     577 
     578 DataSource ds=(DataSource)this.getServlet().getServletContext().getAttribute("data");
     579 
     580         Connection con=ds.getConnection();
     581 
     582 10、如何在jbuilder中开发struts?     
     583 ?  工程
     584 
     585 ?  Web模型(选中struts1.2.8,会自加在web –inf中生成tld及struts-config.xml,并加载相关的类包)
     586 
     587 ?  建一个ActionForm
     588 
     589 ?  建一个Action
     590 
     591 ?  修改struts-config.xml文件
     592 
     593 11、如何实现struts的validator框架?    
     594 ?      手动:
     595 
     596 ?          public class myForm extends ActionForm  
     597 
     598 ?          {
     599 
     600 ?              public ActionErrors validate()
     601 
     602 ?              {
     603 
     604 actionErrors.add(ActionErrors.GLOBAL_MESSAGE,new ActionMessage("properties中的键名"));
     605 
     606 ?              }
     607 
     608 ?          }   
     609 
     610 ?          struts-config.xml中修改action的标签validate=true
     611 
     612 ?              input="错误页面"
     613 
     614 ?          如果validate方法中的ActionErrors不为空且size>0时
     615 
     616 ?          会回到input页面。
     617 
     618 ?      自动
     619 
     620 ?          public class myForm extends ValidateForm    
     621 
     622 ?          {
     623 
     624 ?              不能覆盖validate方法。
     625 
     626 ?              //public void validate()
     627 
     628 ?              //{
     629 
     630 ?  
     631 
     632 ?              //}
     633 
     634 ?          }   
     635 
     636 ?          在struts-config.xml文件中加入插件
     637 
     638 ?              <plug-in className="org.apache.struts.validator.ValidatorPlugIn">
     639 
     640 ?                      <set-property property="pathnames" value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml" />
     641 
     642 ?              </plug-in>
     643 
     644 ?  修改validation.xml中的内容
     645 
     646 ?      errors.required={0} is required.
     647 
     648 ?      errors.minlength={0} can not be less than {1} characters.
     649 
     650  
     651 
     652 ?      <formset>
     653 
     654 ?          <form name="loginForm">
     655 
     656 ?              <field property="userName" depends="required">
     657 
     658 ?                  <arg0 key="userName" />
     659 
     660 ?              </field>
     661 
     662 ?              <field property="pwd" depends="required,minlength">
     663 
     664 ?                  <arg0 key="pwd" />
     665 
     666 ?                  <arg1 key="${var:minlength}" resource="false"/>
     667 
     668 ?                  <var>
     669 
     670 ?                      <var-name>minlength</var-name>
     671 
     672 ?                      <var-value>6</var-value>
     673 
     674 ?                  </var>
     675 
     676 ?              </field>
     677 
     678 ?          </form>
     679 
     680 ?      </formset>
     681 
     682 ?      struts-config.xml中修改action的标签validate=true
     683 
     684 ?              input="/错误页面"   
     685 
     686 13、如何实现国际化?
     687 国际化:不用修改代码,就适用于不同的语言国家
     688 
     689 本地化:如果要适应一个国家,要修改源代码
     690 
     691 实现过程:
     692 
     693     在struts-config.xml中用如下标签说明资源文件名,注意其只是文件名,没有语言_国家
     694 
     695          <message-resources parameter="struts.ApplicationResources" />
     696 
     697     在资源文件对应的目录struts中加入适应不同语言、国家的properties文件
     698 
     699         ApplicationResources_zh_CN.properties 中国
     700 
     701         ApplicationResources_en_US.properties us
     702 
     703     如果不是英语要转码
     704 
     705         native2ascii -encoding gb2312 源 ApplicationResources_zh_CN.properties
     706 
     707     在jsp页面中用
     708 
     709         <bean:message key=""/>取出信息
     710 
     711 8 JSF界面控制层技术
     712 1、Jsf中的核心类用那些?有什么作用?    
     713 核心类
     714 
     715         FacesServlet 
     716 
     717 LiftCycle    FacesContext  
     718 
     719         
     720 
     721 2、Jsf中的LiftCycle六大生命周期是什么? 
     722 恢复视图->应用请求值->校验->更新模型->调用应用程序->呈现响应
     723 
     724 3、如何管量web层中的Bean,用什么标签。如何通过jsp页面与Bean绑定在一起进行处理?
     725 <managed-bean>
     726 
     727             <managed-bean-name>checkNumber</managed-bean-name>
     728 
     729        <managed-bean-class>jsf1.CheckNumber</managed-bean-class>
     730 
     731             <managed-bean-scope>session</managed-bean-scope>
     732 
     733 </managed-bean>
     734 
     735 4、Jsf中导航的标签是什么?
     736 <navigation-rule>
     737 
     738             <from-view-id>/main.jsp</from-view-id>
     739 
     740             <navigation-case>
     741 
     742                  <from-outcome>success</from-outcome>
     743 
     744                   <to-view-id>/result.jsp</to-view-id>
     745 
     746             </navigation-case>
     747 
     748 </navigation-rule>
     749 
     750 5、jsf中用户界面组件模型有几类,各代表什么?
     751 UI组件、事件监听、显示、类型转换、验证
     752 
     753 6、表格处理及取值
     754 import javax.faces.model.DataModel;
     755 
     756 import javax.faces.model.ListDataModel;
     757 
     758     DataModel:代表一个表格,其可以从客户端传上来。
     759 
     760         实例化:
     761 
     762             DataModel dm=new ListDataModel();
     763 
     764         将一个list值放入到DataModel中. 
     765 
     766             dm.setWrappedData(list)
     767 
     768         将客户端当前行取出
     769 
     770             (LogsVO) dm.getRowData()
     771 
     772 对于多条的查询及增删改在模型中加入了如下属性:       
     773 
     774     模型的名称是bean,其下的属性是
     775 
     776         DataModel dm:代表返有的行数据
     777 
     778         VO vo:代表一行数据。
     779 
     780             取一行:
     781 
     782                 vo=(VO) dm.getRowData();
     783 
     784                 通#{bean.vo.属性名},如果修改对应信息自动修改。
     785 
     786             增加一行:
     787 
     788                 this.vo=new VO();
     789 
     790                 通#{bean.vo.属性名},显示肯定无值,但客户输入值提交后会将值勤写入
     791 
     792 7、jsf的标签库有哪些?
     793     核心:f
     794 
     795         校验
     796 
     797             <f:validateDoubleRange>
     798 
     799             <f:validateLength>
     800 
     801         转化
     802 
     803             <f:convertDateTime pattern="yyyy-MM-dd"/>           
     804 
     805             <f:convertNumber type="currency"/>
     806 
     807         选择框:
     808 
     809             <f:selectItem/>
     810 
     811             <f:selectItems/>
     812 
     813         
     814 
     815     html:h
     816 
     817         选择控件:
     818 
     819             <h:selectOneRadio>:一个string
     820 
     821             <h:selectManyCheckBox>:一个String数组
     822 
     823             <h:selectOneMenu>:组合框架选择一个  
     824 
     825             <h:selectManyMenu>:组合框架选择多个
     826 
     827             <h:selectOneList>:下拉列表选择一个  
     828 
     829             <h:selectManyList>:下拉列表选择多个
     830 
     831         表格:
     832 
     833             <h:dataTable value="集合" var="集合中的一个">
     834 
     835                 <h:column>
     836 
     837                     <!--头-->
     838 
     839                     <f:facet name=”header”>
     840 
     841                         <h:outputText >
     842 
     843                     </f:facet>  
     844 
     845                     <!--具体的行值-->
     846 
     847                     <h:outputText value=""/>
     848 
     849                 <h:column>              
     850 
     851             </h:dataTable>
     852 
     853 9 Spring 应用框架技术
     854 1、Spring和Struts的区别?
     855        strusts:是一种基于MVC模式的一个web层的处理。
     856        Spring:提供了通用的服务,ioc/di aop,关心的不仅仅web层,应当j2ee整体的一个服务,可以很容易融合不同的技术struts hibernate ibatis ejb remote springJDBC springMVC
     857 
     858 2、什么是aop,aop的作用是什么?
     859 Oop:纵向的业务
     860 
     861 Aop:oop的一个横向的服务,是对oop进一步的补充,提供安全、事务、日志等的集中式处理,相关的装备before、around、after exception
     862 
     863 3、aop中的关键名词有些那些,相互关系是什么? 
     864 拦截器: 代理
     865 
     866 装备(advice)
     867 
     868 目标对象
     869 
     870 关切点:条件
     871 
     872 连接点:方法、属性
     873 
     874 4、依赖注入的方式有几种,各是什么?
     875 Setter
     876 
     877 Interface
     878 
     879 constructor
     880 
     881 5、spring中的核心类有那些,各有什么作用?
     882 BeanFactory:产生一个新的实例,可以实现单例模式
     883 
     884 BeanWrapper:提供统一的get及set方法
     885 
     886 ApplicationContext:提供框架的实现,包括BeanFactory的所有功能
     887 
     888 6、ApplicationContext的作用
     889 beanFactory
     890 
     891 国际化(getMesage)
     892 
     893 资源管理:可以直接读取一个文件的内容(getResource)
     894 
     895 加入web框架中(加入一个servlet或监听器)
     896 
     897 事件处理
     898 
     899 7、如何实现资源管理
     900 使用
     901 
     902 applicationContext.getResource(“classpath:文件名”):在src根目录下,在类路径下
     903 
     904 applicationContext.getResource(“classpath:/chap01/文件名”): 以src根目录下的基准往下走。
     905 
     906 applicationContext.getResource(“file:c:/a.properties”):在系统文件目录下。
     907 
     908 8、如何实现加入web框架中
     909 在web.xml中加入如下同容,在启动web服务器时加载/WEB-INF/applicationContext.xml中的内容。
     910 
     911 <servlet>
     912 
     913 <servlet-name>context</servlet-name>
     914 
     915 <servlet-class>
     916 
     917 org.springframework.web.context.ContextLoaderServlet
     918 
     919 </servlet-class>
     920 
     921 <load-on-startup>1</load-on-startup>
     922 
     923 </servlet>
     924 
     925 通过如下类得到ApplicationContext实例
     926 
     927             WebApplicationContextUtils.getWebApplicationContext
     928 
     929 9、如何实现事件处理
     930 事件
     931 
     932         Extends ApplicationEvent
     933 
     934 监听器
     935 
     936         Implements ApplicationListener
     937 
     938 事件源
     939 
     940         Implements ApplicationContextAware
     941 
     942 在applicationContext.xml中配置事件源、监听器
     943 
     944 先得到事件源,调用事件源的方法,通知监听器。
     945 
     946 10、spring的ioc及di代表什么意思? 
     947 Ioc:程序在运行过程中,根据配置文件动态加载所依赖的配置类
     948 
     949 、如何在spring中实现国际化?
     950 ?  在applicationContext.xml加载一个bean
     951 
     952 <bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
     953 
     954         <property name="basename">
     955 
     956             <value>message</value>
     957 
     958         </property>
     959 
     960 </bean>
     961 
     962 ?  在src目录下建多个properties文件
     963 
     964 ?  对于非英文的要用native2ascii -encoding gb2312 源  目转化文件相关内容 
     965 
     966 ?  其命名格式是message_语言_国家。
     967 
     968 ?  页面中的中显示提示信息,键名取键值。
     969 
     970 ?  当给定国家,系统会自动加载对应的国家的properties信息。
     971 
     972 ?  通过applictionContext.getMessage(“键名”,”参数”,”区域”)取出相关的信息。
     973 
     974  
     975 
     976 12、spring的配置的主要标签是什么?有什么作用?
     977 <beans>
     978 
     979             <bean id=”” class=”” init=”” destroy=”” singleton=””>
     980 
     981                 <property name=””>
     982 
     983                     <value></value>
     984 
     985                 </property>
     986 
     987                 <property name=””>
     988 
     989                     <ref local></ref>
     990 
     991                 </property>
     992 
     993             </bean>
     994 
     995 </beans>
     996 
     997 13、spring与ejb2.0的事务管理比较的优缺点?
     998 测试:
     999 
    1000             Spring:pojo
    1001 
    1002             Ejb:二个接口一个类,一堆配置文件
    1003 
    1004 事务类型
    1005 
    1006             Spring:jdbc jta  hibernate
    1007 
    1008             Ejb:jta
    1009 
    1010 成本
    1011 
    1012            Spring:普通容器(tomcat jboss)
    1013 
    1014            Ejb:weblogic jboss
    1015 
    1016 开发的周期:
    1017 
    1018             Spring远比ejb快.
    1019 
    1020 14、spring的jdbc与传统的jdbc有什么区别,其核心类有那些?
    1021 Spring的jdbc:节省代码,不管连接(Connection),不管事务、不管异常、不管关闭(con.close() ps.close )
    1022 
    1023  
    1024 
    1025         JdbcTemplate(dataSource):增、删、改、查
    1026 
    1027         TransactionTemplate(transactionManager):进行事务处理
    1028 
    1029 15、在spring中有几种事务管理,分别是什么? 
    1030 代码管理的事务处理
    1031 
    1032 TransactonTemplate的execute方法中的内部类TransactionCallback中的doInTransaction方法中使用。
    1033 
    1034 public void make()
    1035 
    1036     {   
    1037 
    1038         TransactionTemplate jtm=new TransactionTemplate(this.getTransactionManager());
    1039 
    1040         jtm.execute(new myClass1());
    1041 
    1042     }
    1043 
    1044     public class myClass1 implements TransactionCallback
    1045 
    1046     {
    1047 
    1048  
    1049 
    1050         public Object doInTransaction(TransactionStatus trans) 
    1051 
    1052         {
    1053 
    1054             JdbcTemplate jdbc=new JdbcTemplate(dataSource);
    1055 
    1056             jdbc.execute("insert into customer(customerName) values('b')");
    1057 
    1058             jdbc.execute("insert into customer(customerName) values('b')");
    1059 
    1060             return null;
    1061 
    1062         }       
    1063 
    1064     }
    1065 
    1066             容器管理的事务处理
    1067 
    1068 16、在spring中如何配代码的事务管理?
    1069 Datasouce
    1070 
    1071             transactionManager
    1072 
    1073             userDao要注入
    1074 
    1075                 Datasouce
    1076 
    1077                 transactionManager
    1078 
    1079         通过如下类实现
    1080 
    1081                 TransactionTemplate
    1082 
    1083                 JdbcTemplate
    1084 
    1085 17、在spring中如何配容器的事务管理,相关的类有那些? 
    1086 Datasouce
    1087 
    1088             transactionManager
    1089 
    1090             userDao要注入
    1091 
    1092                 Datasouce
    1093 
    1094             Proxy代理
    1095 
    1096                 Target:userDao:代理对象(目标对象)
    1097 
    1098                 transactionAttributes(那些方法需要事务处理)
    1099 
    1100                 transactionManager(事务处理服务)
    1101 
    1102 18、如果spring与hibernate结合在一起可以不需要hibernate.cfg.xml文件是否正确?
    1103 不需要
    1104 
    1105 19、spring+hibernate的配置文件中的主要类有那些?如何配置?
    1106 在myeclipse中先加入spring环境再加入hibernate环境。
    1107 
    1108     如果spring与hibernate结合在一起可以不需要hibernate.cfg.xml文件是否正确?
    1109 
    1110     spring+hibernate的配置文件中的主要类有那些?如何配置?
    1111 
    1112         dataSource
    1113 
    1114         sessionFactory:hibernate.cfg.xml
    1115 
    1116         transactionManager
    1117 
    1118         userDao (extends HibernateDaoSupport)  
    1119 
    1120             sessionFactory
    1121 
    1122         facade
    1123 
    1124         proxy
    1125 
    1126             sessionFactory
    1127 
    1128             transactionManager
    1129 
    1130             facade
    1131 
    1132  
    1133 
    1134 20、spring+hibernate的代码实现中,对于实现类一定继承于一个类是那一个,它有什么作用。
    1135 extends HibernateDaoSupport,可以节省代码。
    1136 
    1137 21、如何配置spring+struts?
    1138 ?  在struts-config.xml加入一个插件,通过它加载applicationContext.xml
    1139 
    1140 ?  在struts-config.xml修改action-mapping标记,具体action交给了DelegateActionProxy
    1141 
    1142 ?  通过DelegateActionProxy进入一spring的环境。
    1143 
    1144 ?  在spring的applicationContext.xml加入<bean name="/login" class="" singleton="false"/>
    1145 
    1146 22、如何在web环境中配置applicationContext.xml文件?
    1147 <listener>
    1148 
    1149         <listener-class>
    1150 
    1151             org.springframework.web.context.ContextLoaderListener
    1152 
    1153         </listener-class>
    1154 
    1155     </listener>
    1156 
    1157     或:
    1158 
    1159     <servlet>
    1160 
    1161         <servlet-name>context</servlet-name>
    1162 
    1163             <servlet-class>
    1164 
    1165                 org.springframework.web.context.ContextLoaderServlet
    1166 
    1167             </servlet-class>
    1168 
    1169         <load-on-startup>1</load-on-startup>
    1170 
    1171     </servlet>
    1172 
    1173     通过如下方法取出applicationContext实例:
    1174 
    1175     ApplicationContext ac=WebApplicationContextUtils.getWebApplicationContext(this.getServletContext);
    1176 
    1177 24、Jsf和spring的区别?
    1178 jsf:是一种基于MVC模式的一个web层的处理,粒度较struts较细。
    1179        Spring:提供了通用的服务,ioc/di aop,关心的不仅仅web层,应当j2ee整体的一个服务,可以很容易融合不同的技术struts hibernate ibatis ejb remote springJDBC springMVC
    1180 
    1181  
    1182 
    1183 Ejb技术
    1184 1、weblogic的热发布
    1185        将ear、jar、war拷到C:eauser_projectsdomainsmydomainapplications目录
    1186 
    1187        weblogic会自动发布
    1188 
    1189        通过jbuilder将ear或jar或war部署到服务器上。
    1190 
    1191 2、在ejb中实现one-to-many
    1192        1、在many中的将外键字段属性删除
    1193 
    1194        2、在删除many中的值时要将Collection转化为ArrayList,
    1195 
    1196           并反向遍历ArrayList,先删除ArrayList中值,根据
    1197 
    1198           ArrayList删除反回的对象转化为many的远程接口,通过
    1199 
    1200           远程接口将many删除
    1201 
    1202 3、ejb所用的技术:
    1203 Jndi:java naming directory inferface
    1204 
    1205 Rmi:     remote method invoke 
    1206 
    1207 4、实现ejb几个接口,几个类?
    1208        两个接口一个类
    1209 
    1210        extends EJBHome
    1211 
    1212               通过jndi得到home接口
    1213 
    1214               create方法调用服务端的ejbCreate方法,在服务端产生一个EntityBean或SessionBean实例,向客户端返回一个远程接口。
    1215 
    1216               通过find方法在从服务端找到一个EntityBean实例,向客户端返回一个远程接口。
    1217 
    1218        extends EJBObject
    1219 
    1220               在客户端通过rmi调用远程服务端方法。
    1221 
    1222               通过remove方法调用服务端的ejbRemove方法,将EnityBean删除
    1223 
    1224        implements SessionBean
    1225 
    1226               在服务端实现真正的处理,实现核心业务
    1227 
    1228 5、实现ejb相关的配置文件是什么?
    1229        ejb-jar.xml:说明ejb的两个接口一个类的。
    1230 
    1231        weblogic-ejb-jar.xml:说明ejb的JNDI名
    1232 
    1233        weblogic-rdbms-ejb.xml:o-rMapping实现数据库表、字段与ejb属性对应的关系。
    1234 
    1235 ejb2.0的开发
    1236 
    1237        1、用jbuilder集成环境
    1238 
    1239        2、可以用eclipse开发,用源代码注释说明,用ant执行xdoclet,xdoclet通
    1240 
    1241               过源代码注释自动生相关的配置、两个接口一个类。
    1242 
    1243               /**
    1244 
    1245               *     @stateLess
    1246 
    1247               *     @remote 
    1248 
    1249               */
    1250 
    1251 6、ejb的分类?区别
    1252        sessionBean
    1253 
    1254               stateless:方法间不保留(1..1)
    1255 
    1256               statefull:方法间保留(1..n)
    1257 
    1258        entityBean:持久化
    1259 
    1260               cmp:增删改容器
    1261 
    1262               bmp:增删改手动jdbc
    1263 
    1264        message driver bean
    1265 
    1266               异处的消息处理
    1267 
    1268 7、本地接口与远程接口的区别。
    1269        EJBHome(在不同的进程或主机间调用,即不同的jvm)
    1270 
    1271        EJBObjet
    1272 
    1273        EJBLocalHome(在同一进程,同是jvm中)
    1274 
    1275        EJBLocalObject      
    1276 
    1277 8、请求处理的过程? 
    1278        会话
    1279 
    1280               url
    1281 
    1282               factory
    1283 
    1284        通过jndi得到一个home实例
    1285 
    1286        在客户端通过home实例在服务端产生一个sessionBean,客户端返回一个接口
    1287 
    1288        客户端通过远程接口调用方法。
    1289 
    1290 9、statefull的生命周期
    1291        不存在
    1292 
    1293               setSessionContext
    1294 
    1295               create--->ejbcreate 
    1296 
    1297        就绪:可以调用remove方法将sessionBean删除、可以调用服务端的任何方法。
    1298 
    1299               ejbPassivate(从就绪到挂起)
    1300 
    1301               ejbActivate(从挂起到就绪)
    1302 
    1303        挂起       
    1304 
    1305               如果超时自动删除
    1306 
    1307 10、stateless的生命周期
    1308        不存在
    1309 
    1310               setSessionContext
    1311 
    1312               create--->ejbcreate
    1313 
    1314               remove-->ejbremove
    1315 
    1316        就绪
    1317 
    1318 11、entityBean的生命周期:
    1319        不存在
    1320 
    1321               setEntityContext
    1322 
    1323               create--->ejbcreate
    1324 
    1325        入池
    1326 
    1327               空房子,没加载数据
    1328 
    1329               ejbActivate
    1330 
    1331               ejbPassivate
    1332 
    1333        就绪
    1334 
    1335               remove-->ejbRemove
    1336 
    1337               加载了数据库的数据
    1338 
    1339  
    1340 
    1341 12、EJB需直接实现它的业务接口或Home接口吗,请简述理由。
    1342 远程接口和Home接口不需要直接实现,
    1343 
    1344 他们的实现代码是由服务器产生的,
    1345 
    1346 程序运行中通过接口调用服务端产生的实例。
    1347 
    1348  
    1349 
    1350 13、EJB的激活机制
    1351 以Stateful Session Bean 为例:其Cache大小决定了内存中可以同时存在的Bean实例的数量,根据MRU或NRU算法,实例在就绪和挂起状态之间迁移。
    1352 
    1353  
    1354 
    1355 就绪:从文件到内存,调用ejbActivate方法
    1356 
    1357 挂起:从内存到文件,调用ejbPassivate方法
    1358 
    1359 14、EJB是基于哪些技术实现的?并说 出SessionBean和EntityBean的区别,
    1360 EJB包括Session Bean、Entity Bean、Message Driven Bean,基于JNDI、RMI、JTA等技术实现.
    1361 
    1362 SessionBean在J2EE应用程序中被用来完成一些服务器端的业务操作。例如访问数据库、调用其他EJB组件.
    1363 
    1364 EntityBean被用来代表应用系统中用到的数据.对于客户机,
    1365 
    1366 SessionBean是一种非持久性对象,它实现某些在服务器上运行的业务逻辑;
    1367 
    1368 EntityBean是一种持久性对象,它代表一个存储在持久性存储器中的实体的对象视图,或是一个由现有企业应用程序实现的实体.
    1369 
    1370 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 的优势却在于他可以维持使用者的状态.
    1371 
    1372  
    1373 
    1374 15、EJB的分类是什么?各有什么特点?
    1375 sessionBean:主机重起消失
    1376 
    1377     Stateless:不记忆
    1378 
    1379     StateFull:一个用户多个操作可记忆
    1380 
    1381 EntityBean:持久的数据库中
    1382 
    1383     Cmp:容器通过o/r mapping实现数据的持久化,不写sql,实现方便,在速度慢。
    1384 
    1385     Bmp:通过jdbc实现持久化,实现复杂,速度快
    1386 
    1387 messageBean:提供异步处理。
    1388 
    1389  
    1390 
    1391 10、EJB中主要的配置文件及作用是什么? 
    1392 EJB部署时需要三个文件:
    1393 
    1394 ?  Ejb-jar.xml:
    1395 
    1396 ?  将二个接口一个类打包在一起,给EJB一个名称。
    1397 
    1398 ?  说明当前的sessionBean的事务是由容器处理的。
    1399 
    1400 ?  其在所有的服务器上是通用的。
    1401 
    1402 ?  Weblogic-ejb-jar.xml:
    1403 
    1404 ?  将一个EJB名称,对应一个JNDI,在仅对weblogic服务器
    1405 
    1406 ?  Weblogic-rdbms-jar.xml:
    1407 
    1408 ?  实现o/r mapping的说明,相当于*.hbm.xml
    1409 
    1410 15、说出数据连接池的工作机制是什么?
    1411 容器或相关的应用程序在其池中实例化多个边接,当应用程序在使用时,容器直接将池中的连接取出应用程序直接使用,同时当应用程序使用完后,容器还可以将连接收回。从而提高系统的效率。
    1412 
    1413 16、EJB2.0有哪些内容?分别用在什么场合? EJB2.0和EJB1.1的区别?
    1414 sessionBean:是一个过程
    1415 
    1416 entityBean:是持久化,代表的是一个业务实体,有主键。
    1417 
    1418 Struts+sessionBean+entityBean
    1419 
    1420 EJB2.0加入的本地接口及本地home
    1421 
    1422 EJB1.1中只有远程接口及远程home
    1423 
    1424  
    1425 
    1426  
    1427 
    1428 18、EJB与JAVA BEAN的区别?
    1429 Java Bean 是可复用的组件,任何一个Java类都可以是一个Bean。但通常情况下,Java Bean是被容器所创建(如Tomcat)的,所以Java Bean具有如下特点:
    1430 
    1431  
    1432 
    1433 一个无参的构造器
    1434 
    1435 实现Serializable接口
    1436 
    1437 私有属性
    1438 
    1439 公有get set方法
    1440 
    1441  
    1442 
    1443 Enterprise Java Bean 是一个分布式组件,其特点是
    1444 
    1445 基于(RMI)技术的,可以被远程访问(跨进程、跨计算机)。
    1446 
    1447 EJB必须被布署在Webspere、WebLogic容器中,不能直接访问ejb,而是通过容器访问ejb,容器是ejb访问的一个代理。
    1448 
    1449 19、EJB的角色和三个对象
    1450 六个角色组成,分别是
    1451 
    1452 EJB组件开发者(Enterprise Bean Provider):sun
    1453 
    1454 应用组合者(Application Assembler)真正的开发商
    1455 
    1456 部署者(Deployer):
    1457 
    1458 EJB 服务器提供者(EJB Server Provider):sun ibm 小机
    1459 
    1460 EJB 容器提供者(EJB Container Provider):weblogic jboss
    1461 
    1462 系统管理员(System Administrator):维护员
    1463 
    1464 三个对象是Remote(Local)接口、Home(LocalHome)接口,Bean类
    1465 
    1466 20、EJB容器提供的服务
    1467 主要提供
    1468 
    1469 安全
    1470 
    1471 事务管理
    1472 
    1473 分布式
    1474 
    1475 jts
    1476 
    1477 声明周期管理
    1478 
    1479 代码产生
    1480 
    1481 持续性管理
    1482 
    1483 锁和并发行管理等服务。
    1484 
    1485 21、EJB规范规定EJB中禁止的操作有哪些?
    1486 1.不能操作线程和线程API(线程API指非线程对象的方法如notify,wait等),
    1487 
    1488 2.不能操作awt,
    1489 
    1490 3.不能实现服务器功能,
    1491 
    1492 4.不能对静态属生存取,
    1493 
    1494 5.不能使用IO操作直接存取文件系统,
    1495 
    1496 6.不能加载本地库.,
    1497 
    1498 7.不能将this作为变量和返回,
    1499 
    1500 8.不能循环调用。
    1501 
    1502 26、EJB的基本架构 
    1503 答:一个EJB包括三个部分: 
    1504 
    1505  
    1506 
    1507 Remote Interface 接口的代码 
    1508 
    1509 package Beans; 
    1510 
    1511 import javax.ejb.EJBObject; 
    1512 
    1513 import java.rmi.RemoteException; 
    1514 
    1515 public interface Add extends EJBObject 
    1516 
    1517 { 
    1518 
    1519 //some method declare 
    1520 
    1521 } 
    1522 
    1523 Home Interface 接口的代码 
    1524 
    1525 package Beans; 
    1526 
    1527 import java.rmi.RemoteException; 
    1528 
    1529 import jaax.ejb.CreateException; 
    1530 
    1531 import javax.ejb.EJBHome; 
    1532 
    1533 public interface AddHome extends EJBHome 
    1534 
    1535 { 
    1536 
    1537 //some method declare 
    1538 
    1539 } 
    1540 
    1541  
    1542 
    1543 EJB类的代码 
    1544 
    1545  
    1546 
    1547 package Beans; 
    1548 
    1549  
    1550 
    1551 import java.rmi.RemoteException; 
    1552 
    1553 import javax.ejb.SessionBean; 
    1554 
    1555 import javx.ejb.SessionContext; 
    1556 
    1557 public class AddBean Implements SessionBean 
    1558 
    1559 { 
    1560 
    1561 //some method declare 
    1562 
    1563 }
    1564 
    1565 30、如何在weblogic中进行ssl配置与客户端的认证配置或说说j2ee(标准)进行ssl的配置
    1566 缺省安装中使用DemoIdentity.jks和DemoTrust.jks KeyStore实现SSL,需要配置服务器使用Enable SSL,配置其端口,在产品模式下需要从CA获取私有密钥和数字证书,创建identity和trust keystore,装载获得的密钥和数字证书。可以配置此SSL连接是单向还是双向的。
    1567 
    1568 31如何查看在weblogic中已经发布的EJB?
    1569 可以使用管理控制台,在它的Deployment中可以查看所有已发布的EJB
    View Code

    五、WebService技术 javaee 设计模式

      1 1、什么是Web Service?
      2 Web Service就是为了使原来各孤立的站点之间的信息能够相互通信、共享而提出的一种接口。
      3 
      4 使用的技术:
      5 
      6 HTTP、XML、SOAP(简单对象访问协议)、WSDL
      7 
      8 优点:
      9 
     10     跨平台、跨语言、跨系统
     11 
     12 SOAP协议:
     13 
     14     SOAP协议(Simple Object Access Protocal,简单对象访问协议)
     15 
     16     Tcp/ipàhttp->soap,soap 通过xml文件传送信息
     17 
     18 缺点:
     19 
     20  (1).WebService使用了XML对数据封装,会造成大量的数据要在网络中传输。
     21 
     22  (2).WebService规范没有规定任何与实现相关的细节,包括对象模型、编程语言,这一点,它不如CORBA。
     23 
     24 2、什么是Web容器?
     25 实现J2EE规范中web协议的应用.该协议定义了web程序的运行时环境,包括:并发性,安全性,生命周期管理等等.
     26 
     27     就是在tomcat、weblogic下运行jsp、servlet、struts
     28 
     29 3、应用服务器有那些?
     30 BEA WebLogic Server,IBM WebSphere Application Server,Oracle9i Application Server,jBoss,Tomcat
     31 
     32 5、如何给weblogic指定大小的内存?
     33 在启动Weblogic的脚本中(位于所在Domian对应服务器目录下的startServerName),增加set MEM_ARGS=-Xms32m -Xmx200m,可以调整最小内存为32M,最大200M 
     34 
     35 6、如何设定的weblogic的热启动模式(开发模式)与产品发布模式?
     36 可以在管理控制台中修改对应服务器的启动模式为开发或产品模式之一。或者修改服务的启动文件或者commenv文件,增加set PRODUCTION_MODE=true 37 
     38 7、如何启动时不需输入用户名与密码?
     39 修改服务启动文件,增加 WLS_USER和WLS_PW项。也可以在boot.properties文件中增加加密过的用户名和密码.
     40 
     41 8、在weblogic管理制台中对一个应用域(或者说是一个网站,Domain)进行jms及ejb或连接池等相关信息进行配置后,实际保存在什么文件中?
     42 保存在此Domain的config.xml文件中,它是服务器的核心配置文件。
     43 
     44 9、说说weblogic中一个Domain的缺省目录结构?比如要将一个简单的helloWorld.jsp放入何目录下,然的在浏览器上就可打入 http://主机:端口号//helloword.jsp就可以看到运行结果了? 又比如这其中用到了一个自己写的javaBean该如何办?
     45 Domain 目录服务器目录applications,将应用目录放在此目录下将可以作为应用访问,如果是Web应用,应用目录需要满足Web应用目录要求,jsp文件可以直接放在应用目录中,Javabean需要放在应用目录的WEB-INF目录的classes目录中,设置服务器的缺省应用将可以实现在浏览器上无需输入应用名。
     46 
     47 12、CORBA是什么?用途是什么?
     48 CORBA 标准是公共对象请求代理结构(Common Object Request Broker Architecture),由对象管理组织 (Object Management Group,缩写为 OMG)标准化。它的组成是接口定义语言(IDL), 语言绑定(binding:也译为联编)和允许应用程序间互操作的协议。其目的为:用不同的程序设计语言书写在不同的进程中运行,为不同的操作系统开发。
     49 
     50 13、说说在weblogic中开发消息Bean时的persistent与non-persisten的差别
     51 persistent方式的MDB可以保证消息传递的可靠性,也就是如果EJB容器出现问题而JMS服务器依然会将消息在此MDB可用的时候发送过来,而non-persistent方式的消息将被丢弃。
     52 
     53 14、WEB SERVICE名词解释。JSWDL开发包的介绍。JAXP、JAXM的解释。SOAP、UDDI,WSDL解释。
     54 Web ServiceWeb Service是基于网络的、分布式的模块化组件,它执行特定的任务,遵守具体的技术规范,这些规范使得Web Service能与其他兼容的组件进行互操作。
     55 
     56 JAXP(Java API for XML Parsing) 定义了在Java中使用DOM, SAX, XSLT的通用的接口。这样在你的程序中你只要使用这些通用的接口,当你需要改变具体的实现时候也不需要修改代码。
     57 
     58 JAXM(Java API for XML Messaging) 是为SOAP通信提供访问方法和传输机制的API。
     59 
     60 WSDL是一种 XML 格式,用于将网络服务描述为一组端点,这些端点对包含面向文档信息或面向过程信息的消息进行操作。这种格式首先对操作和消息进行抽象描述,然后将其绑定到具体的网络协议和消息格式上以定义端点。相关的具体端点即组合成为抽象端点(服务)。
     61 
     62 SOAP即简单对象访问协议(Simple Object Access Protocol),它是用于交换XML编码信息的轻量级协议。
     63 
     64 UDDI 的目的是为电子商务建立标准;UDDI是一套基于Web的、分布式的、为Web Service提供的、信息注册中心的实现标准规范,同时也包含一组使企业能将自身提供的Web Service注册,以使别的企业能够发现的访问协议的实现标准。
     65 
     66 j2ee模式(MVC模式、Model1,Model2)
     67 1、j2ee常用的设计模式?说明工厂模式。
     68 Java中的23种设计模式:
     69 
     70 Factory(工厂模式), Builder(建造模式), Factory Method(工厂方法模式),
     71 
     72 Prototype(原始模型模式),Singleton(单例模式), Facade(门面模式),
     73 
     74 Adapter(适配器模式), Bridge(桥梁模式), Composite(合成模式),
     75 
     76 Decorator(装饰模式), Flyweight(享元模式), Proxy(代理模式),
     77 
     78 Command(命令模式), Interpreter(解释器模式), Visitor(访问者模式),
     79 
     80 Iterator(迭代子模式), Mediator(调停者模式), Memento(备忘录模式),
     81 
     82 Observer(观察者模式), State(状态模式), Strategy(策略模式),
     83 
     84 Template Method(模板方法模式), Chain Of Responsibleity(责任链模式)
     85 
     86 工厂模式:工厂模式是一种经常被使用到的模式,根据工厂模式实现的类可以根据提供的数据生成一组类中某一个类的实例,通常这一组类有一个公共的抽象父类并且实现了相同的方法,但是这些方法针对不同的数据进行了不同的操作。首先需要定义一个基类,该类的子类通过不同的方法实现了基类中的方法。然后需要定义一个工厂类,工厂类可以根据条件生成不同的子类实例。当得到子类的实例后,开发人员可以调用基类中的方法而不必考虑到底返回的是哪一个子类的实例。
     87 
     88 2、说说你所熟悉或听说过的j2ee中的几种常用模式?及对设计模式的一些看法
     89 Session Facade Pattern:使用SessionBean访问EntityBean
     90 
     91 Message Facade Pattern:实现异步调用
     92 
     93 EJB Command Pattern:使用Command JavaBeans取代SessionBean,实现轻量级访问
     94 
     95 Data Transfer Object Factory:通过DTO Factory简化EntityBean数据提供特性
     96 
     97 Generic Attribute Access:通过AttibuteAccess接口简化EntityBean数据提供特性
     98 
     99 Business Interface:通过远程(本地)接口和Bean类实现相同接口规范业务逻辑一致性
    100 
    101 ejb架构的设计好坏将直接影响系统的性能、可扩展性、可维护性、组件可重用性及开发效率。项目越复杂,项目队伍越庞大则越能体现良好设计的重要性。
    102 
    103 3、解释下面关于J2EE的名词
    104 (1)JNDI:Java Naming & Directory Interface,JAVA命名目录服务.主要提供的功能是:提供一个目录系统,让其它各地的应用程序在其上面留下自己的索引,从而满足快速查找和定位分布式应用程序的功能.
    105 
    106 (2)JMS:Java Message Service,JAVA消息服务.主要实现各个应用程序之间的通讯.包括点对点和广播.
    107 
    108 (3)JTA:Java Transaction API,JAVA事务服务.提供各种分布式事务服务.应用程序只需调用其提供的接口即可.
    109 
    110 (4)JAF: Java Action FrameWork,JAVA安全认证框架.提供一些安全控制方面的框架.让开发者通过各种部署和自定义实现自己的个性安全控制策略.
    111 
    112 (5)RMI:Remote Method Interface,远程方法调用
    113 
    114  
    115 
    116 4、介绍J2EE、J2SE、J2ME的区别。
    117 J2ee:企业级,主要的application server的web及应用服务
    118 
    119 J2se:标准版, 没有application server
    120 
    121 J2me:手机、pda的嵌入式开发
    122 
    123  
    124 
    125 5、开发中都用到了那些设计模式?用在什么场合?
    126 每个模式都描述了一个在我们的环境中不断出现的问题,然后描述了该问题的解决方案的核心。通过这种方式,你可以无数次地使用那些已有的解决方案,无需在重复相同的工作。主要用到了MVC的设计模式。用来开发JSP/Servlet或者J2EE的相关应用。简单工厂模式等。
    127 
    128 6、J2EE是什么?
    129 J2EE 是Sun公司提出的多层(multi-diered),分布式(distributed),基于组件(component-base)的企业级应用模型 (enterpriese application model).在这样的一个应用系统中,可按照功能划分为不同的组件,这些组件又可在不同计算机上,并且处于相应的层次(tier)中。所属层次包括客户层(clietn tier)组件,web层和组件,Business层和组件,企业信息系统(EIS)层。
    130 
    131 7、J2EE是技术还是平台还是框架?
    132     J2EE本身是一个标准,一个为企业分布式应用的开发提供的标准平台。
    133 
    134     J2EE也是一个框架,包括JDBC、JNDI、RMI、JMS、EJB、JTA等技术。
    View Code

    六、其他,软件工程

      1 1、当前主流的解析器有那些?
      2 DOM:文档对象模型(document object model)
      3 
      4 SAX
      5 
      6 2、Dom解析处理的过程是什么?
      7 package ss;
      8 
      9 import javax.xml.parsers.DocumentBuilderFactory;
     10 
     11 import javax.xml.parsers.DocumentBuilder;
     12 
     13 import org.w3c.dom.Document;
     14 
     15 import org.w3c.dom.Element;
     16 
     17 import org.w3c.dom.Node;
     18 
     19 import org.w3c.dom.Attr;
     20 
     21 import org.w3c.dom.NodeList;
     22 
     23 import javax.xml.transform.TransformerFactory;
     24 
     25 import javax.xml.transform.Transformer;
     26 
     27 import javax.xml.transform.dom.DOMSource;
     28 
     29 import javax.xml.transform.stream.StreamResult;
     30 
     31  
     32 
     33 public class XmlParser
     34 
     35 {
     36 
     37     public static void main(String[] args)
     38 
     39             throws Exception
     40 
     41     {
     42 
     43         xmlwriter();
     44 
     45     }
     46 
     47  
     48 
     49     public static void xmlparser()
     50 
     51             throws Exception
     52 
     53     {
     54 
     55         DocumentBuilderFactory xdf = DocumentBuilderFactory.newInstance();
     56 
     57         DocumentBuilder db = xdf.newDocumentBuilder();
     58 
     59         Document d = db.parse("C:\A1\customer.xml");
     60 
     61         NodeList nl = d.getElementsByTagName("customer");
     62 
     63         for (int i = 0; i < nl.getLength(); i++)
     64 
     65         {
     66 
     67  
     68 
     69             Element e = (Element) nl.item(i);
     70 
     71             Attr a = e.getAttributeNode("customerID");
     72 
     73             System.out.println(a.getNodeValue());
     74 
     75             NodeList nl1 = e.getElementsByTagName("customerName");
     76 
     77             System.out.println(nl1.item(0).getFirstChild().getNodeValue());
     78 
     79         }
     80 
     81     }
     82 
     83     public static void xmlwriter() throws Exception
     84 
     85     {
     86 
     87         DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
     88 
     89         DocumentBuilder db=dbf.newDocumentBuilder();
     90 
     91         Document d=db.parse("C:\A1\customer.xml");
     92 
     93         NodeList nl=d.getElementsByTagName("customerName");
     94 
     95         for(int i=0;i<nl.getLength();i++)
     96 
     97         {
     98 
     99            Element e=(Element) nl.item(i);
    100 
    101            System.out.println(e.getFirstChild().getNodeValue());
    102 
    103            e.getFirstChild().setNodeValue(e.getFirstChild().getNodeValue()+"111111111111111");
    104 
    105         }
    106 
    107         TransformerFactory tff=TransformerFactory.newInstance();
    108 
    109         Transformer tf=tff.newTransformer();
    110 
    111         tf.transform(new DOMSource(d),new StreamResult("c:\aa.xml"));
    112 
    113     }
    114 
    115 }
    116 
    117  
    118 
    119 DocumentBuilderFactory
    120 
    121               DocumentBuiler db
    122 
    123               Document d=db.parse(“具体文件路径”);
    124 
    125               NodeList nl=d.getElementsByTagName(“节点名”)
    126 
    127 3、Sax解析处理的过程是什么?
    128 import org.xml.sax.helpers.DefaultHandler;
    129 
    130 import org.xml.sax.SAXException;
    131 
    132 import org.xml.sax.Attributes;
    133 
    134 import javax.xml.parsers.SAXParser;
    135 
    136 import javax.xml.parsers.SAXParserFactory;
    137 
    138 public class SaxParser extends DefaultHandler
    139 
    140 {
    141 
    142     public void characters(char[] ch, int start, int length)
    143 
    144             throws SAXException
    145 
    146     {
    147 
    148         String temp=new String(ch,start,length);
    149 
    150         System.out.println(temp);
    151 
    152     }
    153 
    154  
    155 
    156     public void endDocument()
    157 
    158             throws SAXException
    159 
    160     {
    161 
    162         System.out.println("正在开始一个文档");
    163 
    164     }
    165 
    166  
    167 
    168     public void endElement(String namespaceURI, String localName, String qName)
    169 
    170             throws SAXException
    171 
    172     {
    173 
    174         System.out.println("结束元素"+qName);
    175 
    176     }
    177 
    178  
    179 
    180     public void startDocument()
    181 
    182             throws SAXException
    183 
    184     {
    185 
    186         System.out.println("开始文档");
    187 
    188     }
    189 
    190  
    191 
    192     public void startElement(String namespaceURI, String localName,
    193 
    194                              String qName, Attributes atts)
    195 
    196             throws SAXException
    197 
    198     {
    199 
    200          System.out.println("开始元素"+qName);
    201 
    202     }
    203 
    204     public static void main(String[] args) throws Exception
    205 
    206     {
    207 
    208         SAXParserFactory spf=SAXParserFactory.newInstance();
    209 
    210         SAXParser sp=spf.newSAXParser();
    211 
    212         sp.parse("C:\A1\customer.xml",new SaxParser());
    213 
    214     }
    215 
    216 }
    217 
    218 4、Dom与Sax相比它们的优缺点是什么?
    219 DOM可以访问任何一个节点,要将所有资源全部加载,比较耗内存,可以修改。
    220 
    221               SAX只能顺序读,不可随意访问,不可写,但速度快。
    222 
    223 1.         Dom中的核心接口有那些?
    224 
    225 Node
    226 
    227        TextNode 
    228 
    229 Element  
    230 
    231 Arr
    232 
    233 NodeList
    234 
    235 Document
    236 
    237 5、如何将Dom对象写入到文件中? 
    238 TransformerFactory
    239 
    240 Transformer通过如下方法进行处理
    241 
    242 Transformer(DOMSource(Document d),ResultStream(OutputStream o))
    243 
    244 6、用jdom解析xml文件时如何解决中文问题?
    245 类文件是utf-8,xml文件头也应是utf-8 如<?xml version="1.0" encoding="UTF-8" ?>
    246 
    247 7、XML文档定义有几种形式?它们之间有何本质区别?解析XML文档有哪几种方式?
    248 a: 两种形式 dtd  schema,
    249 
    250 b: 本质区别:schema本身是xml的,可以被XML解析器解析(这也是从DTD上发展schema的根本目的),
    251 
    252 c:有DOM,SAX,STAX等
    253 
    254  DOM:处理大型文件时其性能下降的非常厉害。这个问题是由DOM的树结构所造成的,这种结构占用的内存较多,而且DOM必须在解析文件之前把整个文档装入内存,适合对XML的随机访问
    255 
    256 SAX:不现于DOM,SAX是事件驱动型的XML解析方式。它顺序读取XML文件,不需要一次全部装载整个文件。当遇到像文件开头,文档结束,或者标签开头与标签结束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来处理XML文件,适合对XML的顺序访问
    257 
    258 STAX:Streaming API for XML (StAX)
    259 
    260  
    261 
    262 8、标准建模语言UML中的各种图?
    263 静态图
    264 
    265 用例图、类图、对象图、构件、部署,
    266 
    267 动态图(行为图)
    268 
    269 活动图,协作图,状态、时序
    270 
    271 9、BS与CS的联系与区别。
    272 C/S是Client/Server的缩写。服务器通常采用高性能的PC、工作站或小型机,并采用大型数据库系统,如Oracle、Sybase、Informix或 SQL Server。客户端需要安装专用的客户端软件。
    273 
    274 B/S是Brower/Server的缩写,客户机上只要安装一个浏览器(Browser),如Netscape Navigator或Internet Explorer,服务器安装Oracle、Sybase、Informix或 SQL Server等数据库。在这种结构下,用户界面完全通过WWW浏览器实现,一部分事务逻辑在前端实现,但是主要事务逻辑在服务器端实现。浏览器通过Web Server 同数据库进行数据交互。
    275 
    276 C/S 与 B/S 区别:
    277 
    278.硬件环境不同:
    279 
    280   C/S 一般建立在专用的网络上, 小范围里的网络环境, 局域网之间再通过专门服务器提供连接和数据交换服务.
    281 
    282   B/S 建立在广域网之上的, 不必是专门的网络硬件环境,例与电话上网, 租用设备. 信息自己管理. 有比C/S更强的适应范围, 一般只要有操作系统和浏览器就行
    283 
    284.对安全要求不同
    285 
    286   C/S 一般面向相对固定的用户群, 对信息安全的控制能力很强. 一般高度机密的信息系统采用C/S 结构适宜. 可以通过B/S发布部分可公开信息.
    287 
    288   B/S 建立在广域网之上, 对安全的控制能力相对弱, 可能面向不可知的用户。
    289 
    290.对程序架构不同
    291 
    292   C/S 程序可以更加注重流程, 可以对权限多层次校验, 对系统运行速度可以较少考虑.
    293 
    294   B/S 对安全以及访问速度的多重的考虑, 建立在需要更加优化的基础之上. 比C/S有更高的要求 B/S结构的程序架构是发展的趋势, 从MS的.Net系列的BizTalk 2000 Exchange 2000等, 全面支持网络的构件搭建的系统. SUN 和IBM推的JavaBean 构件技术等,使 B/S更加成熟.
    295 
    296.软件重用不同
    297 
    298   C/S 程序可以不可避免的整体性考虑, 构件的重用性不如在B/S要求下的构件的重用性好.
    299 
    300   B/S 对的多重结构,要求构件相对独立的功能. 能够相对较好的重用.就入买来的餐桌可以再利用,而不是做在墙上的石头桌子
    301 
    302.系统维护不同 
    303 
    304   C/S 程序由于整体性, 必须整体考察, 处理出现的问题以及系统升级. 升级难. 可能是再做一个全新的系统
    305 
    306   B/S 构件组成,方面构件个别的更换,实现系统的无缝升级. 系统维护开销减到最小.用户从网上自己下载安装就可以实现升级.
    307 
    308.处理问题不同
    309 
    310   C/S 程序可以处理用户面固定, 并且在相同区域, 安全要求高需求, 与操作系统相关. 应该都是相同的系统
    311 
    312   B/S 建立在广域网上, 面向不同的用户群, 分散地域, 这是C/S无法作到的. 与操作系统平台关系最小.
    313 
    314.用户接口不同
    315 
    316   C/S 多是建立的Window平台上,表现方法有限,对程序员普遍要求较高
    317 
    318   B/S 建立在浏览器上, 有更加丰富和生动的表现方式与用户交流. 并且大部分难度减低,减低开发成本.
    319 
    320.信息流不同
    321 
    322   C/S 程序一般是典型的中央集权的机械式处理, 交互性相对低
    323 
    324   B/S 信息流向可变化, B-B B-C B-G等信息、流向的变化, 更像交易中心。
    325 
    326 10、Uml的概念是什么?主要的工具是什么
    327 Uml:统一建模语言
    328 
    329 工具:Rational Rose
    330 
    331 11、Uml的概念中的九大图形是什么?最重的三个图是什么?各有什么特点?
    332 类图
    333 
    334        继承 
    335 
    336 关联:(1..n  n..1  n..n) 
    337 
    338 依赖 
    339 
    340 实现接口
    341 
    342 聚集
    343 
    344 组成
    345 
    346 类图的生命周期(开发的所有阶段都使用)
    347 
    348               总体设计
    349 
    350               详细设计
    351 
    352               开发:以类图进行开发
    353 
    354               测试
    355 
    356 Use-case图
    357 
    358        关系
    359 
    360                      用例与用例
    361 
    362 包含(include):必须调用
    363 
    364                             扩展(extends):可以调用也可以不调用
    365 
    366                      角色与角色的关系
    367 
    368                             泛化
    369 
    370                      用例与角色的关系:
    371 
    372                             用例与角色:通知
    373 
    374                             角色与用例:调用
    375 
    376               元素
    377 
    378                      用例
    379 
    380                      角色
    381 
    382                      系统边界
    383 
    384 Use-case图的生命周期
    385 
    386               需求
    387 
    388               整体设计
    389 
    390               测试(单元测试、集成测试、系统测试、用户验收) 
    391 
    392 时序
    393 
    394               元素
    395 
    396 横坐标:对象
    397 
    398 纵坐标:   时间
    399 
    400 作用
    401 
    402                      找类
    403 
    404                      找方法
    405 
    406                      验证系统的正确
    407 
    408 生命周期
    409 
    410                      详细设计
    411 
    412 活动(流程图)
    413 
    414 作用
    415 
    416                      分析业务
    417 
    418 构件图
    419 
    420        作用:说明组件与组件之间的关系,依赖关系
    421 
    422 部署
    423 
    424        作用:说明安装软件的主机之间的关系,系统运行时的性能的主要影响者。
    425 
    426 协作
    427 
    428        对象与对象之间的调用协作。
    429 
    430 状态
    431 
    432        一个对象状态在不同的动作下的变化。
    433 
    434        对象
    435 
    436               说明对象
    437 
    438 13、在类图中如何找类?
    439 找名词
    View Code

    七、数据库

      1   为管理岗位业务培训信息,建立3个表:
      2 
      3   S (S#,SN,SD,SA) S#,SN,SD,SA 分别代表学号、学员姓名、所属单位、学员年龄
      4 
      5   C (C#,CN ) C#,CN 分别代表课程编号、课程名称
      6 
      7   SC ( S#,C#,G ) S#,C#,G 分别代表学号、所选修的课程编号、学习成绩
      8 
      9   1. 使用标准SQL嵌套语句查询选修课程名称为’税收基础’的学员学号和姓名
     10 
     11  
     12 
     13   --实现代码:
     14 
     15  
     16 
     17   Select SN,SD FROM S Where [S#] IN( Select [S#] FROM C,SC Where C.[C#]=SC.[C#] AND CN=N'税收基础')  
     18 
     19  
     20 
     21   2. 使用标准SQL嵌套语句查询选修课程编号为’C2’的学员姓名和所属单位
     22 
     23  
     24 
     25   --实现代码:
     26 
     27  
     28 
     29   Select S.SN,S.SD FROM S,SC Where S.[S#]=SC.[S#] AND SC.[C#]='C2'
     30 
     31  
     32 
     33   3. 使用标准SQL嵌套语句查询不选修课程编号为’C5’的学员姓名和所属单位
     34 
     35  
     36 
     37   --实现代码:
     38 
     39  
     40 
     41   Select SN,SD FROM S Where [S#] NOT IN( Select [S#] FROM SC
     42 
     43  Where [C#]='C5')
     44 
     45  
     46 
     47   4. 使用标准SQL嵌套语句查询选修全部课程的学员姓名和所属单位
     48 
     49 http://www.ad0.cn/netfetch/
     50 
     51   --实现代码:
     52 
     53  
     54 
     55   Select SN,SD FROM S Where [S#] IN( Select [S#] FROM SC RIGHT JOIN
     56 
     57  C ON SC.[C#]=C.[C#] GROUP BY [S#] HAVING COUNT(*)=COUNT([S#]))
     58 
     59  
     60 
     61   5. 查询选修了课程的学员人数
     62 
     63  
     64 
     65   --实现代码:
     66 
     67  
     68 
     69   Select 学员人数=COUNT(DISTINCT [S#]) FROM SC
     70 
     71  
     72 
     73   6. 查询选修课程超过5门的学员学号和所属单位
     74 
     75  
     76 
     77   --实现代码:
     78 
     79   Select SN,SD FROM S Where [S#] IN( Select [S#] FROM SC GROUP BY [S#] HAVING COUNT(DISTINCT [C#])>5)
     80 
     81       题目2
     82 
     83  
     84 
     85   问题描述:
     86 
     87   已知关系模式:
     88 
     89   S (SNO,SNAME) 学生关系。SNO 为学号,SNAME 为姓名
     90 
     91   C (CNO,CNAME,CTEACHER) 课程关系。CNO 为课程号,CNAME 为课程名,CTEACHER 为任课教师
     92 
     93   SC(SNO,CNO,SCGRADE) 选课关系。SCGRADE 为成绩
     94 
     95   
     96 
     97 1. 找出没有选修过“李明”老师讲授课程的所有学生姓名
     98 
     99  
    100 
    101   --实现代码:
    102 
    103  
    104 
    105   Select SNAME FROM S Where NOT EXISTS( Select * FROM SC,C Where SC.CNO=C.CNO  AND CNAME='李明' AND SC.SNO=S.SNO)
    106 
    107  
    108 
    109   2. 列出有二门以上(含两门)不及格课程的学生姓名及其平均成绩
    110 
    111  
    112 
    113   --实现代码:
    114 
    115  
    116 
    117   Select S.SNO,S.SNAME,AVG_SCGRADE=AVG(SC.SCGRADE)  FROM S,SC,(
    118 
    119  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
    120 
    121  
    122 
    123   3. 列出既学过“1”号课程,又学过“2”号课程的所有学生姓名
    124 
    125  
    126 
    127   --实现代码:
    128 
    129  
    130 
    131   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
    132 
    133  
    134 
    135   4. 列出“1”号课成绩比“2”号同学该门课成绩高的所有学生的学号
    136 
    137  
    138 
    139   --实现代码:
    140 
    141   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
    142 
    143  
    144 
    145   5. 列出“1”号课成绩比“2”号课成绩高的所有学生的学号及其“1”号课和“2”号课的成绩
    146 
    147  
    148 
    149   --实现代码:
    150 
    151  
    152 
    153   Select S.SNO,S.SNAME,SC.[1号课成绩],SC.[2号课成绩] FROM S,(
    154 
    155  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
    156 
    157  )SC Where S.SNO=SC.SNO
    158 
    159  
    View Code
  • 相关阅读:
    简单工厂,工厂方法和抽象工厂
    谈谈类之间的关联关系与依赖关系(转载)
    redis-cli 命令操作 Redis 五种数据类型
    深入分析java中的反射机制
    深入分析Java中String、StringBuilder、StringBuffer的区别
    String类型为什么设计成不可变的?
    java集合系列(5)LinkedList
    java集合系列(4)fail-fast机制(面试常问)
    java集合系列(3)ArrayList
    java集合系列(2)collection
  • 原文地址:https://www.cnblogs.com/tk55/p/8612264.html
Copyright © 2011-2022 走看看