SSM框架---Java SSM 框架常见面试题(十)

Java SSM 框架常见面试题

你的导师 架构师日刊 昨天


    阅读本文约需要5分钟 

---------------------------

1 Spring面试题

1、Spring 在ssm中起什么作用?

  • Spring:轻量级框架
  • 作用:Bean工厂,用来管理Bean的生命周期和框架集成。
  • 两大核心:1IOC/DI(控制反转/依赖注入) :把dao依赖注入到service层,service层反转给controller层,Spring顶层容器为BeanFactory2AOP:面向切面编程

2、Spring的事务?

  • 编程式事务管理:编程方式管理事务,极大灵活性,难维护。
  • 声明式事务管理:可以将业务代码和事务管理分离,用注解和xml配置来管理事务。分为三种:1、全xml2xml+注解(用的最多)3、全注解

三种实现方式均有代码:

3、IOC 在项目中的作用?

作用:Ioc解决对象之间的依赖问题,把所有Bean的依赖关系通过配置文件或注解关联起来,降低了耦合度。

4、Spring的配置文件中的内容?

  • 开启事务注解驱动
  • 事务管理器
  • 开启注解功能,并配置扫描包
  • 配置数据库
  • 配置SQL会话工厂,别名,映射文件
  • 不用编写Dao层的实现类

5、Spring下的注解?

  • 注册:@Controller @Service @Repository @Component
  • 注入:@Autowired @Resource
  • 请求地址:@RequestMapping
  • 返回具体数据类型而非跳转,Ajax@ResponseBody

6、Spring DI 的三种方式?

1) 构造器注入:通过构造方法初始化

  • <constructor-arg index="0" type ="java.lang.String" value ="宝马"></constructor-arg>

2) setter方法注入:通过setter方法初始化

  • <property name="id" value = "1111" ></property>

3) 接口注入

7、Spring主要使用了什么模式?

工厂模式:每个Bean的创建通过方法

单例模式:默认的每个Bean的作用域都是单例

代理模式:关于Aop的实现通过代理模式

8、IOC,AOP的实现原理?

IOC:通过反射机制生成对象注入

AOP:动态代理

2 SpringMVC面试题

1、SpringMvc 的控制器是不是单例模式,如果是,有什么问题,怎么解决?

默认是单例模式。问题:单例模式,在多线程访问时有线程安全问题

解决方法:不要用同步,在控制器里面不能写成员变量。

为什么设计成单例模式?

性能 (不用每次请求都创建对象)

不需要多例(不要在控制器类中定义成员变量)

2、SpringMvc 中控制器的注解?

@Controller:该注解表明该类扮演控制器的角色

3、@RequestMapping 注解用在类上的作用?

作用:用来映射一个URL到一个类或者一个特定的处理方法上

4、前台多个参数,这些参数都是一个对象,快速得到对象?

这个问题有点垃圾,没价值。

方法:直接在方法中声明这个对象,SpringMvc就自动把属性赋值到这个对象里面

5、SpringMvc中函数的返回值?

String,ModelAndView,void, List,Set 等

一般String,Ajax请求,返回一个List集合

6、SpringMvc中的转发和重定向?

转发:return "forward: hello "

重定向 return "redirect:hello"

7、SpringMvc和Ajax之间的相互调用?

通过JackSon框架把java里面对象直接转换成js可识别的json对象。具体步骤如下:

1、页面引入

1)页面引入js方法:<script type="text/javascript" src="${pageContext.request.contextPath }/js/jquery-1.4.4.min.js"></script>

2) ajax方法:$.ajax({});

2、springmvc框架的配置

1)需要添加三个jar  jackson-annotations-2.4.0.jar、jackson-core-2.4.2.jar、jackson-databind-2.4.2.jar

  1. 在springmvc.xml容器中配置注解映射的支持,支持json

3、controller的要素

1)对方法添加@ResponseBody注解

8、SpringMvc的工作流程图?

9、Struts2 和 SpringMvc的区别?

入口不同:

Struts2:filter过滤器

SpringMvc:一个Servlet即前端控制器

开发方式不同:

Struts2:基于类开发,传递参数通过类的属性,只能设置为多例

SpringMvc:基于方法开发(一个url对应一个方法),请求参数传递到方法形参,可以为单例也可以为多例(建议单例)

请求方式不同:

Struts2:值栈村塾请求和响应的数据,通过OGNL存取数据

SpringMvc:通过参数解析器将request请求内容解析,给方法形参赋值,将数据和视图封装成ModelAndView对象,最后又将ModelAndView中的模型数据通过request域传输到页面,jsp视图解析器默认使用的是jstl。

10、数据库连接池的实现?

