- 浏览: 958380 次
- 性别:
- 来自: 魔都
文章分类
- 全部博客 (745)
- MultiThread (19)
- My Plan (118)
- JavaBasic (61)
- MyInterview (104)
- InternetTechnique (5)
- ProjectConclusion (1)
- Maven (5)
- MogoDb (5)
- Hadoop (11)
- Memcached (6)
- TechniqueCollect (1)
- Ibaits (1)
- Android (34)
- ItLife (40)
- Tree (2)
- ProjectArchitect (7)
- Open Source (3)
- liunx (5)
- socket (8)
- Spring (27)
- DesginPattern (35)
- WebBasic (13)
- English (13)
- structs (1)
- structs2 (2)
- Oracle (17)
- Hibernate (2)
- JavaScript (4)
- Jdbc (1)
- Jvm (15)
- Ibatis (1)
- DataStructures (13)
- Https/Socket/Tcp/Ip (3)
- Linux (4)
- Webservice (7)
- Io (2)
- Svn (1)
- Css (1)
- Ajax (1)
- ExtJs (1)
- UML (2)
- DataBase (6)
- BankTechnique (3)
- SpringMvc (3)
- Nio (3)
- Load Balancing/Cluster (3)
- Tools (1)
- javaPerformanceOptimization (8)
- Lucene(SEO) (1)
- My Think (80)
- NodeJs (1)
- Quartz (1)
- Distributed-java (1)
- MySql (7)
- Project (4)
- junit (4)
- framework (1)
- enCache (1)
- git (2)
- SCJP (1)
- sd (1)
最新评论
-
lkjxshi:
你都这水平了还考这个证干嘛
SCJP 认证考试指南 -
钟逸华:
问的真多
百度java开发面试题(转) -
zuimeitulip:
觉得我就是这样的,从小阅读量就很少,导致现在的读的速度非常慢, ...
让读书成为一种习惯 -
DDT_123456:
我觉得你是不符合要求。问你hashmap的那个问题,你那样回答 ...
阿里面试2(转) -
jingjing0907:
刚刚写了很多读过此博客的感受,竟然没有发上去,以为我注册账号还 ...
让读书成为一种习惯
面试要点
了解一下教育背景,是否有真正做过文本分类的算法,可以了解一下分类算法是否熟悉
是否有过B/S的开发经验
传递参数时,什么时候是值传递,什么时候是引用传递
是否使用过JDBC,JDBC的使用方法
try-catch-finally中,如果在try或catch中有return过,是否还执行
简述快速排序
不是用中间变量实现swap(x,y)函数
1、 除了在从前的项目中使用了哪些开源框架开发外,需注重他们是否清楚框架的工作原理;
Jdk1.5新特性,
Spring的原理,事务如何管理,如何防止脏读数据,
你最有成就感的项目,
说说方法sysnchrnized 和方法块sysnchrnized区别,
Hibernate的延迟加载,session何时开启,何时关闭.
2、对java应用的内存处理机制,线程工作原理,并有没有在项目中实际解决该类问题的经验;
3、 有没有在项目中有过系统性能调优,性能跟踪,内存泄漏定位等相关经验,
4、 在解决实际问题时,是否有了解解决问题方法的本质(解决方案的系统原理);
5、 对关系型数据库工作原理,以及关键性能影响点的了解及项目中的实际经验;
6、 是否爱好技术,愿意不断投入时间去跟进,学习(学习的深入度,是否能结合系统原理来看一些新技术);
Java面试题
1.string,stringbuffer 和stringbuilder的区别
2.struts1和2的区别
3.ArrayList,HashMap,HashTable区别
4.谈谈NIO
5.Weblogic怎么发布一个JMS
6.OBJECT有些什么函数,都是做什么用的
7.JSP,SERVLE是线程安全的吗?为什么?
8.了解SOA吗?
9.网页中跨域访问的问题怎么解决
10.ibtas中怎么设置OS CACHE
JAVA面试基础测试题
1.抽象:
抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。
7、String 和StringBuffer的区别
JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类提供了数值不可改变的字符串。而这个StringBuffer类提供的字符串进行修改。当你知道字符数据要改变的时候你就可以使用StringBuffer。典型地,你可以使用 StringBuffers来动态构造字符数据。
9、说出Servlet的生命周期,并说出Servlet和CGI的区别。
Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。
与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。
10、说出ArrayList,Vector, LinkedList的存储性能和特性
ArrayList 和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。
14、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算法都大概一样,所以性能不会有很大的差异。
16、sleep() 和 wait() 有什么区别?
sleep是线程类(Thread)的方法,导致此线程暂停执行指定时间,给执行机会给其他线程,但是监控状态依然保持,到时后会自动恢复。调用sleep不会释放对象锁。
wait是Object类的方法,对此对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态。
19、同步和异步有何异同,在什么情况下分别使用他们?举例说明。
如果数据将在线程间共享。例如正在写的数据以后可能被另一个线程读到,或者正在读的数据可能已经被另一个线程写过了,那么这些数据就是共享数据,必须进行同步存取。
当应用程序在对象上调用了一个需要花费很长时间来执行的方法,并且不希望让程序等待方法的返回时,就应该使用异步编程,在很多情况下采用异步途径往往更有效率。
20、abstract class和interface有什么区别?
声明方法的存在而不去实现它的类被叫做抽象类(abstract class),它用于要创建一个体现某些基本行为的类,并为该类声明方法,但不能在该类中实现该类的情况。不能创建abstract 类的实例。然而可以创建一个变量,其类型是一个抽象类,并让它指向具体子类的一个实例。不能有抽象构造函数或抽象静态方法。Abstract 类的子类为它们父类中的所有抽象方法提供实现,否则它们也是抽象类为。取而代之,在子类中实现该方法。知道其行为的其它类可以在类中实现这些方法。
接口(interface)是抽象类的变体。在接口中,所有方法都是抽象的。多继承性可通过实现这样的接口而获得。接口中的所有方法都是抽象的,没有一个有程序体。接口只可以定义static final成员变量。接口的实现与子类相似,除了该实现类不能从接口定义中继承行为。当类实现特殊接口时,它定义(即将程序体给予)所有这种接口的方法。然后,它可以在实现了该接口的类的任何对象上调用接口的方法。由于有抽象类,它允许使用接口名作为引用变量的类型。通常的动态联编将生效。引用可以转换到接口类型或从接口类型转换,instanceof 运算符可以用来决定某对象的类是否实现了接口。
22、forward 和redirect的区别
forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器,浏览器根本不知道服务器发送的内容是从哪儿来的,所以它的地址栏中还是原来的地址。
redirect就是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址,一般来说浏览器会用刚才请求的所有参数重新请求,所以session,request参数都可以获取。
27、GC是什么? 为什么要有GC?
GC是垃圾收集的意思(Gabage Collection),内存处理是编程人员容易出现问题的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃,Java提供的GC功能可以自动监测对象是否超过作用域从而达到自动回收内存的目的,Java语言没有提供释放已分配内存的显示操作方法。
41、是否可以继承String类?
String类是final类故不可以继承。
48、编程题: 写一个Singleton出来。
Singleton模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在。
一般Singleton模式通常有几种种形式:
第一种形式: 定义一个类,它的构造函数为private的,它有一个static的private的该类变量,在类初始化时实例话,通过一个public的getInstance方法获取对它的引用,继而调用其中的方法。
public class Singleton {
private Singleton(){}
//在自己内部定义自己一个实例,是不是很奇怪?
//注意这是private 只供内部调用
private static Singleton instance = new Singleton();
//这里提供了一个供外部访问本class的静态方法,可以直接访问
public static Singleton getInstance() {
return instance;
}
}
第二种形式:
public class Singleton {
private static Singleton instance = null;
public static synchronized Singleton getInstance() {
//这个方法比上面有所改进,不用每次都进行生成对象,只是第一次
//使用时生成实例,提高了效率!
if (instance==null)
instance=new Singleton();
return instance; }
}
其他形式:
定义一个类,它的构造函数为private的,所有方法为static的。
一般认为第一种形式要更加安全些
52、请说出你所知道的线程同步的方法。
wait():使一个线程处于等待状态,并且释放所持有的对象的lock。
sleep():使一个正在运行的线程处于睡眠状态,是一个静态方法,调用此方法要捕捉InterruptedException异常。
notify():唤醒一个处于等待状态的线程,注意的是在调用此方法的时候,并不能确切的唤醒某一个等待状态的线程,而是由JVM确定唤醒哪个线程,而且不是按优先级。
Allnotity():唤醒所有处入等待状态的线程,注意并不是给所有唤醒线程一个对象的锁,而是让它们竞争。
56、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?
多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
同步的实现方面有两种,分别是synchronized,wait与notify
58、线程的基本概念、线程的基本状态以及状态之间的关系
线程指在程序执行过程中,能够执行程序代码的一个执行单位,每个程序至少都有一个线程,也就是程序本身。
Java中的线程有四种状态分别是:运行、就绪、挂起、结束。
99、java中有几种方法可以实现一个线程?用什么关键字修饰同步方法? stop()和suspend()方法为何不推荐使用?
有两种实现方法,分别是继承Thread类与实现Runnable接口
用synchronized关键字修饰同步方法
反对使用stop(),是因为它不安全。它会解除由线程获取的所有锁定,而且如果对象处于一种不连贯状态,那么其他线程能在那种状态下检查和修改它们。结果很难检查出真正的问题所在。suspend()方法容易发生死锁。调用suspend()的时候,目标线程会停下来,但却仍然持有在这之前获得的锁定。此时,其他任何线程都不能访问锁定的资源,除非被"挂起"的线程恢复运行。对任何线程来说,如果它们想恢复目标线程,同时又试图使用任何一个锁定的资源,就会造成死锁。所以不应该使用suspend(),而应在自己的Thread类中置入一个标志,指出线程应该活动还是挂起。若标志指出线程应该挂起,便用 wait()命其进入等待状态。若标志指出线程应当恢复,则用一个notify()重新启动线程。
125、启动一个线程是用run()还是start()?
启动一个线程是调用start()方法,使线程所代表的虚拟处理机处于可运行状态,这意味着它可以由JVM调度并执行。这并不意味着线程就会立即运行。run()方法可以产生必须退出的标志来停止一个线程。
Java电话面试题及解答(搜索中心)。
1. HashCode的作用是什么?
答:HashCode就是一个散列码,用来在散列存储结构中确定对象的存储地址。HashMap,HashSet,他们在将对象存储时,需要确定它们的地址,而HashCode就是做这个用的。在默认情况下,由Object类定义的hashCode方法会针对不同的对象返回不同的整数,这一般是通过将该对象的内部地址转换成一个整数来实现的。
2. Hash算法?
答:HashCode是用来查找用的,它可以提高查找效率。举例说:
内存中有0,1,2,3,4,5,6,7…,N一共N+1个位置可以存储对象,然后类中有个字段叫ID,如何确定这个对象在内存中的存储位置呢?用ID%(N+1)得到的余数就是存储的位置,当要查找这个对象的时候,只需要将ID%(N+1)的余数得到,就可以立即找到这个对象,大大提高了查找效率。
3. 为什么实现了equals()方法后必须重写hashCode()方法?
答:由于java.lang.Object的规范,如果两个对象根据equals()方法是相等的,那么这两个对象中的每一个对象调用hashCode方法都必须生成相同的整数结果。举例说,在HashSet中,通过被存入对象的hashCode()来确定对象在HashSet中的存储地址,通过equals()来确定存入的对象是否重复,hashCode()和equals()都需要重新定义,因为hashCode()默认是由对象在内存中的存储地址计算返回一个整数得到,而equals()默认是比较对象的引用,如果不同时重写他们的话,那么同一个类产生的两个完全相同的对象就都可以存入Set,因为他们是通过equals()来确定的,这就是HashSet失去了意义。
4. Maven的工作原理?
答:采用远程仓库和本地仓库以及一个类似build.xml的pom.xml,将pom.xml中定义的jar文件从远程仓库下载到本地仓库,哥哥应用使用同一个本地仓库的jar,同一个版本的jar只需要下载一次,而且避免每个应用都去拷贝jar。同时它采用了插件的体系架构,只保留最小号核心,其余功能都通过插件的形式提供。
5. Maven在解决包依赖关系上是怎么做的?
答:在project.xml中配置依赖关系。显式写明依赖的版本号可以解决依赖的问题。
6. iBatis和Hibernate的区别和各自优缺点?
答:IBATIS的最大优点是控制SQL发送的数目,提高数据层的访问效率。IBATIS是半自动化的,通过表和对象的映射以及手写的SQL语句,可以实现比Hibernate更高的查询效率。它的优点具体有易于学习和掌握,容易对SQL进行优化,可以进行细粒度的优化。缺点就是不同的数据库支持不好,缺省的cache支持不好。
Hibernate对JDBC进行了轻量级的封装,使得Java程序员可以使用对象编程的思维来操作数据库。优点是它使用Java反射机制而不是字节码增强程序来实现透明性,它的性能比较好,因为它是个轻量级的框架,映射灵活出色,支持多种关系型数据库,从一对一到多对多的各种复杂关系。缺点是限制你所使用的对象模型,比如一个持久性类不能映射到多个表。
7. HashMap和HashTable的区别?
答:Hashtable是基于陈旧的Dictionary类的,HashMap是Java1.2中引进的Map接口的一个实现。Hashtable是线程安全的,HashMap不是线程安全的。HashMap可以将null作为一个条目的key或者value。
8. List,Set和Map的区别?
答:List顺序存储,可以存储相同的对象。Set顺序存储不能存储相同的对象。Map中含有将key,value作为一组值作为一条记录来存储,key和value都可以分别作为一个collection取出来。
9. 谈谈Java的反射机制?
答:Java发射机制可以让我们在运行时加载,探知,使用编译期间完全未知的classes。换句话说就是Java程序可以加载一个在运行时才得知名称的class,获悉其完整构造,并生成其对象实体,或对其fields设值,或调用其methods。
10. 谈谈JVM工作原理?
答:操作系统装入jvm是通过jdk中的java.exe来完成的,通常有下面四个步骤。1.创建jvm装载环境和配置。2.装载jvm.dll。3.初始化jvm.dll并挂接到JNIENV(JNI调用接口)实例。4.调用JNIENV实例装载并处理class类。
11. 谈谈ClassLoader的工作原理?
答:ClassLoader是用来Class文件到JVM的。ClassLoader在JVM运行的时候加载java核心API以满足java程序最基本的需要,其中就包括用户定义的ClassLoader,这里所谓的用户定义是只通过java程序实现的ClassLoader,一个是ExtClassLoader,这个ClassLoader是用来加载java的扩展API的,也就是/lib/ext中的类。一个是AppClassLoader,这个ClassLoader是用来加载用户机器上CLASSPATH设置目录中的Class的,通常在没有指定ClassLoader的情况下,程序员自定义的类就由该ClassLoader来进行加载。
当运行一个程序的时候,JVM启动,运行bootstrap classloader,该ClassLoader加载Java核心API(ExtClassLoader和AppClassLoader也在此时加载),然后调用ExtClassLoader加载扩展API,最后AppClassLoader加载CLASSPATH目录下定义的Class。这就是一个程序最基本的加载流程。
12. 什么情况下适合使用分布式系统?
13. Google是怎么做到一提交Query就立马返回结果?
答:因为它使用了倒排索引的技术。
14. 说几个J2EE中使用的协议?
答:SOAP, JAXP, JAXM, UDDI
15. JNI和JNDI是干吗用的?区别在哪里?
答:JNI:Java本地接口,允许运行在JVM上的代码调用本地程序和类库,或者被他们调用,这些程序和类库可以是其他语言编写的,比如说C,C++。
JNDI:Java Naming and Directory Interface。Java名称和目录服务接口。提供一个目录系统,让其他各地的应用程序在上面留下自己的索引,从而满足快速查找和定位分布式应用程序的功能。
16. 如何在Oracle中实现分页查询?
答:select * from (select rownum as rowno, T.* from k_task T where … and rownum <= 20) table_alias where table_alias.rowno >= 10; 如果要排序的话把排序子句放到内层查询。
17. final,finally和finalize的区别?
18. UNIX系统下用什么指令查看内存使用情况和CPU型号?
答:AIX下:内存使用情况:lsdev –C | grep mem;CPU型号:lsdev –C | grep –i processor | wc -l
19. 大文件的拷贝用什么办法实现?
答:管道,FileChannel
20. Web Application是通过什么来启动Servlet的?
答:Servlet由Web服务器加载启动。
21. EJB在JBoss或Weblogic中的部署描述符是怎样的?
答:JBoss,通过ejb-jar.xml写部署描述符
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE ejb-jar PUBLIC "-//Sun Microsystems, Inc.//DTD Enterprise JavaBeans 2.0//EN" "http://java.sun.com/j2ee/dtds/ejb-jar_2_0.dtd">
<ejb-jar>
<enterprise-beans>
<session>
<description>Deployment descriptor for Rubis SB_BrowseRegions Bean</description>
<display-name>RUBiS SB_BrowseRegions Bean</display-name>
<ejb-name>SB_BrowseRegions</ejb-name>
<home>edu.rice.rubis.beans.SB_BrowseRegionsHome</home>
<remote>edu.rice.rubis.beans.SB_BrowseRegions</remote>
<ejb-class>edu.rice.rubis.beans.SB_BrowseRegionsBean</ejb-class>
<session-type>Stateless</session-type>
<transaction-type>Bean</transaction-type>
<ejb-ref>
<description>This is the reference to the region bean</description>
<ejb-ref-name>ejb/Region</ejb-ref-name>
<ejb-ref-type>Entity</ejb-ref-type>
<ejb-link>Region</ejb-link>
<home>edu.rice.rubis.beans.RegionHome</home>
<remote>edu.rice.rubis.beans.Region</remote>
</ejb-ref>
<resource-ref>
<res-ref-name>jdbc/rubis</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
</session>
<entity>
<description>Region Bean deployment descriptor</description>
<display-name>Region</display-name>
<ejb-name>Region</ejb-name>
<home>edu.rice.rubis.beans.RegionHome</home>
<remote>edu.rice.rubis.beans.Region</remote>
<ejb-class>edu.rice.rubis.beans.RegionBean</ejb-class>
<persistence-type>Container</persistence-type>
<prim-key-class>edu.rice.rubis.beans.RegionPK</prim-key-class>
<reentrant>False</reentrant>
<cmp-field>
<description>Region name</description>
<field-name>name</field-name>
</cmp-field>
<cmp-field>
<description>Region id</description>
<field-name>id</field-name>
</cmp-field>
<resource-ref>
<res-ref-name>jdbc/rubis</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
</entity>
</enterprise-beans>
<assembly-descriptor>
<container-transaction>
<method>
<ejb-name>Region</ejb-name>
<method-name>*</method-name>
</method>
<trans-attribute>Required</trans-attribute>
</container-transaction>
</assembly-descriptor>
</ejb-jar>
22. 举例几个Apache上的开源项目?
答:iBatis,Maven,Velocity,POI,Ant, Apache HTTP Server.
23. Perl有面向对象的概念吗?它如何实现代码重用?
答:有,通过包或Module来实现代码重用。
24. JDK1.5和JDK1.4多了哪些东西?
泛型,枚举类型,Autoboxing和Unboxing,可变长度的参数列表,Annotation,for/in语句,静态的Import,格式化输出,java.concurrent包支持多线程。
25. WAR包和EAR包的内部目录结构?
答:WAR:WEB-INF/web.xml
EAR: META-INF
26. Object类有哪些方法?
答:equals(), hashCode(), getClass(), toString(), notify(), notifyAll(), wait(), clone()
27. equals()和==的区别?
28. CVS版本控制原理?
答:CVS服务器用于保存项目源(包括源代码,项目文件,文档等任何需要进行版本控制的对象)。但是CVS服务器中的项目源不能被直接使用。要将其导出到客户端,在客户端建立副本才可以对其进行修改编辑。在进行团队开发时,需要对代码进行共享。通常开发人员首先将自己的代码保存(也叫导入或者签入,英文为Check in)到CVS服务器,这样团队中的其他成员可以把这些代码导出(也叫签出,英文为Check out)到本地计算机上。这样就可以在多个客户端上保存同一项目的副本,实现了代码的共享。
29. Rational Clear Case的Branch合并原理?
阿里:
1、花两分钟时间介绍(推销)一下自己?
2、你熟悉JavaEE的哪些技术?比较擅长的是什么?
3、谈谈你最擅长的技术(他上面提到的技术)都包含哪些特性?(注:主要看掌握的深度)
4、说说常用的设计模式有哪些,结合工作中的实例谈谈你是怎么利用这些模式处理实际问题的?
(注:至少能说出4、5个来,能对其中一两个模式结合实例做一下分析)
5、谈谈你对数据库SQL性能优化方面的看法和经验?
6、你对业界的最新技术发展动态有关注吗?最近炒得比较火热的是哪些技术?
阿里对笔试不是很在意,比较在意面试,我去面试的时候就碰到过一次笔试,而且笔试的时候也才过了5分钟,就有考官上来叫我不用笔试,直接面试了。
面试总结
首先自我介绍
1. 面试官拿着你的简历,会挑其中的一个项目,然后让你说出这个框架的流程。
2. 画出框架的流程图,会问每一个部分都是干什么用的。
3. 针对2的问题,我们做的都是web项目,在那个框架中,servlet对应的是哪一个部分。
4. 由前两个问题牵引出web.xml文件配置中都有哪些属性,以及它的作用。
5. 对spring了解吗?
6. spring的依赖注入方式有哪几种(注意不是spring的注入方式是依赖注入)?
7. 有关事务的问题,做项目中做到哪些与事务有关的,事务是怎么控制的,怎么去写?
8. 触发器,存储过程也说了一点.
9. 项目开发中,如果遇到一个问题,你自己也不知道该用什么技术去解决,怎么去解决,该如何去查?
10. 你有三年项目开发经验,觉得自己比别人有优势的地方在哪?
11. 最后会问对他们公司有什么要了解的,给你个机会,让你去问问题。
1,自我介绍,自己做过的项目,擅长的技术。
2,用过的框架,最擅长的那个?
3,所知道的MVC框架还有哪些?
4,经常去些什么样的网站,对自己将来有什么样的打算,规划。
5,喜欢技术吗,(喜欢)。举个例子来说明你喜欢技术。
6,以前项目中有没有加班,频率、加班时间长度。对加班的看法。
7,以前的项目主中要做什么内容,SE级别,还是开发。
8,在项目组怎样做项目,没有详细设计能做吗?
9,Struts用的什么版本。
10,Struts2用过吗?和Struts1有什么区别。
11,Spring的AOP了解吗,主要用在项目的那些方面。
12,以前的项目规模都是多大的。
1. 首先自我介绍
2. 问最熟悉的项目
3. 画出STRUTS框架响应jsp的流程图.
4. 针对2的问题,我们做的都是web项目,在那个框架中,servlet对应的是哪一个部分
5. 由前两个问题牵引出web.xml文件配置中都有哪些属性,以及他的作用
6. 对spring了解吗
7. spring的依赖注入方式有哪几种(注意不是spring的注入方式是依赖注入)
8. 有关事务的问题,做项目中做到哪些与事务有关的,事务是怎么控制的,怎么去写
9. Struts底层的相关知识
10.项目开发中,如果遇到一个问题,你自己也不知道该用什么技术去解决,怎么去解决,该如何去查
11.你有三年项目开发经验,觉得自己比别人有优势的地方在哪
12.最后会问对他们公司有什么要了解的,给你个机会,让你去问问题
1. 首先自我介绍
2. 在你所用过的框架中你比较喜欢那个
3. 问你做过的这些项目中那个收获最大,收获到了什么
4. ibatis 和 Hibernate 的区别
5. servlet 的生命周期
6. spring 的两个主要特性(AOP 和IOC)
7. 说一下你所理解的J2EE是什么
8. 为什么说JBOSS 符合J2EE的要求,而TOMCAT 不符合J2EE的要求
9. Hibernate 的优点和缺点
10. 你认为在项目中最重要的是什么
11. 要是分给你的任务,你感到完成有困难,你会怎么办
12. 最后你对支付宝有什么要问的
总结: 根据面试官不同,他可能喜欢的人也不同,这个面试官喜欢做事有计划的。
工作和学习是分不开的,技术的追求也不是唯一的。但是,做技术的,我认为要适当给自己定位,总得有个目标,也有个标准能够衡量自己,时刻提醒自己有几斤几两。现在能忽悠的人很多,实干的人很少。我不想成为那样的人,为此,得始终保持清醒的头脑。阿里、腾讯、百度应该是国内IT比较好的公司之三,在这里我copy了别人在阿里面试过程中所遇到的问题、面试题,其中有自己知道的、知道不多的、知道不深入的、不知道的、完全不知道的。所以,在这里我将它贴上来,只要有时间就去看看这些知识,始终让自己保持着一个学习的心,期望有一天也能够一展身手吧!
一、String,StringBuffer, StringBuilder 的区别是什么?String为什么是不可变的?
二、VECTOR,ARRAYLIST, LINKEDLIST的区别是什么?
三、HASHTABLE, HASGMAQ,TreeMap区别
四、ConcurrentMap和HashMap的区别
五、Tomcat,apache,jboss的区别
六、GET POST区别
七、SESSION, COOKIE区别
八、Servlet的生命周期
九、HTTP 报文包含内容
十、Statement与PreparedStatement的区别,什么是SQL注入,如何防止SQL注入
十一、redirect, foward区别
十二、关于JAVA内存模型,一个对象(两个属性,四个方法)实例化100次,现在内存中的存储状态,
几个对象,几个属性,几个方法。
十三、谈谈Hibernate的理解,一级和二级缓存的作用,在项目中Hibernate都是怎么使用缓存的
十四、反射讲一讲,主要是概念,都在哪需要反射机制,反射的性能,如何优化
十五、谈谈Hibernate与Ibatis的区别,哪个性能会更高一些
十六、对Spring的理解,项目中都用什么?怎么用的?对IOC、和AOP的理解及实现原理
十七、线程同步,并发操作怎么控制
十八、描述struts的工作流程。
十九、Tomcat的session处理,如果让你实现一个tomcatserver,如何实现session机制
二十、关于Cache(Ehcache,Memcached)
二一、sql的优化相关问题
二二、oracle中 rownum与rowid的理解,一千条记录我查200到300的记录怎么查?
二三、如何分析ORACLE的执行计划?
二四、 DB中索引原理,种类,使用索引的好处和问题是什么?
二五、JVM垃圾回收实现原理。垃圾回收的线程优先级。
二六、jvm 最大内存设置。设置的原理。结合垃圾回收讲讲。
1、了解j2EE规范,选择几点进行重点消化。
2、异常分类,一般性异常和运行期异常,异常捕获。
3、了解spring mvc框架,和struts mvc框架的区别。
4、要对spring和ibatis非常熟悉,必须,熟知。
5、应适当关注需求分析和产品方面的知识。
6、了解多线程相关知识
7、了解java5以及java6新特性
8、熟悉linux相关命令操作。
9、工厂模式,简单工厂、抽象工厂的区别
10、动态代理模式
学习是快乐的!雪学而时习之,不亦说乎!
Servlet的生命周期:
servlet有良好的生存期的定义,包括如何加载、实例化、初始化、处理客户端请求以及如何被移除。这个生存期由javax.servlet.Servlet接口的init,service和destroy方法表达。
1、加载和实例化
容器负责加载和实例化一个servlet。实例化和加载可以发生在引擎启动的时候,也可以推迟到容器需要该servlet为客户请求服务的时候。
首先容器必须先定位servlet类,在必要的情况下,容器使用通常的Java类加载工具加载该servlet,可能是从本机文件系统,也可以是从远程文件系统甚至其它的网络服务。容器加载servlet类以后,它会实例化该类的一个实例。需要注意的是可能会实例化多个实例,例如一个servlet类因为有不同的初始参数而有多个定义,或者servlet实现SingleThreadModel而导致容器为之生成一个实例池。
2、初始化
servlet加载并实例化后,容器必须在它能够处理客户端请求前初始化它。初始化的过程主要是读取永久的配置信息,昂贵资源(例如JDBC连接)以及其它仅仅需要执行一次的任务。通过调用它的init方法并给它传递唯一的一个(每个servlet定义一个)ServletConfig对象完成这个过程。给它传递的这个配置对象允许servlet访问容器的配置信息中的名称-值对(name-value)初始化参数。这个配置对象同时给servlet 提供了访问实现了ServletContext接口的具体对象的方法,该对象描述了servlet的运行环境。
2.1初始化的错误处理
在初始化期间,servlet实例可能通过抛出UnavailableException 或者 ServletException异常表明它不能进行有效服务。如果一个servlet抛出一个这样的异常,它将不会被置入有效服务并且应该被容器立即释放。在此情况下destroy方法不会被调用因为初始化没有成功完成。在失败的实例被释放后,容器可能在任何时候实例化一个新的实例,对这个规则的唯一例外是如果失败的servlet抛出的异常是UnavailableException并且该异常指出了最小的无效时间,那么容器就会至少等待该时间指明的时限才会重新试图创建一个新的实例。
2.2、工具因素
当工具(注:根据笔者的理解,这个工具可能是应用服务器的某些检查工具,通常是验证应用的合法性和完整性)加载和内省(introspect)一个web应用时,它可能加载和内省该应用中的类,这个行为将触发那些类的静态初始方法被执行,因此,开发者不能假定只要当servlet的init方法被调用后它才处于活动容器运行状态(active container runtime)。作为一个例子,这意味着servlet不能在它的静态(类)初始化方法被调用时试图建立数据库连接或者连接EJB容器。
3、处理请求
在servlet被适当地初始化后,容器就可以使用它去处理请求了。每一个请求由ServletRequest类型的对象代表,而servlet使用 ServletResponse回应该请求。这些对象被作为service方法的参数传递给servlet。在HTTP请求的情况下,容器必须提供代表请求和回应的HttpServletRequest和HttpServletResponse的具体实现。需要注意的是容器可能会创建一个servlet实例并将之放入等待服务的状态,但是这个实例在它的生存期中可能根本没有处理过任何请求。
3.1、多线程问题
容器可能同时将多个客户端的请求发送给一个实例的service方法,这也就意味着开发者必须确保编写的servlet可以处理并发问题。如果开发者想防止这种缺省的行为,那么他可以让他编写的servlet实现SingleThreadModel。实现这个类可以保证一次只会有一个线程在执行service 方法并且一次性执行完。容器可以通过将请求排队或者维护一个servlet实例池满足这一点。如果servlet是分布式应用的一部分,那么,那么容器可能在该应用分布的每个JVM中都维护一个实例池。如果开发者使用synchronized关键字定义service方法(或者是doGet和 doPost),容器将排队处理请求,这是由底层的java运行时系统要求的。我们强烈推荐开发者不要同步service方法或者HTTPServlet 的诸如doGet和doPost这样的服务方法。
3.2、处理请求中的异常
servlet在对请求进行服务的时候有可能抛出ServletException或者UnavailableException异常。ServletException表明在处理请求的过程中发生了错误容器应该使用合适的方法清除该请求。UnavailableException表明servlet不能对请求进行处理,可能是暂时的,也可能是永久的。如果UnavailableException指明是永久性的,那么容器必须将servlet从服务中移除,调用它的destroy方法并释放它的实例。如果指明是暂时的,那么容器可以选择在异常信息里面指明的这个暂时无法服务的时间段里面不向它发送任何请求。在这个时间段里面被被拒绝的请求必须使用SERVICE_UNAVAILABLE (503)返回状态进行响应并且应该携带稍后重试(Retry-After)的响应头表明不能服务只是暂时的。容器也可以选择不对暂时性和永久性的不可用进行区分而全部当作永久性的并移除抛出异常的servlet。
3.3线程安全
开发者应该注意容器实现的请求和响应对象(注:即容器实现的HttpServletRequest和HttpServletResponese)没有被保证是线程安全的,这就意味着他们只能在请求处理线程的范围内被使用,这些对象不能被其它执行线程所引用,因为引用的行为是不确定的。
4、服务结束
容器没有被要求将一个加载的servlet保存多长时间,因此一个servlet实例可能只在容器中存活了几毫秒,当然也可能是其它更长的任意时间(但是肯定会短于容器的生存期)当容器决定将之移除时(原因可能是保存内存资源或者自己被关闭),那么它必须允许servlet释放它正在使用的任何资源并保存任何永久状态(这个过程通过调用destroy方法达到)。容器在能够调用destroy方法前,它必须允许那些正在service方法中执行的线程执行完或者在服务器定义的一段时间内执行(这个时间段在容器调用destroy之前)。一旦destroy方法被调用,容器就不会再向该实例发送任何请求。如果容器需要再使用该servlet,它必须创建新的实例。destroy方法完成后,容器必须释放servlet实例以便它能够被垃圾回收。
Java中Error与Exception的区别:
Exceptions
1.可以是 可被控制(checked) 或 不可控制的(unchecked)
2.表示一个由程序员导致的错误
3.应该在应用程序级被处理
Errors
1.总是 不可控制的(unchecked)
2.经常用来用于表示系统错误或低层资源的错误
3.如何可能的话,应该在系统级被捕捉
error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出。不可能指望程序能处理这样的情况。
exception 表示一种设计或实现问题。也就是说,它表示如果程序运行正常,从不会发生的情
进程与线程的区别:
通俗的解释
一个系统运行着很多进程,可以比喻为一条马路上有很多马车
不同的进程可以理解为不同的马车
而同一辆马车可以有很多匹马来拉----这些马就是线程
假设道路的宽度恰好可以通过一辆马车
道路可以认为是临界资源
那么马车成为分配资源的最小单位(进程)
而同一个马车被很多匹马驱动(线程)----即最小的运行单位
每辆马车马匹数>=1
所以马匹数=1的时候进程和线程没有严格界限,只存在一个概念上的区分度
马匹数>1的时候才可以严格区分进程和线程
专业的解释
简而言之,一个程序至少有一个进程,一个进程至少有一个线程.
线程的划分尺度小于进程,使得多线程程序的并发性高。另外,进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。
线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。
从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的重要区别。
进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位.
线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源.
一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行.
Java的序列化接口的作用:
Serializable接口,是作为一个标记使用的,因为本身没有任何方法需要实现;
Java内部的序列化机制会检查此接口,如果有这个接口,则序列化它,否则不序列化。
典型的用途是在分布式Java编程里,比如通过RMI或者EJB,需要在网络上传输的对象,一定要实现此接口,否则程序会出错,因为在网络上传递对象需要先序列化它。
使用序列化的目的有一个两个:一个是为了persistent对象,如在Hibernate中要保存的对象必须是序列化的;第二个是为了跨平台传输,消除平台间的差异,如在JMS中,传送的消息对象都必须是序列化的.
Hibernate的三种状态以及表现形式:
objects在hibernate中的生命周期中存在3种状态:transient, persistent, detached。附件1描述的即是hibernate application中objects的生命周期。
通过new操作符生成的object是transient object,此时的object还没有和数据库中的任何数据关联,所以一旦没有被引用,就会被jvm垃圾收集。一旦通过Hibernate 的Persistence manager执行了save()方法或者被其他已经存在的Persistent objects引用,那么object的状态就会从transient转为persistent。
Persistent objects是包含在transactions中的,它们的状态是通过transactions来控制的, Persistent objects是和数据库中的表对应的,所以表示主键的属性不会为空,也就是说每一个persistent object都会有一个匹配的database identity,除非是通过new产生的新的transient object,此时object的database identity是空的,如果在transaction中对该object执行save()方法,那么在transaction成功结束的时候该 object会在数据库中新增一条对应的记录,其它已经存在的persistent objects会相应的更新数据库中的相应行。
当Hibernate中的Persistence Manager执行close()方法,也就是persistence Manager放弃对persistent objects的控制,那么persistent objects的状态就转为detached objects。这些detached objects可以在未来被新的persistence manager重新控制并使用。这种将object从transaction转向表现层然后又重新包含于新的Transaction的实现是 Hibernate的一个卖点。
在objects存在的三种状态中,处于persistent状态中object的比较是通过该object的database identity来确定的,所以这里需要override equals()来实现。其它状态中的objects就可以简单的通过java的equality来判断即可。
了解一下教育背景,是否有真正做过文本分类的算法,可以了解一下分类算法是否熟悉
是否有过B/S的开发经验
传递参数时,什么时候是值传递,什么时候是引用传递
是否使用过JDBC,JDBC的使用方法
try-catch-finally中,如果在try或catch中有return过,是否还执行
简述快速排序
不是用中间变量实现swap(x,y)函数
1、 除了在从前的项目中使用了哪些开源框架开发外,需注重他们是否清楚框架的工作原理;
Jdk1.5新特性,
Spring的原理,事务如何管理,如何防止脏读数据,
你最有成就感的项目,
说说方法sysnchrnized 和方法块sysnchrnized区别,
Hibernate的延迟加载,session何时开启,何时关闭.
2、对java应用的内存处理机制,线程工作原理,并有没有在项目中实际解决该类问题的经验;
3、 有没有在项目中有过系统性能调优,性能跟踪,内存泄漏定位等相关经验,
4、 在解决实际问题时,是否有了解解决问题方法的本质(解决方案的系统原理);
5、 对关系型数据库工作原理,以及关键性能影响点的了解及项目中的实际经验;
6、 是否爱好技术,愿意不断投入时间去跟进,学习(学习的深入度,是否能结合系统原理来看一些新技术);
Java面试题
1.string,stringbuffer 和stringbuilder的区别
2.struts1和2的区别
3.ArrayList,HashMap,HashTable区别
4.谈谈NIO
5.Weblogic怎么发布一个JMS
6.OBJECT有些什么函数,都是做什么用的
7.JSP,SERVLE是线程安全的吗?为什么?
8.了解SOA吗?
9.网页中跨域访问的问题怎么解决
10.ibtas中怎么设置OS CACHE
JAVA面试基础测试题
1.抽象:
抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。
7、String 和StringBuffer的区别
JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类提供了数值不可改变的字符串。而这个StringBuffer类提供的字符串进行修改。当你知道字符数据要改变的时候你就可以使用StringBuffer。典型地,你可以使用 StringBuffers来动态构造字符数据。
9、说出Servlet的生命周期,并说出Servlet和CGI的区别。
Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。
与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。
10、说出ArrayList,Vector, LinkedList的存储性能和特性
ArrayList 和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。
14、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算法都大概一样,所以性能不会有很大的差异。
16、sleep() 和 wait() 有什么区别?
sleep是线程类(Thread)的方法,导致此线程暂停执行指定时间,给执行机会给其他线程,但是监控状态依然保持,到时后会自动恢复。调用sleep不会释放对象锁。
wait是Object类的方法,对此对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态。
19、同步和异步有何异同,在什么情况下分别使用他们?举例说明。
如果数据将在线程间共享。例如正在写的数据以后可能被另一个线程读到,或者正在读的数据可能已经被另一个线程写过了,那么这些数据就是共享数据,必须进行同步存取。
当应用程序在对象上调用了一个需要花费很长时间来执行的方法,并且不希望让程序等待方法的返回时,就应该使用异步编程,在很多情况下采用异步途径往往更有效率。
20、abstract class和interface有什么区别?
声明方法的存在而不去实现它的类被叫做抽象类(abstract class),它用于要创建一个体现某些基本行为的类,并为该类声明方法,但不能在该类中实现该类的情况。不能创建abstract 类的实例。然而可以创建一个变量,其类型是一个抽象类,并让它指向具体子类的一个实例。不能有抽象构造函数或抽象静态方法。Abstract 类的子类为它们父类中的所有抽象方法提供实现,否则它们也是抽象类为。取而代之,在子类中实现该方法。知道其行为的其它类可以在类中实现这些方法。
接口(interface)是抽象类的变体。在接口中,所有方法都是抽象的。多继承性可通过实现这样的接口而获得。接口中的所有方法都是抽象的,没有一个有程序体。接口只可以定义static final成员变量。接口的实现与子类相似,除了该实现类不能从接口定义中继承行为。当类实现特殊接口时,它定义(即将程序体给予)所有这种接口的方法。然后,它可以在实现了该接口的类的任何对象上调用接口的方法。由于有抽象类,它允许使用接口名作为引用变量的类型。通常的动态联编将生效。引用可以转换到接口类型或从接口类型转换,instanceof 运算符可以用来决定某对象的类是否实现了接口。
22、forward 和redirect的区别
forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器,浏览器根本不知道服务器发送的内容是从哪儿来的,所以它的地址栏中还是原来的地址。
redirect就是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址,一般来说浏览器会用刚才请求的所有参数重新请求,所以session,request参数都可以获取。
27、GC是什么? 为什么要有GC?
GC是垃圾收集的意思(Gabage Collection),内存处理是编程人员容易出现问题的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃,Java提供的GC功能可以自动监测对象是否超过作用域从而达到自动回收内存的目的,Java语言没有提供释放已分配内存的显示操作方法。
41、是否可以继承String类?
String类是final类故不可以继承。
48、编程题: 写一个Singleton出来。
Singleton模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在。
一般Singleton模式通常有几种种形式:
第一种形式: 定义一个类,它的构造函数为private的,它有一个static的private的该类变量,在类初始化时实例话,通过一个public的getInstance方法获取对它的引用,继而调用其中的方法。
public class Singleton {
private Singleton(){}
//在自己内部定义自己一个实例,是不是很奇怪?
//注意这是private 只供内部调用
private static Singleton instance = new Singleton();
//这里提供了一个供外部访问本class的静态方法,可以直接访问
public static Singleton getInstance() {
return instance;
}
}
第二种形式:
public class Singleton {
private static Singleton instance = null;
public static synchronized Singleton getInstance() {
//这个方法比上面有所改进,不用每次都进行生成对象,只是第一次
//使用时生成实例,提高了效率!
if (instance==null)
instance=new Singleton();
return instance; }
}
其他形式:
定义一个类,它的构造函数为private的,所有方法为static的。
一般认为第一种形式要更加安全些
52、请说出你所知道的线程同步的方法。
wait():使一个线程处于等待状态,并且释放所持有的对象的lock。
sleep():使一个正在运行的线程处于睡眠状态,是一个静态方法,调用此方法要捕捉InterruptedException异常。
notify():唤醒一个处于等待状态的线程,注意的是在调用此方法的时候,并不能确切的唤醒某一个等待状态的线程,而是由JVM确定唤醒哪个线程,而且不是按优先级。
Allnotity():唤醒所有处入等待状态的线程,注意并不是给所有唤醒线程一个对象的锁,而是让它们竞争。
56、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?
多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
同步的实现方面有两种,分别是synchronized,wait与notify
58、线程的基本概念、线程的基本状态以及状态之间的关系
线程指在程序执行过程中,能够执行程序代码的一个执行单位,每个程序至少都有一个线程,也就是程序本身。
Java中的线程有四种状态分别是:运行、就绪、挂起、结束。
99、java中有几种方法可以实现一个线程?用什么关键字修饰同步方法? stop()和suspend()方法为何不推荐使用?
有两种实现方法,分别是继承Thread类与实现Runnable接口
用synchronized关键字修饰同步方法
反对使用stop(),是因为它不安全。它会解除由线程获取的所有锁定,而且如果对象处于一种不连贯状态,那么其他线程能在那种状态下检查和修改它们。结果很难检查出真正的问题所在。suspend()方法容易发生死锁。调用suspend()的时候,目标线程会停下来,但却仍然持有在这之前获得的锁定。此时,其他任何线程都不能访问锁定的资源,除非被"挂起"的线程恢复运行。对任何线程来说,如果它们想恢复目标线程,同时又试图使用任何一个锁定的资源,就会造成死锁。所以不应该使用suspend(),而应在自己的Thread类中置入一个标志,指出线程应该活动还是挂起。若标志指出线程应该挂起,便用 wait()命其进入等待状态。若标志指出线程应当恢复,则用一个notify()重新启动线程。
125、启动一个线程是用run()还是start()?
启动一个线程是调用start()方法,使线程所代表的虚拟处理机处于可运行状态,这意味着它可以由JVM调度并执行。这并不意味着线程就会立即运行。run()方法可以产生必须退出的标志来停止一个线程。
Java电话面试题及解答(搜索中心)。
1. HashCode的作用是什么?
答:HashCode就是一个散列码,用来在散列存储结构中确定对象的存储地址。HashMap,HashSet,他们在将对象存储时,需要确定它们的地址,而HashCode就是做这个用的。在默认情况下,由Object类定义的hashCode方法会针对不同的对象返回不同的整数,这一般是通过将该对象的内部地址转换成一个整数来实现的。
2. Hash算法?
答:HashCode是用来查找用的,它可以提高查找效率。举例说:
内存中有0,1,2,3,4,5,6,7…,N一共N+1个位置可以存储对象,然后类中有个字段叫ID,如何确定这个对象在内存中的存储位置呢?用ID%(N+1)得到的余数就是存储的位置,当要查找这个对象的时候,只需要将ID%(N+1)的余数得到,就可以立即找到这个对象,大大提高了查找效率。
3. 为什么实现了equals()方法后必须重写hashCode()方法?
答:由于java.lang.Object的规范,如果两个对象根据equals()方法是相等的,那么这两个对象中的每一个对象调用hashCode方法都必须生成相同的整数结果。举例说,在HashSet中,通过被存入对象的hashCode()来确定对象在HashSet中的存储地址,通过equals()来确定存入的对象是否重复,hashCode()和equals()都需要重新定义,因为hashCode()默认是由对象在内存中的存储地址计算返回一个整数得到,而equals()默认是比较对象的引用,如果不同时重写他们的话,那么同一个类产生的两个完全相同的对象就都可以存入Set,因为他们是通过equals()来确定的,这就是HashSet失去了意义。
4. Maven的工作原理?
答:采用远程仓库和本地仓库以及一个类似build.xml的pom.xml,将pom.xml中定义的jar文件从远程仓库下载到本地仓库,哥哥应用使用同一个本地仓库的jar,同一个版本的jar只需要下载一次,而且避免每个应用都去拷贝jar。同时它采用了插件的体系架构,只保留最小号核心,其余功能都通过插件的形式提供。
5. Maven在解决包依赖关系上是怎么做的?
答:在project.xml中配置依赖关系。显式写明依赖的版本号可以解决依赖的问题。
6. iBatis和Hibernate的区别和各自优缺点?
答:IBATIS的最大优点是控制SQL发送的数目,提高数据层的访问效率。IBATIS是半自动化的,通过表和对象的映射以及手写的SQL语句,可以实现比Hibernate更高的查询效率。它的优点具体有易于学习和掌握,容易对SQL进行优化,可以进行细粒度的优化。缺点就是不同的数据库支持不好,缺省的cache支持不好。
Hibernate对JDBC进行了轻量级的封装,使得Java程序员可以使用对象编程的思维来操作数据库。优点是它使用Java反射机制而不是字节码增强程序来实现透明性,它的性能比较好,因为它是个轻量级的框架,映射灵活出色,支持多种关系型数据库,从一对一到多对多的各种复杂关系。缺点是限制你所使用的对象模型,比如一个持久性类不能映射到多个表。
7. HashMap和HashTable的区别?
答:Hashtable是基于陈旧的Dictionary类的,HashMap是Java1.2中引进的Map接口的一个实现。Hashtable是线程安全的,HashMap不是线程安全的。HashMap可以将null作为一个条目的key或者value。
8. List,Set和Map的区别?
答:List顺序存储,可以存储相同的对象。Set顺序存储不能存储相同的对象。Map中含有将key,value作为一组值作为一条记录来存储,key和value都可以分别作为一个collection取出来。
9. 谈谈Java的反射机制?
答:Java发射机制可以让我们在运行时加载,探知,使用编译期间完全未知的classes。换句话说就是Java程序可以加载一个在运行时才得知名称的class,获悉其完整构造,并生成其对象实体,或对其fields设值,或调用其methods。
10. 谈谈JVM工作原理?
答:操作系统装入jvm是通过jdk中的java.exe来完成的,通常有下面四个步骤。1.创建jvm装载环境和配置。2.装载jvm.dll。3.初始化jvm.dll并挂接到JNIENV(JNI调用接口)实例。4.调用JNIENV实例装载并处理class类。
11. 谈谈ClassLoader的工作原理?
答:ClassLoader是用来Class文件到JVM的。ClassLoader在JVM运行的时候加载java核心API以满足java程序最基本的需要,其中就包括用户定义的ClassLoader,这里所谓的用户定义是只通过java程序实现的ClassLoader,一个是ExtClassLoader,这个ClassLoader是用来加载java的扩展API的,也就是/lib/ext中的类。一个是AppClassLoader,这个ClassLoader是用来加载用户机器上CLASSPATH设置目录中的Class的,通常在没有指定ClassLoader的情况下,程序员自定义的类就由该ClassLoader来进行加载。
当运行一个程序的时候,JVM启动,运行bootstrap classloader,该ClassLoader加载Java核心API(ExtClassLoader和AppClassLoader也在此时加载),然后调用ExtClassLoader加载扩展API,最后AppClassLoader加载CLASSPATH目录下定义的Class。这就是一个程序最基本的加载流程。
12. 什么情况下适合使用分布式系统?
13. Google是怎么做到一提交Query就立马返回结果?
答:因为它使用了倒排索引的技术。
14. 说几个J2EE中使用的协议?
答:SOAP, JAXP, JAXM, UDDI
15. JNI和JNDI是干吗用的?区别在哪里?
答:JNI:Java本地接口,允许运行在JVM上的代码调用本地程序和类库,或者被他们调用,这些程序和类库可以是其他语言编写的,比如说C,C++。
JNDI:Java Naming and Directory Interface。Java名称和目录服务接口。提供一个目录系统,让其他各地的应用程序在上面留下自己的索引,从而满足快速查找和定位分布式应用程序的功能。
16. 如何在Oracle中实现分页查询?
答:select * from (select rownum as rowno, T.* from k_task T where … and rownum <= 20) table_alias where table_alias.rowno >= 10; 如果要排序的话把排序子句放到内层查询。
17. final,finally和finalize的区别?
18. UNIX系统下用什么指令查看内存使用情况和CPU型号?
答:AIX下:内存使用情况:lsdev –C | grep mem;CPU型号:lsdev –C | grep –i processor | wc -l
19. 大文件的拷贝用什么办法实现?
答:管道,FileChannel
20. Web Application是通过什么来启动Servlet的?
答:Servlet由Web服务器加载启动。
21. EJB在JBoss或Weblogic中的部署描述符是怎样的?
答:JBoss,通过ejb-jar.xml写部署描述符
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE ejb-jar PUBLIC "-//Sun Microsystems, Inc.//DTD Enterprise JavaBeans 2.0//EN" "http://java.sun.com/j2ee/dtds/ejb-jar_2_0.dtd">
<ejb-jar>
<enterprise-beans>
<session>
<description>Deployment descriptor for Rubis SB_BrowseRegions Bean</description>
<display-name>RUBiS SB_BrowseRegions Bean</display-name>
<ejb-name>SB_BrowseRegions</ejb-name>
<home>edu.rice.rubis.beans.SB_BrowseRegionsHome</home>
<remote>edu.rice.rubis.beans.SB_BrowseRegions</remote>
<ejb-class>edu.rice.rubis.beans.SB_BrowseRegionsBean</ejb-class>
<session-type>Stateless</session-type>
<transaction-type>Bean</transaction-type>
<ejb-ref>
<description>This is the reference to the region bean</description>
<ejb-ref-name>ejb/Region</ejb-ref-name>
<ejb-ref-type>Entity</ejb-ref-type>
<ejb-link>Region</ejb-link>
<home>edu.rice.rubis.beans.RegionHome</home>
<remote>edu.rice.rubis.beans.Region</remote>
</ejb-ref>
<resource-ref>
<res-ref-name>jdbc/rubis</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
</session>
<entity>
<description>Region Bean deployment descriptor</description>
<display-name>Region</display-name>
<ejb-name>Region</ejb-name>
<home>edu.rice.rubis.beans.RegionHome</home>
<remote>edu.rice.rubis.beans.Region</remote>
<ejb-class>edu.rice.rubis.beans.RegionBean</ejb-class>
<persistence-type>Container</persistence-type>
<prim-key-class>edu.rice.rubis.beans.RegionPK</prim-key-class>
<reentrant>False</reentrant>
<cmp-field>
<description>Region name</description>
<field-name>name</field-name>
</cmp-field>
<cmp-field>
<description>Region id</description>
<field-name>id</field-name>
</cmp-field>
<resource-ref>
<res-ref-name>jdbc/rubis</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
</entity>
</enterprise-beans>
<assembly-descriptor>
<container-transaction>
<method>
<ejb-name>Region</ejb-name>
<method-name>*</method-name>
</method>
<trans-attribute>Required</trans-attribute>
</container-transaction>
</assembly-descriptor>
</ejb-jar>
22. 举例几个Apache上的开源项目?
答:iBatis,Maven,Velocity,POI,Ant, Apache HTTP Server.
23. Perl有面向对象的概念吗?它如何实现代码重用?
答:有,通过包或Module来实现代码重用。
24. JDK1.5和JDK1.4多了哪些东西?
泛型,枚举类型,Autoboxing和Unboxing,可变长度的参数列表,Annotation,for/in语句,静态的Import,格式化输出,java.concurrent包支持多线程。
25. WAR包和EAR包的内部目录结构?
答:WAR:WEB-INF/web.xml
EAR: META-INF
26. Object类有哪些方法?
答:equals(), hashCode(), getClass(), toString(), notify(), notifyAll(), wait(), clone()
27. equals()和==的区别?
28. CVS版本控制原理?
答:CVS服务器用于保存项目源(包括源代码,项目文件,文档等任何需要进行版本控制的对象)。但是CVS服务器中的项目源不能被直接使用。要将其导出到客户端,在客户端建立副本才可以对其进行修改编辑。在进行团队开发时,需要对代码进行共享。通常开发人员首先将自己的代码保存(也叫导入或者签入,英文为Check in)到CVS服务器,这样团队中的其他成员可以把这些代码导出(也叫签出,英文为Check out)到本地计算机上。这样就可以在多个客户端上保存同一项目的副本,实现了代码的共享。
29. Rational Clear Case的Branch合并原理?
阿里:
1、花两分钟时间介绍(推销)一下自己?
2、你熟悉JavaEE的哪些技术?比较擅长的是什么?
3、谈谈你最擅长的技术(他上面提到的技术)都包含哪些特性?(注:主要看掌握的深度)
4、说说常用的设计模式有哪些,结合工作中的实例谈谈你是怎么利用这些模式处理实际问题的?
(注:至少能说出4、5个来,能对其中一两个模式结合实例做一下分析)
5、谈谈你对数据库SQL性能优化方面的看法和经验?
6、你对业界的最新技术发展动态有关注吗?最近炒得比较火热的是哪些技术?
阿里对笔试不是很在意,比较在意面试,我去面试的时候就碰到过一次笔试,而且笔试的时候也才过了5分钟,就有考官上来叫我不用笔试,直接面试了。
面试总结
首先自我介绍
1. 面试官拿着你的简历,会挑其中的一个项目,然后让你说出这个框架的流程。
2. 画出框架的流程图,会问每一个部分都是干什么用的。
3. 针对2的问题,我们做的都是web项目,在那个框架中,servlet对应的是哪一个部分。
4. 由前两个问题牵引出web.xml文件配置中都有哪些属性,以及它的作用。
5. 对spring了解吗?
6. spring的依赖注入方式有哪几种(注意不是spring的注入方式是依赖注入)?
7. 有关事务的问题,做项目中做到哪些与事务有关的,事务是怎么控制的,怎么去写?
8. 触发器,存储过程也说了一点.
9. 项目开发中,如果遇到一个问题,你自己也不知道该用什么技术去解决,怎么去解决,该如何去查?
10. 你有三年项目开发经验,觉得自己比别人有优势的地方在哪?
11. 最后会问对他们公司有什么要了解的,给你个机会,让你去问问题。
1,自我介绍,自己做过的项目,擅长的技术。
2,用过的框架,最擅长的那个?
3,所知道的MVC框架还有哪些?
4,经常去些什么样的网站,对自己将来有什么样的打算,规划。
5,喜欢技术吗,(喜欢)。举个例子来说明你喜欢技术。
6,以前项目中有没有加班,频率、加班时间长度。对加班的看法。
7,以前的项目主中要做什么内容,SE级别,还是开发。
8,在项目组怎样做项目,没有详细设计能做吗?
9,Struts用的什么版本。
10,Struts2用过吗?和Struts1有什么区别。
11,Spring的AOP了解吗,主要用在项目的那些方面。
12,以前的项目规模都是多大的。
1. 首先自我介绍
2. 问最熟悉的项目
3. 画出STRUTS框架响应jsp的流程图.
4. 针对2的问题,我们做的都是web项目,在那个框架中,servlet对应的是哪一个部分
5. 由前两个问题牵引出web.xml文件配置中都有哪些属性,以及他的作用
6. 对spring了解吗
7. spring的依赖注入方式有哪几种(注意不是spring的注入方式是依赖注入)
8. 有关事务的问题,做项目中做到哪些与事务有关的,事务是怎么控制的,怎么去写
9. Struts底层的相关知识
10.项目开发中,如果遇到一个问题,你自己也不知道该用什么技术去解决,怎么去解决,该如何去查
11.你有三年项目开发经验,觉得自己比别人有优势的地方在哪
12.最后会问对他们公司有什么要了解的,给你个机会,让你去问问题
1. 首先自我介绍
2. 在你所用过的框架中你比较喜欢那个
3. 问你做过的这些项目中那个收获最大,收获到了什么
4. ibatis 和 Hibernate 的区别
5. servlet 的生命周期
6. spring 的两个主要特性(AOP 和IOC)
7. 说一下你所理解的J2EE是什么
8. 为什么说JBOSS 符合J2EE的要求,而TOMCAT 不符合J2EE的要求
9. Hibernate 的优点和缺点
10. 你认为在项目中最重要的是什么
11. 要是分给你的任务,你感到完成有困难,你会怎么办
12. 最后你对支付宝有什么要问的
总结: 根据面试官不同,他可能喜欢的人也不同,这个面试官喜欢做事有计划的。
工作和学习是分不开的,技术的追求也不是唯一的。但是,做技术的,我认为要适当给自己定位,总得有个目标,也有个标准能够衡量自己,时刻提醒自己有几斤几两。现在能忽悠的人很多,实干的人很少。我不想成为那样的人,为此,得始终保持清醒的头脑。阿里、腾讯、百度应该是国内IT比较好的公司之三,在这里我copy了别人在阿里面试过程中所遇到的问题、面试题,其中有自己知道的、知道不多的、知道不深入的、不知道的、完全不知道的。所以,在这里我将它贴上来,只要有时间就去看看这些知识,始终让自己保持着一个学习的心,期望有一天也能够一展身手吧!
一、String,StringBuffer, StringBuilder 的区别是什么?String为什么是不可变的?
二、VECTOR,ARRAYLIST, LINKEDLIST的区别是什么?
三、HASHTABLE, HASGMAQ,TreeMap区别
四、ConcurrentMap和HashMap的区别
五、Tomcat,apache,jboss的区别
六、GET POST区别
七、SESSION, COOKIE区别
八、Servlet的生命周期
九、HTTP 报文包含内容
十、Statement与PreparedStatement的区别,什么是SQL注入,如何防止SQL注入
十一、redirect, foward区别
十二、关于JAVA内存模型,一个对象(两个属性,四个方法)实例化100次,现在内存中的存储状态,
几个对象,几个属性,几个方法。
十三、谈谈Hibernate的理解,一级和二级缓存的作用,在项目中Hibernate都是怎么使用缓存的
十四、反射讲一讲,主要是概念,都在哪需要反射机制,反射的性能,如何优化
十五、谈谈Hibernate与Ibatis的区别,哪个性能会更高一些
十六、对Spring的理解,项目中都用什么?怎么用的?对IOC、和AOP的理解及实现原理
十七、线程同步,并发操作怎么控制
十八、描述struts的工作流程。
十九、Tomcat的session处理,如果让你实现一个tomcatserver,如何实现session机制
二十、关于Cache(Ehcache,Memcached)
二一、sql的优化相关问题
二二、oracle中 rownum与rowid的理解,一千条记录我查200到300的记录怎么查?
二三、如何分析ORACLE的执行计划?
二四、 DB中索引原理,种类,使用索引的好处和问题是什么?
二五、JVM垃圾回收实现原理。垃圾回收的线程优先级。
二六、jvm 最大内存设置。设置的原理。结合垃圾回收讲讲。
1、了解j2EE规范,选择几点进行重点消化。
2、异常分类,一般性异常和运行期异常,异常捕获。
3、了解spring mvc框架,和struts mvc框架的区别。
4、要对spring和ibatis非常熟悉,必须,熟知。
5、应适当关注需求分析和产品方面的知识。
6、了解多线程相关知识
7、了解java5以及java6新特性
8、熟悉linux相关命令操作。
9、工厂模式,简单工厂、抽象工厂的区别
10、动态代理模式
学习是快乐的!雪学而时习之,不亦说乎!
Servlet的生命周期:
servlet有良好的生存期的定义,包括如何加载、实例化、初始化、处理客户端请求以及如何被移除。这个生存期由javax.servlet.Servlet接口的init,service和destroy方法表达。
1、加载和实例化
容器负责加载和实例化一个servlet。实例化和加载可以发生在引擎启动的时候,也可以推迟到容器需要该servlet为客户请求服务的时候。
首先容器必须先定位servlet类,在必要的情况下,容器使用通常的Java类加载工具加载该servlet,可能是从本机文件系统,也可以是从远程文件系统甚至其它的网络服务。容器加载servlet类以后,它会实例化该类的一个实例。需要注意的是可能会实例化多个实例,例如一个servlet类因为有不同的初始参数而有多个定义,或者servlet实现SingleThreadModel而导致容器为之生成一个实例池。
2、初始化
servlet加载并实例化后,容器必须在它能够处理客户端请求前初始化它。初始化的过程主要是读取永久的配置信息,昂贵资源(例如JDBC连接)以及其它仅仅需要执行一次的任务。通过调用它的init方法并给它传递唯一的一个(每个servlet定义一个)ServletConfig对象完成这个过程。给它传递的这个配置对象允许servlet访问容器的配置信息中的名称-值对(name-value)初始化参数。这个配置对象同时给servlet 提供了访问实现了ServletContext接口的具体对象的方法,该对象描述了servlet的运行环境。
2.1初始化的错误处理
在初始化期间,servlet实例可能通过抛出UnavailableException 或者 ServletException异常表明它不能进行有效服务。如果一个servlet抛出一个这样的异常,它将不会被置入有效服务并且应该被容器立即释放。在此情况下destroy方法不会被调用因为初始化没有成功完成。在失败的实例被释放后,容器可能在任何时候实例化一个新的实例,对这个规则的唯一例外是如果失败的servlet抛出的异常是UnavailableException并且该异常指出了最小的无效时间,那么容器就会至少等待该时间指明的时限才会重新试图创建一个新的实例。
2.2、工具因素
当工具(注:根据笔者的理解,这个工具可能是应用服务器的某些检查工具,通常是验证应用的合法性和完整性)加载和内省(introspect)一个web应用时,它可能加载和内省该应用中的类,这个行为将触发那些类的静态初始方法被执行,因此,开发者不能假定只要当servlet的init方法被调用后它才处于活动容器运行状态(active container runtime)。作为一个例子,这意味着servlet不能在它的静态(类)初始化方法被调用时试图建立数据库连接或者连接EJB容器。
3、处理请求
在servlet被适当地初始化后,容器就可以使用它去处理请求了。每一个请求由ServletRequest类型的对象代表,而servlet使用 ServletResponse回应该请求。这些对象被作为service方法的参数传递给servlet。在HTTP请求的情况下,容器必须提供代表请求和回应的HttpServletRequest和HttpServletResponse的具体实现。需要注意的是容器可能会创建一个servlet实例并将之放入等待服务的状态,但是这个实例在它的生存期中可能根本没有处理过任何请求。
3.1、多线程问题
容器可能同时将多个客户端的请求发送给一个实例的service方法,这也就意味着开发者必须确保编写的servlet可以处理并发问题。如果开发者想防止这种缺省的行为,那么他可以让他编写的servlet实现SingleThreadModel。实现这个类可以保证一次只会有一个线程在执行service 方法并且一次性执行完。容器可以通过将请求排队或者维护一个servlet实例池满足这一点。如果servlet是分布式应用的一部分,那么,那么容器可能在该应用分布的每个JVM中都维护一个实例池。如果开发者使用synchronized关键字定义service方法(或者是doGet和 doPost),容器将排队处理请求,这是由底层的java运行时系统要求的。我们强烈推荐开发者不要同步service方法或者HTTPServlet 的诸如doGet和doPost这样的服务方法。
3.2、处理请求中的异常
servlet在对请求进行服务的时候有可能抛出ServletException或者UnavailableException异常。ServletException表明在处理请求的过程中发生了错误容器应该使用合适的方法清除该请求。UnavailableException表明servlet不能对请求进行处理,可能是暂时的,也可能是永久的。如果UnavailableException指明是永久性的,那么容器必须将servlet从服务中移除,调用它的destroy方法并释放它的实例。如果指明是暂时的,那么容器可以选择在异常信息里面指明的这个暂时无法服务的时间段里面不向它发送任何请求。在这个时间段里面被被拒绝的请求必须使用SERVICE_UNAVAILABLE (503)返回状态进行响应并且应该携带稍后重试(Retry-After)的响应头表明不能服务只是暂时的。容器也可以选择不对暂时性和永久性的不可用进行区分而全部当作永久性的并移除抛出异常的servlet。
3.3线程安全
开发者应该注意容器实现的请求和响应对象(注:即容器实现的HttpServletRequest和HttpServletResponese)没有被保证是线程安全的,这就意味着他们只能在请求处理线程的范围内被使用,这些对象不能被其它执行线程所引用,因为引用的行为是不确定的。
4、服务结束
容器没有被要求将一个加载的servlet保存多长时间,因此一个servlet实例可能只在容器中存活了几毫秒,当然也可能是其它更长的任意时间(但是肯定会短于容器的生存期)当容器决定将之移除时(原因可能是保存内存资源或者自己被关闭),那么它必须允许servlet释放它正在使用的任何资源并保存任何永久状态(这个过程通过调用destroy方法达到)。容器在能够调用destroy方法前,它必须允许那些正在service方法中执行的线程执行完或者在服务器定义的一段时间内执行(这个时间段在容器调用destroy之前)。一旦destroy方法被调用,容器就不会再向该实例发送任何请求。如果容器需要再使用该servlet,它必须创建新的实例。destroy方法完成后,容器必须释放servlet实例以便它能够被垃圾回收。
Java中Error与Exception的区别:
Exceptions
1.可以是 可被控制(checked) 或 不可控制的(unchecked)
2.表示一个由程序员导致的错误
3.应该在应用程序级被处理
Errors
1.总是 不可控制的(unchecked)
2.经常用来用于表示系统错误或低层资源的错误
3.如何可能的话,应该在系统级被捕捉
error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出。不可能指望程序能处理这样的情况。
exception 表示一种设计或实现问题。也就是说,它表示如果程序运行正常,从不会发生的情
进程与线程的区别:
通俗的解释
一个系统运行着很多进程,可以比喻为一条马路上有很多马车
不同的进程可以理解为不同的马车
而同一辆马车可以有很多匹马来拉----这些马就是线程
假设道路的宽度恰好可以通过一辆马车
道路可以认为是临界资源
那么马车成为分配资源的最小单位(进程)
而同一个马车被很多匹马驱动(线程)----即最小的运行单位
每辆马车马匹数>=1
所以马匹数=1的时候进程和线程没有严格界限,只存在一个概念上的区分度
马匹数>1的时候才可以严格区分进程和线程
专业的解释
简而言之,一个程序至少有一个进程,一个进程至少有一个线程.
线程的划分尺度小于进程,使得多线程程序的并发性高。另外,进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。
线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。
从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的重要区别。
进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位.
线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源.
一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行.
Java的序列化接口的作用:
Serializable接口,是作为一个标记使用的,因为本身没有任何方法需要实现;
Java内部的序列化机制会检查此接口,如果有这个接口,则序列化它,否则不序列化。
典型的用途是在分布式Java编程里,比如通过RMI或者EJB,需要在网络上传输的对象,一定要实现此接口,否则程序会出错,因为在网络上传递对象需要先序列化它。
使用序列化的目的有一个两个:一个是为了persistent对象,如在Hibernate中要保存的对象必须是序列化的;第二个是为了跨平台传输,消除平台间的差异,如在JMS中,传送的消息对象都必须是序列化的.
Hibernate的三种状态以及表现形式:
objects在hibernate中的生命周期中存在3种状态:transient, persistent, detached。附件1描述的即是hibernate application中objects的生命周期。
通过new操作符生成的object是transient object,此时的object还没有和数据库中的任何数据关联,所以一旦没有被引用,就会被jvm垃圾收集。一旦通过Hibernate 的Persistence manager执行了save()方法或者被其他已经存在的Persistent objects引用,那么object的状态就会从transient转为persistent。
Persistent objects是包含在transactions中的,它们的状态是通过transactions来控制的, Persistent objects是和数据库中的表对应的,所以表示主键的属性不会为空,也就是说每一个persistent object都会有一个匹配的database identity,除非是通过new产生的新的transient object,此时object的database identity是空的,如果在transaction中对该object执行save()方法,那么在transaction成功结束的时候该 object会在数据库中新增一条对应的记录,其它已经存在的persistent objects会相应的更新数据库中的相应行。
当Hibernate中的Persistence Manager执行close()方法,也就是persistence Manager放弃对persistent objects的控制,那么persistent objects的状态就转为detached objects。这些detached objects可以在未来被新的persistence manager重新控制并使用。这种将object从transaction转向表现层然后又重新包含于新的Transaction的实现是 Hibernate的一个卖点。
在objects存在的三种状态中,处于persistent状态中object的比较是通过该object的database identity来确定的,所以这里需要override equals()来实现。其它状态中的objects就可以简单的通过java的equality来判断即可。
- 阿里Java面试要点_以往题目.rar (18.9 KB)
- 下载次数: 121
发表评论
-
大众点评电话面试(2015/3/13)
2015-04-02 21:57 461.负责项目的架构是怎样的2.网站搞活动的时候高并发怎么处理 ... -
2015.3.23-3.25面试题
2015-04-02 20:57 372015/3/18 1.项目有哪几 ... -
盛付通面试题(2014.3.25)
2015-03-19 09:35 56盛付通面试 2015/3/16 1. ... -
翰之友面试2015/3/13
2015-03-16 13:08 321.struct1与structs2的区别 2.什么是事 ... -
ebay电话面试 2015/3/11
2015-03-11 18:36 591.hibernate与ibatis的区别 ... -
menards
2015-03-10 18:07 26menards Menards是美国第三大家居装饰和用品 ... -
上海盛付通电子支付面试题(电话)2015/3/4
2015-03-04 23:28 761.object的方法有哪几个 clone,wai ... -
bluem内部面试题(2014.1.12)
2015-01-12 18:25 581.jquery插件没有用过,jquery取兄弟节点($( ... -
bluem内部面试题(2014.12.8)
2014-12-08 15:28 891.主要用jquery,js做了什么,什么功能,用了jqu ... -
englis interview
2014-04-23 13:35 8601.introdue myselfok, it's a ... -
邦购面试题(2014.4.22)
2014-04-22 17:10 2671.多线程银行转账怎么控制,有几个线程同时从账户扣钱(钱不 ... -
塔塔电话摩根面试题(2014.4.21)
2014-04-21 17:30 334塔塔摩根面试题1.what ... -
一网打尽JAVA英文面试题目(转)
2014-04-21 14:09 2756http://blog.csdn.net/aw_vip ... -
百度支付面试(转)
2014-04-20 23:22 281一面 1.简单的自我介绍 2.java方面:集合方面: ... -
车享网面试题(2014.4.16)
2014-04-16 22:54 4961.java内存泄露怎么监 ... -
迅付信息科技有限公司(2014.4.16)
2014-04-16 22:48 8401.常用的设计模式有哪些,画出某个设计模式的UML图 h ... -
阿里巴巴电话面试(2014.4.16)
2014-04-16 21:48 4111.spring ioc 怎么理解? Aop是由动态代理实 ... -
北塔软件面试题(2014.4.14)
2014-04-14 22:22 9221.有一个文件tool.txt,里面有a,b,c,d,f,e ... -
拉卡拉面试题(2014.4.14)
2014-04-14 21:46 12211.jvm参数设置的作用,-server,-mnax,-m ... -
携程网电话面试(2014.4.11)
2014-04-12 23:57 2561.spring事物有几种隔离级别(5种),require ...
相关推荐
阿里巴巴java面试手册
阿里巴巴java面试题目,涵盖全部的Java高级技术,数据库技术和分布式相关技术。
java面试前必看
图文并茂吃透面试题,看完这个,吊打面试官,拿高薪offer!
Java全能学习面试手册——阿里开发手册全套.zip 01 阿里巴巴Java开发手册1.0.0(公开版).pdf 02 阿里巴巴Java开发手册1.1.0(正式版).pdf 03 阿里巴巴Java开发手册1.2.0(升级版).pdf 04 阿里巴巴Java开发手册...
这份《阿里Java面试集锦》中所提到的议题,几乎覆盖了Java开发的核心知识点。 首先,红黑树是一种自平衡的二叉查找树,它在Java集合框架中扮演重要角色,如TreeSet和TreeMap内部实现就用到了红黑树。红黑树的特性...
Java面试资料(阿里内部资料).pdf
首先,我们可以从阿里面试Java1到Java5的文档中,期待找到关于Java核心技术的深度解析。这些文档可能涵盖了以下几个方面: 1. **基础语法**:包括变量、数据类型、运算符、流程控制语句(如if、switch、for、while...
这份"java面试(包含阿里面试题).rar"压缩包文件提供了全面的准备材料,帮助求职者为Java工程师的职位做好充分准备。 1. **最新葵花宝典.Java软件工程师笔试面试必备.doc**:这份文档可能涵盖了Java基础知识,包括...
阿里Java面试问题大全,主要包含该:java基础、数据库、jvm等
Java面试题大全,尤其是阿里面试题,是求职者准备Java开发者职位面试的重要参考资料。这份资料集涵盖了广泛的Java编程、设计模式、数据结构、算法、框架、数据库、并发等多个领域的知识点,旨在帮助求职者全面理解...
阿里Java面试题集锦主要涵盖了Java编程语言的基础与高级特性,以及在阿里巴巴这样的大型企业中常见的面试知识点。以下是对这些面试题的详细解读: 一、红黑树的特性: 红黑树是一种自平衡的二叉查找树,其特性包括...
阿里大佬总结的Java面试资料阿里大佬总结的Java面试资料阿里大佬总结的Java面试资料阿里大佬总结的Java面试资料阿里大佬总结的Java面试资料阿里大佬总结的Java面试资料阿里大佬总结的Java面试资料阿里大佬总结的Java...
JavaOOP面试题 Java集合/泛型面试题 Java异常面试题 Java中的IO与NIO面试题 Java反射面试题 Java序列化面试题 Java注解面试题 多线程&并发面试题 JVM面试题 Mysql面试题 Redis面试题 Memcached面试题 MongoDB面试题 ...
【Java核心知识面试】-阿里Java面试集锦.pdf 这份资料是针对Java开发人员,特别是对准备参加阿里巴巴集团面试的求职者所设计的面试指南。它涵盖了Java编程语言的各个方面,旨在帮助求职者全面理解并掌握Java的核心...
java 阿里淘系面试
包括各大厂最新面试题以及面经,还有涉及JVM,Mysql,并发,Spring,Mybatis,Redis,MQ,Zookeeper,Netty,Dubbo,Spring Boot,Spring Cloud,数据结构与算法,设计模式,网络与操作系统等相关技术领域的大厂面试...
在准备阿里面试时,Java开发者需要对各个技术领域有深入的理解。以下是对提供的压缩包文件所涉及知识点的详细解读: 1. **Spring框架**: - Spring是Java企业级应用中的基石,包括依赖注入(DI)、面向切面编程(AOP)...
阿里云Java笔试面试题是Java开发者在应聘阿里云相关职位时可能会遇到的考察内容,涵盖了Java编程基础、数据结构与算法、并发编程、框架技术、数据库、云计算等多个方面。以下是对这些知识点的详细阐述: 1. **Java...
Java编程语言在阿里巴巴这样的大型企业中占据核心地位,面试中常常会涉及到许多核心概念和技术细节。以下是一些基于题目给出的面试题所涵盖的关键知识点: 一、关于String、StringBuffer和StringBuilder的区别: - ...