本文共 17827 字,大约阅读时间需要 59 分钟。
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()方法 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="/blog/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> xml方面 1、xml有哪些解析技术?区别是什么? 答:有dom,sax,stax等 dom:处理大型文件时其性能下降的非常厉害。这个问题是由dom的树结构所造成的,这种结构占用的内存较多,而且dom必须在解析文件之前把整个文档装入内存,适合对xml的随机访问sax:不现于dom,sax是事件驱动型的xml解析方式。它顺序读取xml文件,不需要一次全部装载整个文件。当遇到像文件开头,文档结束,或者标签开头与标签结束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来处理xml文件,适合对xml的顺序访问 stax:streaming api for xml (stax) 2、你在项目中用到了xml技术的哪些方面?如何实现的? 答:用到了数据存贮,信息配置两方面。在做数据交换平台时,将不能数据源的数据组装成xml文件,然后将xml文件压缩打包加密后通过网络传送给接收者,接收解密与解压缩后再同xml文件中还原相关信息进行处理。在做软件配置时,利用xml可以很方便的进行,软件的各种配置参数都存贮在xml文件中。 3、用jdom解析xml文件时如何解决中文问题?如何解析? 答:看如下代码,用编码方式加以解决 package test; import java.io.*; public class domtest { private string infile = "c://people.xml"; private string outfile = "c://people.xml"; public static void main(string args[]) { new domtest(); } public domtest() { try { javax.xml.parsers.documentbuilder builder = javax.xml.parsers.documentbuilderfactory.newinstance().newdocumentbuilder(); org.w3c.dom.document doc = builder.newdocument(); org.w3c.dom.element root = doc.createelement("老师"); org.w3c.dom.element wang = doc.createelement("王"); org.w3c.dom.element liu = doc.createelement("刘"); wang.appendchild(doc.createtextnode("我是王老师")); root.appendchild(wang); doc.appendchild(root); javax.xml.transform.transformer transformer = javax.xml.transform.transformerfactory.newinstance().newtransformer(); transformer.setoutputproperty(javax.xml.transform.outputkeys.encoding, "gb2312"); transformer.setoutputproperty(javax.xml.transform.outputkeys.indent, "yes"); transformer.transform(new javax.xml.transform.dom.domsource(doc), new javax.xml.transform.stream.streamresult(outfile)); } catch (exception e) { system.out.println (e.getmessage()); } } } 4、编程用java解析xml的方式. 答:用sax方式解析xml,xml文件如下: <?xml version="1.0" encoding="gb2312"?> <person> <name>王小明</name> <college>信息学院</college> <telephone>6258113</telephone> <notes>男,1955年生,博士,95年调入海南大学</notes> </person> 事件回调类saxhandler.java import java.io.*; import java.util.hashtable; import org.xml.sax.*; public class saxhandler extends handlerbase { private hashtable table = new hashtable(); private string currentelement = null; private string currentvalue = null; public void settable(hashtable table) { this.table = table; } public hashtable gettable() { return table; } public void startelement(string tag, attributelist attrs) throws saxexception { currentelement = tag; } public void characters(char[] ch, int start, int length) throws saxexception { currentvalue = new string(ch, start, length); } public void endelement(string name) throws saxexception { if (currentelement.equals(name)) table.put(currentelement, currentvalue); } } jsp内容显示源码,saxxml.jsp: <html> <head> <title>剖析xml文件people.xml</title> </head> <body> <%@ page errorpage="errpage.jsp" contenttype="text/html;charset=gb2312" %> <%@ page import="java.io.*" %> <%@ page import="java.util.hashtable" %> <%@ page import="org.w3c.dom.*" %> <%@ page import="org.xml.sax.*" %> <%@ page import="javax.xml.parsers.saxparserfactory" %> <%@ page import="javax.xml.parsers.saxparser" %> <%@ page import="saxhandler" %> <% file file = new file("c://people.xml"); filereader reader = new filereader(file); parser parser; saxparserfactory spf = saxparserfactory.newinstance(); saxparser sp = spf.newsaxparser(); saxhandler handler = new saxhandler(); sp.parse(new inputsource(reader), handler); hashtable hashtable = handler.gettable(); out.println("<table border=2><caption>教师信息表</caption>"); out.println("<tr><td>姓名</td>" + "<td>" + (string)hashtable.get(new string("name")) + "</td></tr>"); out.println("<tr><td>学院</td>" + "<td>" + (string)hashtable.get(new string("college"))+"</td></tr>"); out.println("<tr><td>电话</td>" + "<td>" + (string)hashtable.get(new string("telephone")) + "</td></tr>"); out.println("<tr><td>备注</td>" + "<td>" + (string)hashtable.get(new string("notes")) + "</td></tr>"); out.println("</table>"); %> </body> </html> ejb方面 1、ejb2.0有哪些内容?分别用在什么场合? ejb2.0和ejb1.1的区别? 答:规范内容包括bean提供者,应用程序装配者,ejb容器,ejb配置工具,ejb服务提供者,系统管理员。这里面,ejb容器是ejb之所以能够运行的核心。ejb容器管理着ejb的创建,撤消,激活,去活,与数据库的连接等等重要的核心工作。jsp,servlet,ejb,jndi,jdbc,jms..... 2、ejb与java bean的区别? 答:java bean 是可复用的组件,对java bean并没有严格的规范,理论上讲,任何一个java类都可以是一个bean。但通常情况下,由于java bean是被容器所创建(如tomcat)的,所以java bean应具有一个无参的构造器,另外,通常java bean还要实现serializable接口用于实现bean的持久性。java bean实际上相当于微软com模型中的本地进程内com组件,它是不能被跨进程访问的。enterprise java bean 相当于dcom,即分布式组件。它是基于java的远程方法调用(rmi)技术的,所以ejb可以被远程访问(跨进程、跨计算机)。但ejb必须被布署在诸如webspere、weblogic这样的容器中,ejb客户从不直接访问真正的ejb组件,而是通过其容器访问。ejb容器是ejb组件的代理,ejb组件由容器所创建和管理。客户通过容器来访问真正的ejb组件。 3、ejb的基本架构 答:一个ejb包括三个部分: remote interface 接口的代码 package beans; import javax.ejb.ejbobject; import java.rmi.remoteexception; public interface add extends ejbobject { //some method declare } home interface 接口的代码 package beans; import java.rmi.remoteexception; import jaax.ejb.createexception; import javax.ejb.ejbhome; public interface addhome extends ejbhome { //some method declare } ejb类的代码 package beans; import java.rmi.remoteexception; import javax.ejb.sessionbean; import javx.ejb.sessioncontext; public class addbean implements sessionbean { //some method declare }
j2ee,mvc方面 1、mvc的各个部分都有那些技术来实现?如何实现? 答:mvc是model-view-controller的简写。"model" 代表的是应用的业务逻辑(通过javabean,ejb组件实现), "view" 是应用的表示面(由jsp页面产生),"controller" 是提供应用的处理过程控制(一般是一个servlet),通过这种设计模型把应用逻辑,处理过程和显示逻辑分成不同的组件实现。这些组件可以进行交互和重用。 2、应用服务器与web server的区别? 希望大家补上,谢谢 3、j2ee是什么? 答:je22是sun公司提出的多层(multi-diered),分布式(distributed),基于组件(component-base)的企业级应用模型(enterpriese application model).在这样的一个应用系统中,可按照功能划分为不同的组件,这些组件又可在不同计算机上,并且处于相应的层次(tier)中。所属层次包括客户层(clietn tier)组件,web层和组件,business层和组件,企业信息系统(eis)层。 4、web service名词解释。jswdl开发包的介绍。jaxp、jaxm的解释。soap、uddi,wsdl解释。 答:web service描述语言wsdl soap即简单对象访问协议(simple object access protocol),它是用于交换xml编码信息的轻量级协议。 uddi 的目的是为电子商务建立标准;uddi是一套基于web的、分布式的、为web service提供的、信息注册中心的实现标准规范,同时也包含一组使企业能将自身提供的web service注册,以使别的企业能够发现的访问协议的实现标准。 5、bs与cs的联系与区别。 希望大家补上,谢谢 6、struts的应用(如struts架构) 答:struts是采用java servlet/javaserver pages技术,开发web应用程序的开放源码的framework。 采用struts能开发出基于mvc(model-view-controller)设计模式的应用构架。 struts有如下的主要功能: 一.包含一个controller servlet,能将用户的请求发送到相应的action对象。 二.jsp自由tag库,并且在controller servlet中提供关联支持,帮助开发员创建交互式表单应用。 三.提供了一系列实用对象:xml处理、通过java reflection apis自动处理javabeans属性、国际化的提示和消息。 设计模式方面 1、开发中都用到了那些设计模式?用在什么场合? 答:每个模式都描述了一个在我们的环境中不断出现的问题,然后描述了该问题的解决方案的核心。通过这种方式,你可以无数次地使用那些已有的解决方案,无需在重复相同的工作。主要用到了mvc的设计模式。用来开发jsp/servlet或者j2ee的相关应用。简单工厂模式等。 2、uml方面 答:标准建模语言uml。用例图,静态图(包括类图、对象图和包图),行为图,交互图(顺序图,合作图),实现图, javascript方面 1、如何校验数字型? var re=/^/d{1,8}$|/./d{1,2}$/; var str=document.form1.all(i).value; var r=str.match(re); if (r==null) { sign=-4; break; } else{ document.form1.all(i).value=parsefloat(str); } corba方面 1、corba是什么?用途是什么? 答:corba 标准是公共对象请求代理结构(common object request broker architecture),由对象管理组织 (object management group,缩写为 omg)标准化。它的组成是接口定义语言(idl), 语言绑定(binding:也译为联编)和允许应用程序间互操作的协议。 其目的为: 用不同的程序设计语言书写 在不同的进程中运行 为不同的操作系统开发 linux方面 1、linux下线程,gdi类的解释。 答:linux实现的就是基于核心轻量级进程的"一对一"线程模型,一个线程实体对应一个核心轻量级进程,而线程之间的管理在核外函数库中实现。 gdi类为图像设备编程接口类库
转载地址:http://ddedi.baihongyu.com/