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渲染显示页面;
分享文章:多年开发经验总结的Java面试题——(七)
本文地址:http://gzruizhi.cn/article/cgeiip.html