有感:应聘Java笔试时可能出现问题及其答案

转自:http://www.javaresearch.org/article/72176.htm

有感:应聘Java笔试时可能出现问题及其答案

前段时间因为要参加一个笔试,在准备期间在网上找到了两条关于笔试题目的文章,其中一篇为<<有感:应聘Java笔试时可能出现问题>>,还有一篇忘了名字,读后深受启发。
在寻找这些答案的过程中,我将相关答案记录下来,就形成了以下这些东西。需要说明的是以下答案肯定有很多不完整甚至错误的地方,需要各位来更正与完善它,千万不要扔我的鸡蛋啊。
希望本文能够给即将奔赴笔试考场的同仁些许帮助,更希望更多的人加入到收集整理笔试题与完善答案的这些工作中来,为大家更好的获得工作机会做一点贡献。
在此感谢前面两文的作者的对笔试题目的收集与整理。
如有任何意见与建议请通过QQ:6045306,Mail:huijunzi@21cn.com与我联系。

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是Java1.2引进的Map接口的一个实现
二.同步性:Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步的
三.值:只有HashMap可以让你将空值作为一个表的条目的key或value
3、char型变量中能不能存贮一个中文汉字?为什么?
答:是能够定义成为一个中文的,因为java中以unicode编码,一个char占16个字节,所以放一个中文是没问题的
4、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?
答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
同步的实现方面有两种,分别是synchronized,wait与notify
5、继承时候类的执行顺序问题,一般都是选择题,问你将会打印出什么?
答:父类:
packagetest;
publicclassFatherClass
{
publicFatherClass()
{
System.out.println("FatherClassCreate");
}
}
子类:
packagetest;
importtest.FatherClass;
publicclassChildClassextendsFatherClass
{
publicChildClass()
{
System.out.println("ChildClassCreate");
}
publicstaticvoidmain(String[]args)
{
FatherClassfc=newFatherClass();
ChildClasscc=newChildClass();
}
}
输出结果:
C:\>javatest.ChildClass
FatherClassCreate
FatherClassCreate
ChildClassCreate

6、内部类的实现方式?
答:示例代码如下:
packagetest;
publicclassOuterClass
{
privateclassInterClass
{
publicInterClass()
{
System.out.println("InterClassCreate");
}
}
publicOuterClass()
{
InterClassic=newInterClass();
System.out.println("OuterClassCreate");
}
publicstaticvoidmain(String[]args)
{
OuterClassoc=newOuterClass();
}
}
输出结果:
C:\>javatest/OuterClass
InterClassCreate
OuterClassCreate


再一个例题:
publicclassOuterClass{
privatedoubled1=1.0;
//insertcodehere
}
Youneedtoinsertaninnerclassdeclarationatline3.Whichtwoinnerclassdeclarationsare
valid?(Choosetwo.)

A.classInnerOne{//.静态内部类可以有静态成员,而非静态内部类则不能有静态成员
publicstaticdoublemethoda(){returnd1;}
}
B.publicclassInnerOne{//.静态内部类可以有静态成员,而非静态内部类则不能有静态成员
staticdoublemethoda(){returnd1;}
}
C.privateclassInnerOne{
doublemethoda(){returnd1;}
}
D.staticclassInnerOne{
protecteddoublemethoda(){returnd1;}//静态内部类的非静态成员不可访问外部类的非静态变量
}
E.abstractclassInnerOne{
publicabstractdoublemethoda();
}
说明如下:
一.静态内部类可以有静态成员,而非静态内部类则不能有静态成员。故A、B错
二.静态内部类的非静态成员可以访问外部类的静态变量,而不可访问外部类的非静态变量;returnd1出错,故D错
三.非静态内部类的非静态成员可以访问外部类的非静态变量。故C正确
四.答案为C、E

7、垃圾回收机制,如何优化程序?
答:结束方法finalize()可以用来帮助优化对象,该方法在释放对象时被子引用,它是java中为了有效地进行垃圾收集而引入的一个特 殊方法,finalize()方法属于java.lang.Object的系统类方法,它能被所有类访问,当一个对象实例已经完全没有被任何变 量引用时,则可以对它进行垃圾收集标记,在进行”垃圾收集”之前,系统将自动调用对象的finalize()方法,释放对象实例所占用的系统资源.

8、float型floatf=3.4是否正确?
答:不正确。精度不准确,应该用强制类型转换,如下所示:floatf=(float)3.4

9、介绍JAVA中的CollectionFrameWork(包括如何写自己的数据结构)?
答:CollectionFrameWork如下:
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的通信编程,编程题(或问答),用JAVASOCKET编程,读服务器几个字符,再写入本地显示?
答:Server端程序:
packagetest;
importjava.net.*;
importjava.io.*;

publicclassServer
{
privateServerSocketss;
privateSocketsocket;
privateBufferedReaderin;
privatePrintWriterout;
publicServer()
{
try
{
ss=newServerSocket(10000);
while(true)
{
socket=ss.accept();
StringRemoteIP=socket.getInetAddress().getHostAddress();
StringRemotePort=":"+socket.getLocalPort();
System.out.println("Aclientcomein!IP:"+RemoteIP+RemotePort);
in=newBufferedReader(newInputStreamReader(socket.getInputStream()));
Stringline=in.readLine();
System.out.println("Cleintsendis:"+line);
out=newPrintWriter(socket.getOutputStream(),true);
out.println("YourMessageReceived!");
out.close();
in.close();
socket.close();
}
}catch(IOExceptione)
{
out.println("wrong");
}
}
publicstaticvoidmain(String[]args)
{
newServer();
}
};
Client端程序:
packagetest;
importjava.io.*;
importjava.net.*;

publicclassClient
{
Socketsocket;
BufferedReaderin;
PrintWriterout;
publicClient()
{
try
{
System.out.println("TrytoConnectto127.0.0.1:10000");
socket=newSocket("127.0.0.1",10000);
System.out.println("TheServerConnected!");
System.out.println("PleaseentersomeCharacter:");
BufferedReaderline=newBufferedReader(newInputStreamReader(System.in));
out=newPrintWriter(socket.getOutputStream(),true);
out.println(line.readLine());
in=newBufferedReader(newInputStreamReader(socket.getInputStream()));
System.out.println(in.readLine());
out.close();
in.close();
socket.close();
}catch(IOExceptione)
{
out.println("Wrong");
}
}
publicstaticvoidmain(String[]args)
{
newClient();
}
};

14、用JAVA实现一种排序,JAVA类实现序列化的方法(二种)?如在COLLECTION框架中,实现比较要实现什么样的接口?
答:用插入法进行排序代码如下
packagetest;
importjava.util.*;
classInsertSort
{
ArrayListal;//定义一个链表

publicInsertSort(intnum,intmod)//带参数的构造函数
{
al=newArrayList(num);//实例化链表
Randomrand=newRandom();//取一个随机数
System.out.println("TheArrayListSortBefore:");
for(inti=0;i<num;i++)
{
al.add(newInteger(Math.abs(rand.nextInt())%mod+1));
System.out.println("al["+i+"]="+al.get(i));
}
}
publicvoidSortIt()
{
IntegertempInt;
intMaxSize=1;
for(inti=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(intj=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("TheArrayListSortAfter:");
for(inti=0;i<al.size();i++)
{
System.out.println("al["+i+"]="+al.get(i));
}
}
publicstaticvoidmain(String[]args)
{
InsertSortis=newInsertSort(10,100);//定义一个类的对象
is.SortIt();//调用类中的方法,执行排序
}
}
JAVA类实现序例化的方法是实现java.io.Serializable接口
Collection框架中实现比较要实现Comparable接口和Comparator接口

15、编程:编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。但是要保证汉字不被截半个,如“我ABC”4,应该截为“我AB”,输入“我ABC汉DEF”,6,应该输出为“我ABC”而不是“我ABC+汉的半个”。
答:代码如下:
packagetest;

classSplitString
{
StringSplitStr;
intSplitByte;

publicSplitString(Stringstr,intbytes)//带参数的构造函数,给类变量赋初值
{
SplitStr=str;
SplitByte=bytes;
System.out.println("TheStringis:´"+SplitStr+"´;SplitBytes="+SplitByte);
}

publicvoidSplitIt()
{
intloopCount;
loopCount=(SplitStr.length()%SplitByte==0)?(SplitStr.length()/SplitByte):(SplitStr.length()/Split
Byte+1);
System.out.println("WillSplitinto"+loopCount);

for(inti=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)));
}
}
}

publicstaticvoidmain(String[]args)
{
SplitStringss=newSplitString("test中dd文dsaf中男大3443n中国43中国人0ewldfls=103",4);
ss.SplitIt();
}
}