任何连接池都要实现DataSource接口,其实都是对底层jdbc的封装。

${}  不是el表达式,而是spring内部自定义

1、Dhcp的实现:

<!-- DBCP -->

<bean id="dbcp" class="org.apache.commons.dbcp.BasicDataSource">

    <property name="driverClassName" value="${jdbc.driver}"></property>

    <property name="url" value="${jdbc.url}"></property>

    <property name="username" value="${jdbc.username}"></property>

    <property name="password" value="${jdbc.password}"></property>

</bean>

 

2、c3p0的实现:

<!-- C3P0 -->

<bean id="c3p0" class="com.mchange.v2.c3p0.ComboPooledDataSource">

    <property name="driverClass" value="${jdbc.driver}"></property>

    <property name="jdbcUrl" value="${jdbc.url}"></property>

    <property name="user" value="${jdbc.username}"></property>

    <property name="password" value="${jdbc.password}"></property>

</bean>

 

3、spring对jdbc的实现:

<!-- 数据库连接池 -->

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"

    destroy-method="close">

    <property name="driverClassName" value="${jdbc.driver}" />

    <property name="url" value="${jdbc.url}" />

    <property name="username" value="${jdbc.username}" />

    <property name="password" value="${jdbc.password}" />

    <property name="maxActive" value="10" />

    <property name="maxIdle" value="5" />

</bean>

 

 

 

3 Mybatis面试题

1、Ibatis和Mybatis?

Ibatis:2010年,apache的Ibatis框架停止更新,并移交给了google团队,同时更名为MyBatis。从2010年后Ibatis在没更新过,彻底变成了一个孤儿框架。一个没人维护的框架注定被mybatis拍在沙滩上。

Mybatis:Ibatis的升级版本。

2、什么是Mybatis的接口绑定,有什么好处?

Mybatis实现了DAO接口与xml映射文件的绑定,自动为我们生成接口的具体实现,使用起来变得更加省事和方便。

3、关于@Requestmap

4、Mybatis在核心处理类叫什么?

SqlSession

5、查询表名和返回实体Bean对象不一致,如何处理?

映射键值对即可:column:数据库中表的列名property:实体Bean中的属性名

  • <result column ="title" property= "title" javaType="java.lang.String"/>

6、Mybatis的好处?

  1. 把Sql语句从Java中独立出来。
  2. 封装了底层的JDBC,API的调用,并且能够将结果集自动转换成JavaBean对象,简化了Java数据库编程的重复工作。
  3. 自己编写Sql语句,更加的灵活。
  4. 入参无需用对象封装(或者map封装),使用@Param注解

7、Mybatis配置一对一查询?

  • <association property ="topicType" select = "selectType" column = "topics_type_id" javaType = "com.tmf.bbs.pojo.Type"/>

property:属性名select:要连接的查询column:共同列javaType:集合中元素的类型

8、Mybatis配置一对多查询?

  • <collection property = "topicComment" column = "id" ofType = "com.tmf.bbs.pojo.Comment" select ="selectComment"/>

property:属性名  column:共同列  ofType:集合中元素的类型   select:要连接的查询

9 ${} #{}的区别?

${}:简单字符串替换,把${}直接替换成变量的值,不做任何转换,这种是取值以后再去编译SQL语句。

#{}:预编译处理,sql中的#{}替换成?,补全预编译语句,有效的防止Sql语句注入,这种取值是编译好SQL语句再取值。

总结:一般用#{}来进行列的代替

#{}:占位符,如果传入的是字符串,预编译时会自动带上单引号

${}:连接符,如果传入的是基础数据类型,也就是string,long,double,int,boolean,float     大括号只能写value,即${value};

          如果传入的是pojo或者map类型,                                                                                                                  大括号只能写属性名或key名,即${username};

    能使用#{}的时候尽量使用#{},不使用${};${}用的很少,也就模糊查询

    #{}相当于jdbc中的preparedstatement(预编译),${}是直接使用里面的值进行拼接,有可能会有SQL注入问题

10、获取上一次自动生成的主键值?

  • select last_insert_id()

11、Mybatis如何分页,分页原理?

RowBounds对象分页

在Sql内直接书写,带有物理分页

12、Mybatis工作原理?

 

原理:

  1. 通过SqlSessionFactoryBuilder从mybatis-config.xml配置文件中构建出SqlSessionFactory。
  2. SqlSessionFactory开启一个SqlSession,通过SqlSession实例获得Mapper对象并且运行Mapper映射的Sql语句。
  3. 完成数据库的CRUD操作和事务提交,关闭SqlSession。

参考文献:https://blog.csdn.net/qq_39031310

 

  • 4
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值