J2EE面试题集锦(附答案)

J2EE面试题集锦(附答案)java

1、基础问答git

  1.下面哪些类能够被继承?web

   java.lang.Thread (T)面试

   java.lang.Number (T)sql

   java.lang.Double (F)数据库

   java.lang.Math  (F)编程

   java.lang.Void  (F)windows

         java.lang.Class  (F)安全

   java.lang.ClassLoader (T)服务器

  2.抽象类和接口的区别

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

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

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

  3.Hashtable的原理,并说出HashMapHashtable的区别

  HashTable的原理:经过节点的关键码肯定节点的存储位置,即给定节点的关键码k,经过必定的函数关系H(散列函数),获得函数值H(k),将此值解释为该节点的存储地址.

HashMap Hashtable很类似,HashMap 是非同步(unsynchronizded)和能够以null为关键码的.

  4.forwardredirect的区别

  forward: an internal transfer in servlet

  redirect: 重定向,2request,2request将丢失第一次的attributs/parameters

  5.什么是Web容器?

  实现J2EE规范中web协议的应用.该协议定义了web程序的运行时环境,包括:并发性,安全性,生命周期管理等等.

  6.解释下面关于J2EE的名词

  (1)JNDI:Java Naming & Directory Interface,JAVA命名目录服务.主要提供的功能是:提供一个目录系统,让其它各地的应用程序在其上面留下本身的索引,从而知足快速查找和定位分布式应用程序的功能.

  (2)JMSJava Message Service,JAVA消息服务.主要实现各个应用程序之间的通信.包括点对点和广播.

  (3)JTAJava Transaction API,JAVA事务服务.提供各类分布式事务服务.应用程序只需调用其提供的接口便可.

  (4)JAF: Java Action FrameWork,JAVA安全认证框架.提供一些安全控制方面的框架.让开发者经过各类部署和自定义实现本身的个性安全控制策略.

  (5)RMI:Remote Method Interface,远程方法调用

  7.EJB是基于哪些技术实现的?并说 出SessionBeanEntityBean的区别,StatefulBeanStatelessBean的区别.

  EJB包括Session BeanEntity BeanMessage Driven Bean,基于JNDIRMIJAT等技术实现.

  SessionBeanJ2EE应用程序中被用来完成一些服务器端的业务操做,例如访问数据库、调用其余EJB组件.EntityBean被用来表明应用系统中用到的数据.对于客户机,SessionBean是一种非持久性对象,它实现某些在服务器上运行的业务逻辑;EntityBean是一种持久性对象,它表明一个存储在持久性存储器中的实体的对象视图,或是一个由现有企业应用程序实现的实体.

  Session Bean 还能够再细分为 Stateful Session Bean 与 Stateless Session Bean .这两种的 Session Bean均可以将系统逻辑放在 method之中执行,不一样的是 Stateful Session Bean 能够记录呼叫者的状态,所以一般来讲,一个使用者会有一个相对应的 Stateful Session Bean 的实体.Stateless Session Bean 虽然也是逻辑组件,可是他却不负责记录使用者状态,也就是说当使用者呼叫 Stateless Session Bean 的时候,EJB Container 并不会找寻特定的 Stateless Session Bean 的实体来执行这个 method.换言之,极可能数个使用者在执行某个 Stateless Session Bean 的 methods 时,会是同一个 Bean 的 Instance 在执行.从内存方面来看, Stateful Session Bean 与 Stateless Session Bean 比较, Stateful Session Bean 会消耗 J2EE Server 较多的内存,然而 Stateful Session Bean 的优点却在于他能够维持使用者的状态.

  8.XML的解析方法

  Sax,DOM,JDOM

  9.什么是Web Service?

  Web Service就是为了使原来各孤立的站点之间的信息可以相互通讯、共享而提出的一种接口。

Web Service所使用的是Internet上统1、开放的标准,如HTTPXMLSOAP(简单对象访问协议)、WSDL等,因此Web Service能够在任何支持这些标准的环境(Windows,Linux)中使用。

  注:SOAP协议(Simple Object Access Protocal,简单对象访问协议),它是一个用于分散和分布式环境下网络信息交换的基于XML的通信协议。在此协议下,软件组件或应用程序可以经过标准的HTTP协议进行通信。它的设计目标就是简单性和扩展性,这有助于大量异构程序和平台之间的互操做性,从而使存在的应用程序可以被普遍的用户访问。

  优点:

  (1).跨平台。

  (2).SOAP协议是基于XMLHTTP这些业界的标准的,获得了全部的重要公司的支持。

  (3).因为使用了SOAP,数据是以ASCII文本的方式而非二进制传输,调试很方便;而且因为这样,它的数据容易经过防火墙,不须要防火墙为了程序而单独开一个“漏洞”。

  (4).此外,WebService实现的技术难度要比CORBADCOM小得多。

  (5).要实现B2B集成,EDI比较完善与比较复杂;而用WebService则能够低成本的实现,小公司也能够用上。

  (6).C/S的程序中,WebService能够实现网页无总体刷新的与服务器打交道并取数。

  缺点:

  (1).WebService使用了XML对数据封装,会形成大量的数据要在网络中传输。

  (2).WebService规范没有规定任何与实现相关的细节,包括对象模型、编程语言,这一点,它不如CORBA

  10.多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?

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

  同步的实现方面有两种,分别是synchronized,waitnotify

  11.JSP中动态INCLUDE与静态INCLUDE的区别? 

  动态INCLUDEjsp:include动做实现

  它老是会检查所含文件中的变化,适合用于包含动态页面,而且能够带参数

  静态INCLUDEinclude伪码实现,定不会检查所含文件的变化,适用于包含静态页面

  <%@ include file="included.htm" %>

