多年开发经验总结的Java面试题——(七)

  • 来源:网络
  • 更新日期:2020-08-21

摘要:1、Hibernate悲观锁和乐观锁 (更多面试题推荐:java面试题及答案)Hibernate悲观锁:在数据有加载的时候就给其进行加锁,直到该锁被释放掉,其他用户才可以进行修改,优点:数据的一致性保

1、Hibernate悲观锁和乐观锁

(更多面试题推荐:java面试题及答案)

Hibernate悲观锁:在数据有加载的时候就给其进行加锁,直到该锁被释放掉,其他用户才可以进行修改,优点:数据的一致性保持得很好,缺点:不适合多个用户并发访问。当一个锁住的资源不被释放掉的时候,这个资源永远不会被其他用户进行修改,容易造成无限期的等待。

Hibernate乐观锁:就是在对数据进行修改的时候,对数据才去版本或者时间戳等方式来比较,数据是否一致性来实现加锁。优点比较好。

2、Hibernate三种状态

临时状态:new的对象还未持久化,还没处于Session中

持久状态:已经持久化,加入到session缓存冲,处于此状态的对象叫持久对象;

游离状态:持久化对象脱离了Session的对象。如Session缓存被清空的对象。特点:已经持久化,但不在Session缓存中。处于此状态的对象叫游离对象;

(相关教程推荐:java入门教程)

3、hibernate和ibatis的区别

ibatis:开源项目上手简单,开发灵活,开发工作量大,大多自己写sql,很多配置文件

Hibernate:开源的对象关系映射框架,开发效率高,但不能干扰sql,做优化程度较低

4、讲讲mybatis连接池

常见的mybatis连接池有原生、c3p0、dbcp三类,通过工厂模式创建DataSource接口,它的实现有unpooledDataSource(不带连接池的数据源),PooledDataSource(带连接池的数据源),它们都可以通过对应的工厂类对象获取;

拿PooledDataSource来说的话首先:需要一个连接数据库的对象,在执行SQL语句的时候获取java.sql.Connection连接对象

其次:PooledDataSource数据源将Connection连接池对象包裹成PooledConnection对象放到了PoolState类型的容器中维护。 MyBatis将连接池中的连接池dui分为两种状态: 空闲状态(idle)和活动状态(active),PooledConnection对象分别被存储到PoolState容器内的idleConnections和activeConnections两个List集合中:

空闲(idle)状态就把PooledConnection对象被放置到idleConnections集合中,表示当前闲置的没有被使用的PooledConnection集合,调用PooledDataSource的getConnection()方法时,会优先从此集合中取PooledConnection对象。当用完一个java.sql.Connection对象时,MyBatis会将其包裹成PooledConnection对象放到此集合中。

活动(active)状态下把PooledConnection对象被放置到名为activeConnections的ArrayList中,表示当前正在被使用的PooledConnection集合,调用PooledDataSource的getConnection()方法时,会优先从idleConnections集合中取PooledConnection对象,如果没有,则看此集合是否已满,如果未满,PooledDataSource会创建出一个PooledConnection,添加到此集合中,并返回;

(视频教程推荐:java课程)

5、SpringMVC的工作原理

用户发送请求,被前端控制器DispatcherServlet捕获拦截;

DispatcherServlet调用HandlerMapping处理器映射管理对象获得Handler处理器;

DispatcherServlet根据Handler去获取适合的适配器HandlerAdpter,HttpMessageConveter将请求信息转换成指定的响应对象;

有了适配器,把请求参数填充到Handler,spring就开始执行Handler(Controller)进行数据转换、数据验证、数据格式化操作

Handler执行完之后,向DispatcherServlet返回一个ModelAndView对象;

根据返回的ModelAndView选择一个合适的ViewResolver视图解析器,找到ModelAndView指定的视图;

ViewResolver结合Model、View渲染显示页面;