16、JAVA多线程编程。用JAVA写一个多线程程序,如写四个线程,二个加1,二个对一个变量减一,输出。
希望大家补上,谢谢

17、STRING与STRINGBUFFER的区别。
答:STRING的长度是不可变的,STRINGBUFFER的长度是可变的。如果你对字符串中的内容经常进行操作,特别是内容要修改时,那么使用StringBuffer,如果最后需要String,那么使用StringBuffer的toString()方法

18.==与equals的区别:
答:"=="比较的是两个对象的引用(references),并不是他们的内容.
equals (Object)方法与"=="相比的特殊之处就在于它可以覆盖,所以我们可以通过覆盖的办法让它不是比较引用而是比较数据内容。当然JDK中 也有覆盖过equals(Object)方法的类,如java.lang.String,它就覆盖了从Object继承来的的equals (Object)方法,用以比较字符串内容是否相同。

19.JAVA的基本数据类型有哪些?String是不是基本数据类型?
Java有8种基本数据类型:
byteintshortlongdoublefloatBooleanchar

其中,byteintshortlong都属于整数类型.
Doublefloat属于浮点类型.
Boolean为布尔类型
Char为字符型
String不是基本数据类型.它定义的为对象

20.面向对象语言的特征:
a.抽象性
b.封装
c.继承
d.多态

20.链表和数组的区别:
创建数组必须明确说明数组的长度,(即数组中元素的个数),以便在内存中留出一块空间存放所有的数组元素,数组中各数据元素在内存中是顺序存放的.
创建链表时,不需要给出链表中元素(称为节点)的个数,可以先只创建一个链表头,其他
元素在需要时动态地创建并加入到链表,链表的数据无素在内存中不是连续存放的.


Jsp方面

1、jsp有哪些内置对象?作用分别是什么?
答:JSP共有以下9种基本内置组件(可与ASP的6种内部组件相对应):
request用户端请求,此请求会包含来自GET/POST请求的参数
response网页传回用户端的回应
pageContext网页的属性是在这里管理
session与请求有关的会话期
applicationservlet正在执行的内容
configservlet的构架部件
out用来传送回应的输出(用来向客户端输出数据)
pageJSP网页本身
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:includepage="included.jsp"flush="true"/>它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数
静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面
<%@includefile="included.htm"%>

4、两种跳转方式分别是什么?有什么区别?
答:有两种,分别为:
<jsp:includepage="included.jsp"flush="true">
<jsp:forwardpage="nextpage.jsp"/>
前者页面不会转向include所指的页面,只是显示该页的结果,主页面还是原来的页面。执行完后还会回来,相当于函数调用。并且可以带参数.
后者完全转向新页面,不会再回来。相当于goto语句。
Servlet方面
1、说一说Servlet的生命周期?
答: Servlet的生命周期始于将它装入Web服务器的内存时,并在终止或重新装入Servlet时结束。包括加载和实例化、初始化、处理 请求以及服务结束。这个生存期由javax.servlet.Servlet接口的init,service和destroy方法表达。

2、Servlet版本间(忘了问的是哪两个版本了)的不同?
希望大家补上,谢谢

3、JAVAServletAPI中forward()与redirect()的区别?
答:前者仅是容器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址;
后者则是完全的跳转,浏览器将会得到跳转的地址,并重新发送请求链接。这样,从浏览器的地址栏中可以看到跳转后的链接地址。
所以,前者更加高效,在前者可以满足需要时,尽量使用forward()方法,并且,这样也有助于隐藏实际的链接。但在有些情况下,比如,需要跳转到一个其它服务器上的资源,则必须使用sendRedirect()方法。

4、Servlet的基本架构
importjava.io.*;
importjavax.servlet.*;
importjavax.servlet.http.*;
publicclassServletNameextendsHttpServlet{
publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throws
ServletException,IOException{
}
publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throws
ServletException,IOException{
doPost(request,response);
}
}

Jdbc、Jdo方面

1、可能会让你写一段Jdbc连Oracle的程序,并实现数据查询.
答:程序如下:
packagehello.ant;
importjava.sql.*;
publicclassjdbc
{
StringdbUrl="jdbc:oracle:thin:@127.0.0.1:1521:orcl";
StringtheUser="admin";
StringthePw="manager";
Connectionconn=null;
Statementstmt;
ResultSetrs=null;
publicjdbc()
{
try{
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
conn=DriverManager.getConnection(dbUrl,theUser,thePw);
stmt=conn.createStatement();
}catch(Exceptione){
e.printStackTrace();
}
}
publicbooleanexecuteUpdate(Stringsql)
{
try
{
stmt.executeUpdate(sql);
returntrue;
}
catch(SQLExceptione)
{
e.printStackTrace();
returnfalse;
}
}
publicResultSetexecuteQuery(Stringsql)
{
rs=null;
try
{
rs=stmt.executeQuery(sql);
}
catch(SQLExceptione)
{
e.printStackTrace();
}
returnrs;
}
publicvoidclose()
{
try
{
stmt.close();
conn.close();
}
catch(Exceptione)
{
e.printStackTrace();
}
}
publicstaticvoidmain(String[]args)
{
ResultSetrs;
jdbcstmt=newjdbc();//定义上面jdbc类的对象,并调用其中的查询方法.
rs=stmt.executeQuery("select*fromtest");
try{
while(rs.next())
{
System.out.println(rs.getString("id"));
System.out.println(rs.getString("name"));
}
}catch(Exceptione)
{
e.printStackTrace();
}
}
}

2、Class.forName的作用?为什么要用?
答:调用该访问返回一个以字符串指定类名的类的对象。

3、Jdo是什么?
答: JDO是Java对象持久化的新的规范,为JavaData0bject的简称,也是一个用于存取某种数据仓库中的对象的标准化API。JDO 提供了透明的对象存储,因此对开发人员来说,存储数据对象完全不需要额外的代码(如JDBCAPI的使用)。这些繁琐的例行工作已经转移到JDO产品提 供商身上,使开发人员解脱出来,从而集中时间和精力在业务逻辑上。另外,JDO很灵活,因为它可以在任何数据底层上运行。JDBC只是面向关系数据库 (RDBMS),JDO更通用,提供到任何数据底层的存储功能,比如关系数据库、文件、XML以及对象数据库(ODBMS)等等,使得应用可移植性 更强。

4、在ORACLE大数据量下的分页解决方法。一般用截取ID方法,还有是三层嵌套方法。
答:一种分页方法
<%
inti=1;
intnumPages=14;
Stringpages=request.getParameter("page");
intcurrentPage=1;
currentPage=(pages==null)?(1):{Integer.parseInt(pages)}
sql="selectcount(*)fromtables";
ResultSetrs=DBLink.executeQuery(sql);
while(rs.next())i=rs.getInt(1);
intintPageCount=1;
intPageCount=(i%numPages==0)?(i/numPages):(i/numPages+1);
intnextPage;
intupPage;
nextPage=currentPage+1;
if(nextPage>=intPageCount)nextPage=intPageCount;
upPage=currentPage-1;
if(upPage<=1)upPage=1;
rs.close();
sql="select*fromtables";
rs=DBLink.executeQuery(sql);
i=0;
while((i<numPages*(currentPage-1))&&rs.next()){i++;}
%>
//输出内容
//输出翻页连接
合计:<%=currentPage%>/<%=intPageCount%><ahref="List.jsp?page=1">第一页</a><a
href="List.jsp?page=<%=upPage%>">上一页</a>
<%
for(intj=1;j<=intPageCount;j++){
if(currentPage!=j){
%>
<ahref="list.jsp?page=<%=j%>">[<%=j%>]</a>
<%
}else{
out.println(j);
}
}
%>
<ahref="List.jsp?page=<%=nextPage%>">下一页</a><ahref="List.jsp?page=<%=intPageCount%>">最后页
</a>

Xml方面

1、xml有哪些解析技术?区别是什么?
答:有DOM,SAX,STAX等
DOM:处理大型文件时其性能下降的非常厉害。这个问题是由DOM的树结构所造成的,这种结构占用的内存较多,而且DOM必须在解析文件之前把整个文档装入内存,适合对XML的随机访问
SAX: 不同于DOM(文档驱动型),SAX是事件驱动型的XML解析方式。它顺序读取XML文件,不需要一次全部装载整个文件。当遇到像文件开头,文档结束, 或者标签开头与标签结束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来处理XML文件,适合对XML的顺序访问
STAX:StreamingAPIforXML(StAX)

2、你在项目中用到了xml技术的哪些方面?如何实现的?
答:用到了数据存贮,信息配置两方面。
在做数据交换平台时,将数据源的数据组装成XML文件,然后将XML文件压缩打包加密后通过网络传送给接收者,接收解密与解压缩后再对XML文件中还原的相关信息进行处理。
在做软件配置时,利用XML可以很方便的进行,软件的各种配置参数都存贮在XML文件中。


3、用jdom解析xml文件时如何解决中文问题?如何解析?
答:看如下代码,用编码方式加以解决
packagetest;
importjava.io.*;
publicclassDOMTest
{
privateStringinFile="c:\\people.xml";
privateStringoutFile="c:\\people.xml";

publicstaticvoidmain(Stringargs[])
{
newDOMTest();
}

publicDOMTest()
{
try
{
javax.xml.parsers.DocumentBuilderbuilder=
javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder();
org.w3c.dom.Documentdoc=builder.newDocument();

org.w3c.dom.Elementroot=doc.createElement("老师");
org.w3c.dom.Elementwang=doc.createElement("王");
org.w3c.dom.Elementliu=doc.createElement("刘");

wang.appendChild(doc.createTextNode("我是王老师"));
root.appendChild(wang);
doc.appendChild(root);

javax.xml.transform.Transformertransformer=
javax.xml.transform.TransformerFactory.newInstance().newTransformer();
transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING,"gb2312");
transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT,"yes");

transformer.transform(newjavax.xml.transform.dom.DOMSource(doc),
newjavax.xml.transform.stream.StreamResult(outFile));
}
catch(Exceptione)
{
System.out.println(e.getMessage());
}
}
}