2、Java编程与程序运行结果

  1.Java编程,打印昨天的当前时刻

public class YesterdayCurrent{

  public void main(String[] args){

    Calendar cal = Calendar.getInstance();

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

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

  }

}

  2.文件读写,实现一个计数器

  public int getNum(){

        int i = -1;

        try{

            String stri="";

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

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

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

            }

            in.close();

        }catch(Exception e){

            e.printStackTrace();

        }

        return i;

    }

    public void setNum(){

        int i = getNum();

        i++;        

        try{

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

            out.write(String.valueOf(i));            //多是编码的缘由,若是直接写入int的话,将出现java编码和windows编码的混乱,所以此处写入的是String

            out.close() ;

        }catch(Exception e){

            e.printStackTrace();

        }

    }

  3. 指出下面程序的运行结果:

class A{

    static{

        System.out.print("1");

    }

    public A(){

        System.out.print("2");

    }

}

class B extends A{

    static{

        System.out.print("a");

    }

    public B(){

        System.out.print("b");

    }   

}

public class Hello{

    public static void main(String[] ars){

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

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

    }

}

  注:类的static 代码段,能够看做是类首次加载(被虚拟机加载)执行的代码,而对于类的加载,首先要执行其基类的构造,再执行其自己的构造

  4.写一个Singleton模式的例子

public class Singleton{

private static Singleton single = new Singleton();

private Singleton(){}

public Singleton getInstance(){

  return single;

}

}

3、数据库

  1.删除表的重复记录

  若是记录彻底相同才算重复记录,那么:  (sql server2000下测试经过)

select distinct * into #tmpp from tid

delete from tid     

insert into tid select * from #tmpp

drop table #tmpp

  若是有id主键(数字,自增1的那种),那么:(sql server2000下测试经过)

delete from tableA where id not in

(select id = min(id) from tableA group by name)

  2.delete from tablea & truncate table tablea的区别

  truncate 语句执行速度快,占资源少,而且只记录页删除的日志;

  delete 对每条记录的删除均须要记录日志

JAVA编程题

1.如今输入n个数字,以逗号,分开;而后可选择升或者降序排序;按提交键就在另外一页面显示按什么排序,结果为,提供reset

[hidden]import java.util.*;

public class bycomma{

public static String[] splitStringByComma(String source){

   if(source==null||source.trim().equals(""))

    return null;

   StringTokenizer commaToker = new StringTokenizer(source,",");

   String[] result = new String[commaToker.countTokens()];

   int i=0;

   while(commaToker.hasMoreTokens()){

    result[i] = commaToker.nextToken();

    i++;

   }

   return result;

}

public static void main(String args[]){

String[] s = splitStringByComma("5,8,7,4,3,9,1");

int[] ii = new int[s.length];

for(int i = 0;i ii[i] =Integer.parseInt(s[i]);

}

    Arrays.sort(ii);

    //asc

    for(int i=0;i    System.out.println(ii[i]);

    }

    //desc

    for(int i=(s.length-1);i>=0;i--){

    System.out.println(ii[i]);

    }

}

}[/hidden]

2.金额转换,阿拉伯数字的金额转换成中国传统的形式如:(¥1011)->(一千零一拾一元整)输出。

[hidden]package test.format;

import java.text.NumberFormat;

import java.util.HashMap;

public class SimpleMoneyFormat {

  public static final String EMPTY = "";

  public static final String ZERO = "";

  public static final String ONE = "";

  public static final String TWO = "";

  public static final String THREE = "";

  public static final String FOUR = "";

  public static final String FIVE = "";

  public static final String SIX = "";

  public static final String SEVEN = "";

  public static final String EIGHT = "";

  public static final String NINE = "";

  public static final String TEN = "";

  public static final String HUNDRED = "";

  public static final String THOUSAND = "";

  public static final String TEN_THOUSAND = "";

  public static final String HUNDRED_MILLION = "亿";

  public static final String YUAN = "";

  public static final String JIAO = "";

  public static final String FEN = "";

  public static final String DOT = ".";

  private static SimpleMoneyFormat formatter = null;

  private HashMap chineseNumberMap = new HashMap();

