哪个兄弟姐妹有JAVA入门或最基础的试题吗
郁闷~自考教材找不到学校给的电子文档让我们学习,马上要考试了求个JAVA最基础的试题,谢谢~~
我刚学呀,头晕晕找不到东西南北,望各位前辈帮帮忙!

解决方案 »

  1.   

    www.g.cn搜索java面试题集,只能找一部分了,或者找sun的java证的考试题
      

  2.   

    以下是面试的时候最容易出的几十个基础题目!是自己收藏的.
     ------希望对楼主有用!
    1、面向对象的特征有哪些方面 ?请详细描述   
    抽象 :面向对象程序设计的基本要素是抽象,它是在父类中定义好子类的共有功能,而将功能的实现交给子类,根据自己的情况进行实现。
    封装:是一种把代码和代码所操作的数据捆绑在一起,使这两者不受外界干扰和误用的机制.封装可被理解为一种用做保护的包装器,以防止代码和数据被包装器外部所定义的其他代码任意访问
    继承 :是指一个对象从另一个对象中获得属性的过程,一个对象只需要在它的类中定义是它成为唯一的各个属性,然后从父类中继承它的通用属性
    多态:指一个方法只能有一个名称,但可以有许多形态,也就是程序中可以定义多个同名的方法,用"一个接口,多个方法"来描述.可以通过方法的参数和类型引用。
    2、String是最基本的数据类型吗?
    基本数据类型包括byte、int、char、long、float、double、boolean和short。
    java.lang.String类是final类型的,因此不可以继承这个类、不能修改这个类。为了提高效率节省空间,我们应该用StringBuffer类3、int 和 Integer 有什么区别
    Int 是基本数据类型,而Integer是为int提供的封装类
    4、String 和StringBuffer的区别
    JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类提供了数值不可改变的字符串。而这个StringBuffer类提供的字符串进行修改。当你知道字符数据要改变的时候你就可以使用StringBuffer。典型地,你可以使用StringBuffers来动态构造字符数据。
    5、运行时异常与一般异常有何异同?
    异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。6、说出ArrayList,Vector, LinkedList的存储性能和特性,并说明ArrayList和
    ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。
    7、Collection 和 Collections的区别。
    Collection是集合类的上级接口,继承与他的接口主要有Set 和List.
    Collections是针对集合类的一个帮助类,他提供一系列静态方法实现对各种集合的搜索、排序、线程安全化等操作。 8、&和&&的区别。 
      &是位运算符,表示按位与运算,&&是逻辑运算符,表示逻辑与(and)。
    9、HashMap和Hashtable的区别。 
    HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于Hashtable。
    HashMap允许将null作为一个entry的key或者value,而Hashtable不允许。
    HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因为contains方法容易让人引起误解。 
    Hashtable继承自Dictionary类,而HashMap是Java1.2引进的Map interface的一个实现。
    最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多个线程访问Hashtable时,不需要自己为它的方法实现同步,而HashMap 就必须为之提供外同步。 
    Hashtable和HashMap采用的hash/rehash算法都大概一样,所以性能不会有很大的差异。
    10、final, finally, finalize的区别。 
    final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。
    finally是异常处理语句结构的一部分,表示总是执行。
    finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等。
    11、Overload和Override的区别。Overloaded的方法是否可以改变返回值的类型?
    方法的重写Overriding和重载Overloading是Java多态性的不同表现。重写Overriding是父类与子类之间多态性的一种表现,重载Overloading是一个类中多态性的一种表现。如果在子类中定义某方法与其父类有相同的名称和参数,我们说该方法被重写 (Overriding)。子类的对象使用这个方法时,将调用子类中的定义,对它而言,父类中的定义如同被"屏蔽"了。如果在一个类中定义了多个同名的方法,它们或有不同的参数个数或有不同的参数类型,则称为方法的重载(Overloading)。Overloaded的方法是可以改变返回值的类型。12、error和exception有什么区别?
    error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出。不可能指望程序能处理这样的情况。
    exception 表示一种设计或实现问题。也就是说,它表示如果程序运行正常,从不会发生的情况。
    13、同步和异步有何异同,在什么情况下分别使用他们?举例说明。
    如果数据将在线程间共享。例如正在写的数据以后可能被另一个线程读到,或者正在读的数据可能已经被另一个线程写过了,那么这些数据就是共享数据,必须进行同步存取。
    当应用程序在对象上调用了一个需要花费很长时间来执行的方法,并且不希望让程序等待方法的返回时,就应该使用异步编程,在很多情况下采用异步途径往往更有效率。14、abstract class和interface有什么区别?
    声明方法的存在而不去实现它的类被叫做抽象类(abstract class),它用于要创建一个体现某些基本行为的类,并为该类声明方法,但不能在该类中实现该类的情况。不能创建abstract 类的实例。然而可以创建一个变量,其类型是一个抽象类,并让它指向具体子类的一个实例。不能有抽象构造函数或抽象静态方法。Abstract 类的子类为它们父类中的所有抽象方法提供实现,否则它们也是抽象类为。取而代之,在子类中实现该方法。知道其行为的其它类可以在类中实现这些方法。
    接口(interface)是抽象类的变体。在接口中,所有方法都是抽象的。多继承性可通过实现这样的接口而获得。接口中的所有方法都是抽象的,没有一个有程序体。接口只可以定义static final成员变量。接口的实现与子类相似,除了该实现类不能从接口定义中继承行为。当类实现特殊接口时,它定义(即将程序体给予)所有这种接口的方法。然后,它可以在实现了该接口的类的任何对象上调用接口的方法。由于有抽象类,它允许使用接口名作为引用变量的类型。通常的动态联编将生效。引用可以转换到接口类型或从接口类型转换,instanceof 运算符可以用来决定某对象的类是否实现了接口。15、heap和stack有什么区别。
    栈是一种线形集合,其添加和删除元素的操作应在同一段完成。栈按照后进先出的方式进行处理。
    堆是栈的一个组成元素16、Static Nested Class 和 Inner Class的不同。 
    17、什么时候用assert。 
       assertion(断言)在软件开发中是一种常用的调试方式,很多开发语言中都支持这种机制。在实现中,assertion就是在程序中的一条语句,它对一个boolean表达式进行检查,一个正确程序必须保证这个boolean表达式的值为true;如果该值为false,说明程序已经处于不正确的状态下,系统将给出警告或退出。一般来说,assertion用于保证程序最基本、关键的正确性。assertion检查通常在开发和测试时开启。为了提高性能,在软件发布后,assertion检查通常是关闭的。18、GC是什么? 为什么要有GC? 
    GC是垃圾收集的意思(Gabage Collection),内存处理是编程人员容易出现问题的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃,Java提供的GC功能可以自动监测对象是否超过作用域从而达到自动回收内存的目的,Java语言没有提供释放已分配内存的显示操作方法。19、short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错? 
        short s1 = 1; s1 = s1 + 1; (s1+1运算结果是int型,需要强制转换类型)
    short s1 = 1; s1 += 1;(可以正确编译)20、Math.round(11.5)等於多少? Math.round(-11.5)等於多少? 
    Math.round(11.5)==12
    Math.round(-11.5)==-1121、String s = new String("xyz");创建了几个String Object? 
    两个22、Java有没有goto?
    java中的保留字,现在没有在java中使用。23、给我一个你最常见到的runtime exception。
    ArithmeticException, ArrayStoreException, BufferOverflowException, BufferUnderflowException, CannotRedoException, CannotUndoException, ClassCastException24、接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是
    接口可以继承接口。抽象类可以实现(implements)接口,抽象类是否可继承实体类,但前提是实体类必须有明确的构造函数。
    25、List, Set, Map是否继承自Collection接口?
     List,Set是,Map不是
    26、Object类的概述并列出其常用方法
    27、abstract的method是否可同时是static,是否可同时是native,是否可同   时是synchronized?
    都不能28、数组有没有length()这个方法? String有没有length()这个方法?
    数组没有length()这个方法,有length的属性。String有有length()这个方法。29、Set里的元素是不能重复的,那么用什么方法来区分重复与否呢? 是用==还是equals()? 它们有何区别?。
    Set里的元素是不能重复的,那么用iterator()方法来区分重复与否。equals()是判读两个Set是否相等。
        equals()和==方法决定引用值是否指向同一对象equals()在类中被覆盖,为的是当两个分离的对象的内容和类型相配的话,返回真值。30、构造器Constructor是否可被override?
    构造器Constructor不能被继承,因此不能重写Overriding,但可以被重载Overloading。31、是否可以继承String类?
    String类是final类故不可以继承。32、swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
    switch(expr1)中,expr1是一个整数表达式。因此传递给 switch 和 case 语句的参数应该是 int、 short、 char 或者 byte。long,string 都不能作用于swtich。
    33、try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,在return前还是后?
    会执行,在return前执行。
    34、编程题: 用最有效率的方法算出2乘以8等於几? 
    2 << 3
    35、两个对象值相同(x.equals(y) == true),但却可有不同的hash code,这句话对不对?
    不对,有相同的hash code
    36、当一个对象被当作参数传递到一个方法后,此方法可改变这个对象的属性,并可返回变化后的结果,那么这里到底是值传递还是引用传递? 
    是值传递。Java 编程语言只有值传递参数。当一个对象实例作为一个参数被传递到方法中时,参数的值就是对该对象的引用。对象的内容可以在被调用的方法中改变,但对象的引用是永远不会改变的。
    37、编程题: 写一个Singleton出来。
    public class Singleton { 
      private static Singleton instance = null;
      public static synchronized Singleton getInstance() {
      if (instance==null)
        instance=new Singleton();
    return instance;   } 

    38、写一个简单工厂模式的类。
    public class FrameFactory {
    private Map frameMap;
    private static FrameFactory factory;
    private int mapSize=3;
    private String name=null;
    private FrameFactory(String name){
    this.name=name;
    frameMap=new HashMap(mapSize);
    init();
    }
    public synchronized static FrameFactory getInstance(String name){
    factory=new FrameFactory(name);
    return factory;
    }
    private void init(){
    frameMap.put("管理员",new ManagerMainFrame(name));
    frameMap.put("销售员",new SaleFrame()); }
    public JFrame getFrame(String type){

    if(frameMap.containsKey(type)){
    return (JFrame)frameMap.get(type);
    }
    return null;
    }
    }
    39、Java中的异常处理机制的简单原理和应用。
    当JAVA程序违反了JAVA的语义规则时,JAVA虚拟机就会将发生的错误表示为一个异常。违反语义规则包括2种情况。一种是JAVA类库内置的语义检查。例如数组下标越界,会引发IndexOutOfBoundsException;访问null的对象时会引发NullPointerException。另一种情况就是JAVA允许程序员扩展这种语义检查,程序员可以创建自己的异常,并自由选择在何时用throw关键字引发异常。所有的异常都是java.lang.Thowable的子类。
    40、垃圾回收的优点和原理。并考虑2种回收机制。
    Java语言中一个显著的特点就是引入了垃圾回收机制,使c++程序员最头疼的内存管理的问题迎刃而解,它使得Java程序员在编写程序的时候不再需要考虑内存管理。由于有个垃圾回收机制,Java中的对象不再有"作用域"的概念,只有对象的引用才有"作用域"。垃圾回收可以有效的防止内存泄露,有效的使用可以使用的内存。垃圾回收器通常是作为一个单独的低级别的线程运行,不可预知的情况下对内存堆中已经死亡的或者长时间没有使用的对象进行清楚和回收,程序员不能实时的调用垃圾回收器对某个对象或所有对象进行垃圾回收。回收机制有分代复制垃圾回收和标记垃圾回收,增量垃圾回收。
    41、你所知道的集合类都有哪些?主要方法?
    最常用的集合类是 List 和 Map。 List 的具体实现包括 ArrayList 和 Vector,它们是可变大小的列表,比较适合构建、存储和操作任何类型对象的元素列表。 List 适用于按数值索引访问元素的情形。 
    Map 提供了一个更通用的元素存储方法。 Map 集合类用于存储元素对(称作"键"和"值"),其中每个键映射到一个值。
    42、描述一下JVM加载class文件的原理机制?
    JVM中类的装载是由ClassLoader和它的子类来实现的,Java ClassLoader 是一个重要的Java运行时系统组件。它负责在运行时查找和装入类文件的类。
    43、简述逻辑操作(&,|,^)与条件操作(&&,||)的区别。
    &,|,^是逻辑运算,&&,||是短路运算,逻辑运算在任何情况下运算符两边的操作都要参与运算,短路运算是 如果一个表达式的值决定了各个表达式就不进行后续表达式的计算44、一个".java"源文件中是否可以包括多个类(不是内部类)?有什么限制?。。
    可以。必须只有一个类名与文件名相同。
    45、请详细描述面向对象六大设计原则
    一、“开-闭”原则: 一个软件实体应当对扩展开放,对修改关闭。即在设计一个模块的时候,应当使这个模块可以在不被修改的前提下被扩展。
    二、里氏代换原则: 如果对每一个类型为T1的对象O1,都有类型为T2 的对象O2,使得以T1定义的所有程序P在所有的对象O1都代换为O2时,程序P的行为没有变化,那么类型T2是类型T1的子类型。
    三、 依赖倒转原则: 就是要依赖于抽象,不要依赖于实现。要针对接口编程,不要针对实现编程。
    四、合成/聚合复用原则: 在一个新的对象里面使用一些已有的对象,使之成为新对象的一部分;新的对象通过向这些对象的委派达到复用这些对象的目的。
    五、 迪米特法则: 一个软件实体应当尽可能少的与其他实体发生相互作用。
    六、接口隔离原则:使用多个专门的接口比使用单一的总接口要好。也就是说,一个类对另外一个类的依赖性应当是建立在最小的接口上。 
      

  3.   

    Java基础方面: 1、作用域public,private,protected,以及不写时的区别 
    答:区别如下: 
    作用域 当前类 同一package 子孙类 其他package 
    public √ √ √ √ 
    protected √ √ √ × 
    friendly √ √ × × 
    private √ × × × 
    不写时默认为friendly 2、ArrayList和Vector的区别,HashMap和Hashtable的区别 
    答:就ArrayList与Vector主要从二方面来说. 
    一.同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程序不安全的,不是同步的 
    二.数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半 
    就HashMap与HashTable主要从三方面来说。 
    一.历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现 
    二.同步性:Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步的 
    三.值:只有HashMap可以让你将空值作为一个表的条目的key或value 3、char型变量中能不能存贮一个中文汉字?为什么? 
    答:是能够定义成为一个中文的,因为java中以unicode编码,一个char占16个字节,所以放一个中文是没问题的 4、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么? 
    答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口 
    同步的实现方面有两种,分别是synchronized,wait与notify 5、继承时候类的执行顺序问题,一般都是选择题,问你将会打印出什么? 
    答:父类: 
    package test; 
    public class FatherClass 

    public FatherClass() 

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


    子类: 
    package test; 
    import test.FatherClass; 
    public class ChildClass extends FatherClass 

    public ChildClass() 

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

    public static void main(String[] args) 

    FatherClass fc = new FatherClass(); 
    ChildClass cc = new ChildClass(); 


    输出结果: 
    C:\>java test.ChildClass 
    FatherClass Create 
    FatherClass Create 
    ChildClass Create 6、内部类的实现方式? 
    答:示例代码如下: 
    package test; 
    public class OuterClass 

    private class InterClass 

    public InterClass() 

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


    public OuterClass() 

    InterClass ic = new InterClass(); 
    System.out.println("OuterClass Create"); 

    public static void main(String[] args) 

    OuterClass oc = new OuterClass(); 


    输出结果: 
    C:\>java test/OuterClass 
    InterClass Create 
    OuterClass Create 
    再一个例题: 
    public class OuterClass { 
    private double d1 = 1.0; 
    //insert code here 

    You need to insert an inner class declaration at line 3. Which two inner class declarations are valid?(Choose two.) 
    A. class InnerOne{ 
    public static double methoda() {return d1;} 

    B. public class InnerOne{ 
    static double methoda() {return d1;} 

    C. private class InnerOne{ 
    double methoda() {return d1;} 

    D. static class InnerOne{ 
    protected double methoda() {return d1;} 

    E. abstract class InnerOne{ 
    public abstract double methoda(); 

    说明如下: 
    一.静态内部类可以有静态成员,而非静态内部类则不能有静态成员。 故 A、B 错 
    二.静态内部类的非静态成员可以访问外部类的静态变量,而不可访问外部类的非静态变量;return d1 出错。 故 D 错 
    三.非静态内部类的非静态成员可以访问外部类的非静态变量。 故 C 正确 
    四.答案为C、E 7、垃圾回收机制,如何优化程序? 
    希望大家补上,谢谢 8、float型float f=3.4是否正确? 
    答:不正确。精度不准确,应该用强制类型转换,如下所示:float f=(float)3.4 9、介绍JAVA中的Collection FrameWork(包括如何写自己的数据结构)? 
    答:Collection FrameWork如下: 
    Collection 
    ├List 
    │├LinkedList 
    │├ArrayList 
    │└Vector 
    │ └Stack 
    └Set 
    Map 
    ├Hashtable 
    ├HashMap 
    └WeakHashMap 
    Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements) 
    Map提供key到value的映射 10、Java中异常处理机制,事件机制? 11、JAVA中的多形与继承? 
    希望大家补上,谢谢 12、抽象类与接口? 
    答:抽象类与接口都用于抽象,但是抽象类(JAVA中)可以有自己的部分实现,而接口则完全是一个标识(同时有多重继承的功能)。 13、Java 的通信编程,编程题(或问答),用JAVA SOCKET编程,读服务器几个字符,再写入本地显示? 
    答:Server端程序: 
    package test; 
    import java.net.*; 
    import java.io.*; public class Server 

    private ServerSocket ss; 
    private Socket socket; 
    private BufferedReader in; 
    private PrintWriter out; 
    public Server() 

    try 

    ss=new ServerSocket(10000); 
    while(true) 

    socket = ss.accept(); 
    String RemoteIP = socket.getInetAddress().getHostAddress(); 
    String RemotePort = ":"+socket.getLocalPort(); 
    System.out.println("A client come in!IP:"+RemoteIP+RemotePort); 
    in = new BufferedReader(new InputStreamReader(socket.getInputStream())); 
    String line = in.readLine(); 
    System.out.println("Cleint send is :" + line); 
    out = new PrintWriter(socket.getOutputStream(),true); 
    out.println("Your Message Received!"); 
    out.close(); 
    in.close(); 
    socket.close(); 

    }catch (IOException e) 

    out.println("wrong"); 


    public static void main(String[] args) 

    new Server(); 

    }; 
    Client端程序: 
    package test; 
    import java.io.*; 
    import java.net.*; public class Client 

    Socket socket; 
    BufferedReader in; 
    PrintWriter out; 
    public Client() 

    try 

    System.out.println("Try to Connect to 127.0.0.1:10000"); 
    socket = new Socket("127.0.0.1",10000); 
    System.out.println("The Server Connected!"); 
    System.out.println("Please enter some Character:"); 
    BufferedReader line = new BufferedReader(new InputStreamReader(System.in)); 
    out = new PrintWriter(socket.getOutputStream(),true); 
    out.println(line.readLine()); 
    in = new BufferedReader(new InputStreamReader(socket.getInputStream())); 
    System.out.println(in.readLine()); 
    out.close(); 
    in.close(); 
    socket.close(); 
    }catch(IOException e) 

    out.println("Wrong"); 


    public static void main(String[] args) 

    new Client(); 

    }; 14、用JAVA实现一种排序,JAVA类实现序列化的方法(二种)? 如在COLLECTION框架中,实现比较要实现什么样的接口? 
    答:用插入法进行排序代码如下 
    package test; 
    import java.util.*; 
    class InsertSort 

    ArrayList al; 
    public InsertSort(int num,int mod) 

    al = new ArrayList(num); 
    Random rand = new Random(); 
    System.out.println("The ArrayList Sort Before:"); 
    for (int i=0;i<num ;i++ ) 

    al.add(new Integer(Math.abs(rand.nextInt()) % mod + 1)); 
    System.out.println("al["+i+"]="+al.get(i)); 


    public void SortIt() 

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

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

    al.add(MaxSize,tempInt); 
    MaxSize++; 
    System.out.println(al.toString()); 
    } else { 
    for (int j=0;j<MaxSize ;j++ ) 

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

    al.add(j,tempInt); 
    MaxSize++; 
    System.out.println(al.toString()); 
    break; 




    System.out.println("The ArrayList Sort After:"); 
    for(int i=0;i<al.size();i++) 

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


    public static void main(String[] args) 

    InsertSort is = new InsertSort(10,100); 
    is.SortIt(); 


    JAVA类实现序例化的方法是实现java.io.Serializable接口 
    Collection框架中实现比较要实现Comparable 接口和 Comparator 接口 15、编程:编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。 但是要保证汉字不被截半个,如“我ABC”4,应该截为“我AB”,输入“我ABC汉DEF”,6,应该输出为“我ABC”而不是“我ABC+汉的半个”。 
    答:代码如下: 
    package test; class SplitString 

    String SplitStr; 
    int SplitByte; 
    public SplitString(String str,int bytes) 

    SplitStr=str; 
    SplitByte=bytes; 
    System.out.println("The String is:´"+SplitStr+"´;SplitBytes="+SplitByte); 

    public void SplitIt() 

    int loopCount; 
    loopCount=(SplitStr.length()%SplitByte==0)?(SplitStr.length()/SplitByte):(SplitStr.length()/Split Byte+1); 
    System.out.println("Will Split into "+loopCount); 
    for (int i=1;i<=loopCount ;i++ ) 

    if (i==loopCount){ 
    System.out.println(SplitStr.substring((i-1)*SplitByte,SplitStr.length())); 
    } else { 
    System.out.println(SplitStr.substring((i-1)*SplitByte,(i*SplitByte))); 



    public static void main(String[] args) 

    SplitString ss = new SplitString("test中dd文dsaf中男大3443n中国43中国人 0ewldfls=103",4); 
    ss.SplitIt(); 

    } 16、JAVA多线程编程。 用JAVA写一个多线程程序,如写四个线程,二个加1,二个对一个变量减一,输出。 
    希望大家补上,谢谢 17、STRING与STRINGBUFFER的区别。 
    答:STRING的长度是不可变的,STRINGBUFFER的长度是可变的。如果你对字符串中的内容经常进行操作,特别是内容要修改时,那么使用StringBuffer,如果最后需要String,那么使用StringBuffer的toString()方法 
      

  4.   

    Jsp方面 1、jsp有哪些内置对象?作用分别是什么? 
    答:JSP共有以下9种基本内置组件(可与ASP的6种内部组件相对应): 
     request 用户端请求,此请求会包含来自GET/POST请求的参数 
    response 网页传回用户端的回应 
    pageContext 网页的属性是在这里管理 
    session 与请求有关的会话期 
    application  servlet正在执行的内容 
    out 用来传送回应的输出 
    config servlet的构架部件 
    page JSP网页本身 
    exception 针对错误网页,未捕捉的例外 2、jsp有哪些动作?作用分别是什么? 
    答:JSP共有以下6种基本动作 
    jsp:include:在页面被请求的时候引入一个文件。 
    jsp:useBean:寻找或者实例化一个JavaBean。 
    jsp:setProperty:设置JavaBean的属性。 
    jsp:getProperty:输出某个JavaBean的属性。 
    jsp:forward:把请求转到一个新的页面。 
    jsp:plugin:根据浏览器类型为Java插件生成OBJECT或EMBED标记 3、JSP中动态INCLUDE与静态INCLUDE的区别? 
    答:动态INCLUDE用jsp:include动作实现 
    <jsp:include page="included.jsp" flush="true" />它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数 
    静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面 
    <%@ include file="included.htm" %> 4、两种跳转方式分别是什么?有什么区别? 
    答:有两种,分别为: 
    <jsp:include page="included.jsp" flush="true"> 
    <jsp:forward page= "nextpage.jsp"/> 
    前者页面不会转向include所指的页面,只是显示该页的结果,主页面还是原来的页面。执行完后还会回来,相当于函数调用。并且可以带参数.后者完全转向新页面,不会再回来。相当于go to 语句。 Servlet方面 1、说一说Servlet的生命周期? 
    答:servlet有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束。这个生存期由javax.servlet.Servlet接口的init,service和destroy方法表达。 2、Servlet版本间(忘了问的是哪两个版本了)的不同? 
    希望大家补上,谢谢 3、JAVA SERVLET API中forward() 与redirect()的区别? 
    答:前者仅是容器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址;后者则是完全的跳转,浏览器将会得到跳转的地址,并重新发送请求链接。这样,从浏览器的地址栏中可以看到跳转后的链接地址。所以,前者更加高效,在前者可以满足需要时,尽量使用forward()方法,并且,这样也有助于隐藏实际的链接。在有些情况下,比如,需要跳转到一个其它服务器上的资源,则必须使用sendRedirect()方法。 4、Servlet的基本架构 
    public class ServletName extends HttpServlet { 
    public void doPost(HttpServletRequest request, HttpServletResponse response) throws 
    ServletException, IOException { 

    public void doGet(HttpServletRequest request, HttpServletResponse response) throws 
    ServletException, IOException { 

    } Jdbc、Jdo方面 1、可能会让你写一段Jdbc连Oracle的程序,并实现数据查询. 
    答:程序如下: 
    package hello.ant; 
    import java.sql.*; 
    public class jdbc 

    String dbUrl="jdbc:oracle:thin:@127.0.0.1:1521:orcl"; 
    String theUser="admin"; 
    String thePw="manager"; 
    Connection c=null; 
    Statement conn; 
    ResultSet rs=null; 
    public jdbc() 

    try{ 
    Class.forName("oracle.jdbc.driver.OracleDriver").newInstance(); 
    c = DriverManager.getConnection(dbUrl,theUser,thePw); 
    conn=c.createStatement(); 
    }catch(Exception e){ 
    e.printStackTrace(); 


    public boolean executeUpdate(String sql) 

    try 

    conn.executeUpdate(sql); 
    return true; 

    catch (SQLException e) 

    e.printStackTrace(); 
    return false; 


    public ResultSet executeQuery(String sql) 

    rs=null; 
    try 

    rs=conn.executeQuery(sql); 

    catch (SQLException e) 

    e.printStackTrace(); 

    return rs; 

    public void close() 

    try 

    conn.close(); 
    c.close(); 

    catch (Exception e) 

    e.printStackTrace(); 


    public static void main(String[] args) 

    ResultSet rs; 
    jdbc conn = new jdbc(); 
    rs=conn.executeQuery("select * from test"); 
    try{ 
    while (rs.next()) 

    System.out.println(rs.getString("id")); 
    System.out.println(rs.getString("name")); 

    }catch(Exception e) 

    e.printStackTrace(); 


    } 2、Class.forName的作用?为什么要用? 
    答:调用该访问返回一个以字符串指定类名的类的对象。 3、Jdo是什么? 
    答:JDO是Java对象持久化的新的规范,为java data object的简称,也是一个用于存取某种数据仓库中的对象的标准化API。JDO提供了透明的对象存储,因此对开发人员来说,存储数据对象完全不需要额外的代码(如JDBC API的使用)。这些繁琐的例行工作已经转移到JDO产品提供商身上,使开发人员解脱出来,从而集中时间和精力在业务逻辑上。另外,JDO很灵活,因为它可以在任何数据底层上运行。JDBC只是面向关系数据库(RDBMS)JDO更通用,提供到任何数据底层的存储功能,比如关系数据库、文件、XML以及对象数据库(ODBMS)等等,使得应用可移植性更强。 4、在ORACLE大数据量下的分页解决方法。一般用截取ID方法,还有是三层嵌套方法。 
    答:一种分页方法 
    <% 
    int i=1; 
    int numPages=14; 
    String pages = request.getParameter("page") ; 
    int currentPage = 1; 
    currentPage=(pages==null)?(1):{Integer.parseInt(pages)} 
    sql = "select count(*) from tables"; 
    ResultSet rs = DBLink.executeQuery(sql) ; 
    while(rs.next()) i = rs.getInt(1) ; 
    int intPageCount=1; 
    intPageCount=(i%numPages==0)?(i/numPages):(i/numPages+1); 
    int nextPage ; 
    int upPage; 
    nextPage = currentPage+1; 
    if (nextPage>=intPageCount) nextPage=intPageCount; 
    upPage = currentPage-1; 
    if (upPage<=1) upPage=1; 
    rs.close(); 
    sql="select * from tables"; 
    rs=DBLink.executeQuery(sql); 
    i=0; 
    while((i<numPages*(currentPage-1))&&rs.next()){i++;} 
    %> 
    //输出内容 
    //输出翻页连接 
    合计:<%=currentPage%>/<%=intPageCount%><a href="List.jsp?page=1">第一页</a><a href="List.jsp?page=<%=upPage%>">上一页</a> 
    <% 
    for(int j=1;j<=intPageCount;j++){ 
    if(currentPage!=j){ 
    %> 
    <a href="list.jsp?page=<%=j%>">[<%=j%>]</a> 
    <% 
    }else{ 
    out.println(j); 


    %> 
    <a href="List.jsp?page=<%=nextPage%>">下一页</a><a href="List.jsp?page=<%=intPageCount%>">最后页 </a>