4、编程用JAVA解析XML的方式.
答:用SAX方式解析XML,XML文件如下:
<?xmlversion="1.0"encoding="gb2312"?>
<person>
<name>王小明</name>
<college>信息学院</college>
<telephone>6258113</telephone>
<notes>男,1955年生,博士,95年调入海南大学</notes>
</person>
事件回调类SAXHandler.java
importjava.io.*;
importjava.util.Hashtable;
importorg.xml.sax.*;
publicclassSAXHandlerextendsHandlerBase
{
privateHashtabletable=newHashtable();
privateStringcurrentElement=null;
privateStringcurrentValue=null;
publicvoidsetTable(Hashtabletable)
{
this.table=table;
}
publicHashtablegetTable()
{
returntable;
}
publicvoidstartElement(Stringtag,AttributeListattrs)
throwsSAXException
{
currentElement=tag;
}
publicvoidcharacters(char[]ch,intstart,intlength)
throwsSAXException
{
currentValue=newString(ch,start,length);
}
publicvoidendElement(Stringname)throwsSAXException
{
if(currentElement.equals(name))
table.put(currentElement,currentValue);
}
}
JSP内容显示源码,SaxXml.jsp:
<HTML>
<HEAD>
<TITLE>剖析XML文件people.xml</TITLE>
</HEAD>
<BODY>
<%@pageerrorPage="ErrPage.jsp"
contentType="text/html;charset=GB2312"%>
<%@pageimport="java.io.*"%>
<%@pageimport="java.util.Hashtable"%>
<%@pageimport="org.w3c.dom.*"%>
<%@pageimport="org.xml.sax.*"%>
<%@pageimport="javax.xml.parsers.SAXParserFactory"%>
<%@pageimport="javax.xml.parsers.SAXParser"%>
<%@pageimport="SAXHandler"%>
<%
Filefile=newFile("c:\\people.xml");
FileReaderreader=newFileReader(file);
Parserparser;
SAXParserFactoryspf=SAXParserFactory.newInstance();
SAXParsersp=spf.newSAXParser();
SAXHandlerhandler=newSAXHandler();
sp.parse(newInputSource(reader),handler);
HashtablehashTable=handler.getTable();
out.println("<TABLEBORDER=2><CAPTION>教师信息表</CAPTION>");
out.println("<TR><TD>姓名</TD>"+"<TD>"+
(String)hashTable.get(newString("name"))+"</TD></TR>");
out.println("<TR><TD>学院</TD>"+"<TD>"+
(String)hashTable.get(newString("college"))+"</TD></TR>");
out.println("<TR><TD>电话</TD>"+"<TD>"+
(String)hashTable.get(newString("telephone"))+"</TD></TR>");
out.println("<TR><TD>备注</TD>"+"<TD>"+
(String)hashTable.get(newString("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与JAVABEAN的区别?
答:JavaBean 是可复用的组件,对JavaBean并没有严格的规范,理论上讲,任何一个Java类都可以是一个Bean。但通常情况下,由于JavaBean是被 容器所创建(如Tomcat)的,所以JavaBean应具有一个无参的构造器,另外,通常JavaBean还要实现Serializable接口用 于实现Bean的持久性。JavaBean实际上相当于微软COM模型中的本地进程内COM组件,它是不能被跨进程访问的。
EnterpriseJavaBean相当于DCOM,即分布式组件。它是基于Java的远程方法调用(RMI)技
术 的,所以EJB可以被远程访问(跨进程、跨计算机)。但EJB必须被布署在诸如Webspere、WebLogic这样的容器中,EJB客户从不直接 访问真正的EJB组件,而是通过其容器访问。EJB容器是EJB组件的代理,EJB组件由容器所创建和管理。客户通过容器来访问真正的EJB组件。

3、EJB的基本架构
答:一个EJB包括三个部分:

RemoteInterface接口的代码
packageBeans;
importjavax.ejb.EJBObject;
importjava.rmi.RemoteException;
publicinterfaceAddextendsEJBObject
{
//somemethoddeclare
}

HomeInterface接口的代码
packageBeans;
importjava.rmi.RemoteException;
importjavax.ejb.CreateException;
importjavax.ejb.EJBHome;
publicinterfaceAddHomeextendsEJBHome
{
//somemethoddeclare
}

EJB类的代码
packageBeans;
importjava.rmi.RemoteException;
importjavax.ejb.SessionBean;
importjavax.ejb.SessionContext;
publicclassAddBeanimplementsSessionBean
{
//somemethoddeclare
}

4.会话BEAN的属性:
a.会话Bean是一种作为单用户执行的对象,作为对远程任务请求的响应,容器产生一个SessionBean的实例,一个SessionBean有一个用户,从某种程度上来说,一个SessionBean对于服务器来说就代表了它的那个用户.
b.SessionBean也能用于事务,它能够更新共享的数据,但它不直接描述这些共享的数据.
c.SessionBean的生命周期是相对短暂的,只用当用户保持会话的时候,SessionBean才是活着的.


5.实体BEAN的属性:
a.EntityBean对数据库中的数据提供了一种对象的视图.
b.多个Client能够共享访问同一个EntityBean,多个Client也能够同时地共享访问同一个EntityBean.
c.EntityBean通过事务的上下文来访问或更新下层的数据.这样,数据的完整性就能够被保证.
d.EntityBean能够存活相对较长的时间,并且状态是持续的.只要数据库存在,EntityBean就一直存活,即使EJB容器崩溃了,EntityBean也是存活的.



6.STATESSESSIONBEAN与STATELESSSESSIONBEAN的区别:
a.一个具有状态的SessionBean称为有状态的SessionBean,当用户终止与SessionBean互操作的时候,会话终止了,Bean也不再拥有状态值.
b.无状态的SessionBean并不掌握它的客户的信息或者状态,用户能够调用Bean的一些方法来完成一些操作.但是,Bean只是在方法调用的时候才知道用户的参数变量,当方法调用完成的时候,Bean不再保持这些参数变量.

J2EEMVC方面

1、MVC的各个部分都有那些技术来实现?如何实现?
答:MVC是Model-View-Controller的简写。
"Model"代表的是应用的业务逻辑(通过JavaBean,EJB组件实现),
"View"是应用的表示面(由JSP页面产生),
"Controller"是提供应用的处理过程控制(一般是一个Servlet),通过这种设计模型把应用逻辑,处理过程和显示逻辑分成不同的组件实现。这些组件可以进行交互和重用。

2、应用服务器与WEBSERVER的区别?
希望大家补上,谢谢

3、J2EE是什么?
答:Je22是Sun公司提出的多层(multi-diered),分布式(distributed),基于组件(component-base)
企业级应用模型(enterprieseapplicationmodel).在这样的一个应用系统中,可按照功能划分为
不同的组件,这些组件又可在不同计算机上,并且处于相应的层次(tier)中。所属层次包括客
户层(clietntier)组件,web层和组件,Business层和组件,企业信息系统(EIS)层。

4、WEBSERVICE名词解释。JSWDL开发包的介绍。JAXP、JAXM的解释。SOAP、UDDI,WSDL解释。
答:WebService描述语言WSDL
SOAP即简单对象访问协议(SimpleObjectAccessProtocol),它是用于交换XML编码信息的轻量级协议。
UDDI的目的是为电子商务建立标准;UDDI是一套基于Web的、分布式的、为WebService提供的、信息注册中心的实现标准规范,同时也包含一组使企业能将自身提供的WebService注册,以使别的企业能够发现的访问协议的实现标准。


5、BS与CS的联系与区别。
答:C/S模式,即客户端(Clinet)和服务器端(Server)的两层结构模式,其特点就是主要业务逻辑集中在客户端,因此,也带来了一定的弊端:
a.首先,在安装,调试,维护,升级方面比较因难,因为每个客户端的配置不同,所以在配置的时候,必须对每个客户端进行配置.
b.由于主要业务逻辑集中在客户端,系统的安全受到影响.
B/S模式,即浏览器端(Browers)和服务器端(Server)的结构模式,其核心是用浏览器(Browers)取代C/S模式中的客户端。其优点是:
a.首先,在维护,升级的时候,只须对服务器端进行维护和升能就可以了。
b.由于客户端就是浏览器,有利于系统的安全。


6、STRUTS的应用(如STRUTS架构)
答: Struts是采用JavaServlet/JavaServerPages技术,开发Web应用程序的开放源码的framework。 采用Struts能开发出基于MVC(Model-View-Controller)设计模式的应用构架。Struts有如下的主要功能:
一.包含一个controllerservlet,能将用户的请求发送到相应的Action对象。
二.JSP自由tag库,并且在controllerservlet中提供关联支持,帮助开发员创建交互式表单应用。
三.提供了一系列实用对象:XML处理、通过JavareflectionAPIs自动处理JavaBeans属性、国际化的提示和消息。

设计模式方面

1、开发中都用到了那些设计模式?用在什么场合?
答: 每个模式都描述了一个在我们的环境中不断出现的问题,然后描述了该问题的解决方案的核心。通过这种方式,你可以无数次地使用那些已有的解决方案,无 需再重复相同的工作。主要用到了MVC的设计模式。用来开发JSP/Servlet或者J2EE的相关应用。简单工厂模式等。

2、UML方面
答:标准建模语言UML。用例图,静态图(包括类图、对象图和包图),行为图,交互图
(顺序图,合作图),实现图,

JavaScript方面

1、如何校验数字型?
varre=/^\d{1,8}$|\.\d{1,2}$/;//定义一个变量,初值为不能包含的字符
varstr=document.form1.all(i).value;//定义一个变量,包含页面中的所有字符。
varr=str.match(re);//比较,看文档变量中是否包含有那些特殊字符。
if(r==null)
{
sign=-4;
break;
}
else{
document.form1.all(i).value=parseFloat(str);//转型
}
CORBA方面

1、CORBA是什么?用途是什么?
答: CORBA标准是公共对象请求代理结构(CommonObjectRequestBrokerArchitecture),由对象管理组织 (ObjectManagementGroup,缩写为OMG)标准化。它的组成是接口定义语言(IDL),语言绑定(binding:也译为 联编)和允许应用程序间互操作的协议。其目的为:
a.用不同的程序设计语言书写
b.在不同的进程中运行
c.为不同的操作系统开发


LINUX方面
1、LINUX下线程,GDI类的解释。
答:LINUX实现的就是基于核心轻量级进程的"一对一"线程模型,一个线程实体对应一个核心轻量级进程,而线程之间的管理在核外函数库中实现。
GDI类为图像设备编程接口类库。

数据库方面

1.写一个SQLServer中的存储过程:

以下为一个带有一个输入参数Vdeptno,返回部门为Vdeptnor的所有职员的信息.

createprocedureEmp_dept
@Vdeptnonumber(2)AS
begin
select*fromempwheredeptno=@Vdeptno
end

2.写一个Oracle中的存储过程:

带IN参数的过程
createorreplaceprocedureaddnew(dnoINnumber,
nameINvarchar2,
locationINvarchar2)IS
begin
insertintodeptvalues(dno,name,location);
dbms_output.put_line(‘1recordinserted’);
end;

带OUT参数的过程
createorreplaceproceduregetsal(nameINvarchar2,
salaryOUTnumber)AS
begin
selectsalintosalaryfromempwhereename=name;
end;

HTTP方面
1.HTTP的请求过程:
当点击一个链接时,浏览器首先找到站点的IP地址,这是通过DNS来实现的,在找到IP地址后就可以建立TCP连接了,连接建立后我们就可以发送请求了. 但这个请求是什么样子的呢?我们现在假设点击了一个从www.webmonkey.com/HTML/96/47/Index2A,HTML 点击了WWW.GRIPY.ORG/MATTARG/这时浏览器会发出下面的请求:
Get/MATTARG/HTML/1.0
User-Agent:Mozilla/2.0(macitosh;1;PPC)
Accept:text/html:*/*
Cookie:name=value
Refetet: http://www.webmonkey.com/html/96/47/index2a.html
Host:www.gtippy.org
第一行称为请求,它告诉服务器从MATTMARG取得文件,这是的目录一般是要加/的,下面几行通知服务器你所使用的浏览器是什么类型,你所接收的 数据是什么类型,如果你以前访问过这个站点,站点可能向你发送了Cookie,如果你已经有了一个这样的Cookie,浏览器会将这个 Cookie返回给服务器,referer行通知服务器用户从哪一页到达此页的.
下面服务器就要返回文件了,每次服务器返回文件时,都要返回一个Http/1.0响应,同进带有状态码,在此之后是述内部的头信息,下面就是一个响应:
HTTP/1.0200Pound
Data:Mon10Feb199723:48:22GMT
Server:Apache/1.11Hot&ired/1.0
Content-type:text/html
Last-Moditied:Tues,11Feb199722:45:55GMT
不同的数据可能返回不同的Content-type,因此不同的内容需要不同的Content-type,因此有时候这个过程是很慢的。
深度学习是机器学习的一个子领域,它基于人工神经网络的研究,特别是利用多层次的神经网络来进行学习和模式识别。深度学习模型能够学习数据的高层次特征,这些特征对于图像和语音识别、自然语言处理、医学图像分析等应用至关重要。以下是深度学习的一些关键概念和组成部分: 1. **神经网络(Neural Networks)**:深度学习的基础是人工神经网络,它是由多个层组成的网络结构,包括输入层、隐藏层和输出层。每个层由多个神经元组成,神经元之间通过权重连接。 2. **前馈神经网络(Feedforward Neural Networks)**:这是最常见的神经网络类型,信息从输入层流向隐藏层,最终到达输出层。 3. **卷积神经网络(Convolutional Neural Networks, CNNs)**:这种网络特别适合处理具有网格结构的数据,如图像。它们使用卷积层来提取图像的特征。 4. **循环神经网络(Recurrent Neural Networks, RNNs)**:这种网络能够处理序列数据,如间序列或自然语言,因为它们具有记忆功能,能够捕捉数据中的间依赖性。 5. **长短期记忆网络(Long Short-Term Memory, LSTM)**:LSTM 是一种特殊的 RNN,它能够学习长期依赖关系,非常适合复杂的序列预测任务。 6. **生成对抗网络(Generative Adversarial Networks, GANs)**:由两个网络组成,一个生成器和一个判别器,它们相互竞争,生成器生成数据,判别器评估数据的真实性。 7. **深度学习框架**:如 TensorFlow、Keras、PyTorch 等,这些框架提供了构建、训练和部署深度学习模型的工具和库。 8. **激活函数(Activation Functions)**:如 ReLU、Sigmoid、Tanh 等,它们在神经网络中用于添加非线性,使得网络能够学习复杂的函数。 9. **损失函数(Loss Functions)**:用于评估模型的预测与真实值之间的差异,常见的损失函数包括均方误差(MSE)、交叉熵(Cross-Entropy)等。 10. **优化算法(Optimization Algorithms)**:如梯度下降(Gradient Descent)、随机梯度下降(SGD)、Adam 等,用于更新网络权重,以最小化损失函数。 11. **正则化(Regularization)**:技术如 Dropout、L1/L2 正则化等,用于防止模型过拟合。 12. **迁移学习(Transfer Learning)**:利用在一个任务上训练好的模型来提高另一个相关任务的性能。 深度学习在许多领域都取得了显著的成就,但它也面临着一些挑战,如对大量数据的依赖、模型的解释性差、计算资源消耗大等。研究人员正在不断探索新的方法来解决这些问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值