  private HashMap chineseMoneyPattern = new HashMap();

  private NumberFormat numberFormat = NumberFormat.getInstance();

  private SimpleMoneyFormat() {

    numberFormat.setMaximumFractionDigits(4);

    numberFormat.setMinimumFractionDigits(2);

    numberFormat.setGroupingUsed(false);

    chineseNumberMap.put("0", ZERO);

    chineseNumberMap.put("1", ONE);

    chineseNumberMap.put("2", TWO);

    chineseNumberMap.put("3", THREE);

    chineseNumberMap.put("4", FOUR);

    chineseNumberMap.put("5", FIVE);

    chineseNumberMap.put("6", SIX);

    chineseNumberMap.put("7", SEVEN);

    chineseNumberMap.put("8", EIGHT);

    chineseNumberMap.put("9", NINE);

    chineseNumberMap.put(DOT, DOT);

    chineseMoneyPattern.put("1", TEN);

    chineseMoneyPattern.put("2", HUNDRED);

    chineseMoneyPattern.put("3", THOUSAND);

    chineseMoneyPattern.put("4", TEN_THOUSAND);

    chineseMoneyPattern.put("5", TEN);

    chineseMoneyPattern.put("6", HUNDRED);

    chineseMoneyPattern.put("7", THOUSAND);

    chineseMoneyPattern.put("8", HUNDRED_MILLION);

  }

  public static SimpleMoneyFormat getInstance() {

    if (formatter == null)

      formatter = new SimpleMoneyFormat();

    return formatter;

  }

  public String format(String moneyStr) {

    checkPrecision(moneyStr);

    String result;

    result = convertToChineseNumber(moneyStr);

    result = addUnitsToChineseMoneyString(result);

    return result;

  }

  public String format(double moneyDouble) {

    return format(numberFormat.format(moneyDouble));

  }

  public String format(int moneyInt) {

    return format(numberFormat.format(moneyInt));

  }

  public String format(long moneyLong) {

    return format(numberFormat.format(moneyLong));

  }

  public String format(Number moneyNum) {

    return format(numberFormat.format(moneyNum));

  }

  private String convertToChineseNumber(String moneyStr) {

    String result;

    StringBuffer cMoneyStringBuffer = new StringBuffer();

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

      cMoneyStringBuffer.append(chineseNumberMap.get(moneyStr.substring(i, i + 1)));

    }

    //拾佰仟万亿等都是汉字里面才有的单位,加上它们

    int indexOfDot = cMoneyStringBuffer.indexOf(DOT);

    int moneyPatternCursor = 1;

    for (int i = indexOfDot - 1; i > 0; i--) {

      cMoneyStringBuffer.insert(i, chineseMoneyPattern.get(EMPTY + moneyPatternCursor));

      moneyPatternCursor = moneyPatternCursor == 8 ? 1 : moneyPatternCursor + 1;

    }

    String fractionPart = cMoneyStringBuffer.substring(cMoneyStringBuffer.indexOf("."));

    cMoneyStringBuffer.delete(cMoneyStringBuffer.indexOf("."), cMoneyStringBuffer.length());

    while (cMoneyStringBuffer.indexOf("零拾") != -1) {

      cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零拾"), cMoneyStringBuffer.indexOf("零拾") + 2, ZERO);

    }

    while (cMoneyStringBuffer.indexOf("零佰") != -1) {

      cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零佰"), cMoneyStringBuffer.indexOf("零佰") + 2, ZERO);

    }

    while (cMoneyStringBuffer.indexOf("零仟") != -1) {

      cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零仟"), cMoneyStringBuffer.indexOf("零仟") + 2, ZERO);

    }

    while (cMoneyStringBuffer.indexOf("零万") != -1) {

      cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零万"), cMoneyStringBuffer.indexOf("零万") + 2, TEN_THOUSAND);

    }

    while (cMoneyStringBuffer.indexOf("零亿") != -1) {

      cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零亿"), cMoneyStringBuffer.indexOf("零亿") + 2, HUNDRED_MILLION);

    }

    while (cMoneyStringBuffer.indexOf("零零") != -1) {

      cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零零"), cMoneyStringBuffer.indexOf("零零") + 2, ZERO);

    }

    if (cMoneyStringBuffer.lastIndexOf(ZERO) == cMoneyStringBuffer.length() - 1)

      cMoneyStringBuffer.delete(cMoneyStringBuffer.length() - 1, cMoneyStringBuffer.length());

    cMoneyStringBuffer.append(fractionPart);

    result = cMoneyStringBuffer.toString();

    return result;

  }

  private String addUnitsToChineseMoneyString(String moneyStr) {

    String result;

    StringBuffer cMoneyStringBuffer = new StringBuffer(moneyStr);

    int indexOfDot = cMoneyStringBuffer.indexOf(DOT);

    cMoneyStringBuffer.replace(indexOfDot, indexOfDot + 1, YUAN);[/hidden]

相关文章
相关标签/搜索