您的位置:首页 > 职场人生

java面试问题收集(2)

2017-08-13 18:10 363 查看
1 Integer int相等问题
Integer对象和int比较的时候会有一个拆箱的过程,始终相等
Integer和new Integer对象不会相等,引用不同
两个Integer对象比较,Integer ii=3,等同于Integer ii=Integer.valueof(3);当值在-128-127之间从cache中取回引用,其他的new,所以在区间内的对象相等,值相等
Integer.equals是比较intvalue()
String.equals也是比较内容是否相同

StringBuffer类中没有重新定义equals这个方法,因此这个方法就来自Object类,而Object类中的equals方法是用来比较“地址”的

2 HashMap工作原理
http://www.importnew.com/7099.html
http://blog.csdn.net/hpc19950723/article/details/64920214?locationNum=8&fps=1
负载因子 0.75,自动resize参考
选择常量作为键值,这也是选择String的原因
数据存放在Entry[]自定义数组里,Entry实现了链表功能,也就是bucket(key,value,next(key,value))

3 Vector 和ArrayList
http://blog.csdn.net/qq924862077/article/details/48039567
vector线程安全的,其他都和ArrayList一样

4 Java集合迭代器之fail-fast机制
http://blog.csdn.net/u014558484/article/details/52221458
http://www.cnblogs.com/shamo89/p/6685216.html
http://blog.csdn.net/tkd03072010/article/details/6759234
ArrayList和CopyOnWriteArrayList
HashMap和ConcurrentHashMap
itorator遍历增删改 ,前者都是fail-fast,有增减元素时候触发,因为后者 Iterator重新实现了,不会checkForComodification

5 ThreadLocal
http://blog.csdn.net/lufeng20/article/details/24314381
线程隔离的秘密,就在于ThreadLocalMap这个类。ThreadLocalMap是ThreadLocal类的一个静态内部类, 每个线程中都有一个独立的ThreadLocalMap副本,它所存储的值,只能被当前线程读取和修改

6 handlermapping放的什么
http://www.cnblogs.com/dragonfei/p/6148625.html

7事务嵌套

8 mybatis原理
http://blog.csdn.net/luanlouis/article/details/37671851
连接池
当我们需要创建SqlSession对象并需要执行SQL语句时,这时候MyBatis才会去调用dataSource对象来创建java.sql.Connection对象
MyBatis将连接池中的PooledConnection分为两种状态: 空闲状态(idle)和活动状态(active),这两种状态的PooledConnection对象
分别被存储到PoolState容器内的idleConnectionsactiveConnections两个List集合中

PooledConenction实现了InvocationHandler接口,并且,proxyConnection对象也是根据这个它来生成的代理对象, 我们调用PooledDataSource
的getConnection()方法返回的就是这个proxyConnection对象,当我们调用此proxyConnection对象上的任何方法时,都会调用PooledConnection对象内invoke()方法

Configuration 加载
org.apache.ibatis.session.Configuration 对象作为一个所有配置信息的容器,Configuration对象的组织结构和XML配置文件的组织结构几乎完全一样
MyBatis初始化的过程,就是创建 Configuration对象的过程, mybatis的初始化就发生在 SqlSessionFactoryBuilder.builder, 方法中调用了XMLConfigBuilder的parse()方法,然后返回了Configuration对象

MyBatis的事务管理的实现机制

MyBatis的事务管理分为两种形式:
一、使用JDBC的事务管理机制:即利用java.sql.Connection对象完成对事务的提交(commit())、回滚(rollback())、关闭(close())等
二、使用MANAGED的事务管理机制:这种机制MyBatis自身不会去实现事务管理,而是让程序的容器如(JBOSS,Weblogic)来实现对事务的管理

mybatis框架分为:接口层、数据处理层(框架支撑)
接口层 MyBatis和数据库的交互有两种方式:
a.使用传统的MyBatis提供的API(SqlSession根据Statement ID, 在mybatis配置对象Configuration中获取到对应的MappedStatement对象,
然后调用mybatis执行器来执行具体的操作。
b. 使用Mapper接口,纯粹是为了满足面向接口编程的需要,原理和a一样
框架支撑 事务管理机制 连接池管理机制 缓存机制

9 多表连接的三种方式详解 HASH JOIN MERGE JOIN NESTED LOOP
http://blog.csdn.net/tianlesoftware/article/details/5826546

<context:property-placeholder location="classpath:/config/ibatis/jdbc.properties"/>

CountDownLatch用来进行多线程测试

redis过期时间设置
hash内部key设置过期时间?

Spring MVC的实例化和自动装配工作
<content:component-scan base-package="" annotation-config="true"/>
<aop:aspectj-autoproxy />
系统初始化时,component-scan 扫描(Controller、Service、Repository)后将BeanDefinition实例放入BeanFactory,
同时annotation-config的设置注册AutowiredAnnotationBeanPostProcessor(实例执行了自动装配 )到bean工厂,
Bean实例初始化是在第一次请求Bean实例的时候,spring调用BeanFactory的getBean,Spring会检查确定调用的构造器,并实例化该Bean.
实例化完成后,Spring会调用Bean工厂的populateBean方法, populateBean方法便是调用了BeanPostProcessor实例来完成属性
元素的自动装配工作,来填充bean实例的属性,也就是我们前面提到的自动装配了,Spring会检查被装配的属性是否存在自动装配的
其他属性,然后递归调用getBean方法,直到所有@Autowired的元素都被装配完成
@Autowired是根据类型进行自动装配的。如果当spring上下文中存在不止一个UserDao类型的bean时, 可以使用@Qualifier配合@Autowired来解决这些问题

@Aspect
public class aspectAnotationClass{
@PointCut("execution(* *(..)&&annotation(com...classname))")
public void gg(){}

@Before("gg()")
public void beforefun(){}
@After("gg()")
public void afterfun(){}
@Around("gg()")
public Object aroundfun(ProceedingJoinPoint pjp){}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: