初级程序员面试题总结(一):

本人将这几天面试的题目总结一些,如果出现错误请指正,谢谢。1,谈一谈spring。答:spring是为java程序开发提供的综合性的基础java开发平台,它提供了从表现层SpringMVC到业务层Spring再到持久层springData的一套完整的解决方案。spring的核心有两大块,第一块是AOP,面向切面编程,它将程序与业务分离,集中来解决一些公共问题。第二块是IOC,控制反转,由容…

大家好,又见面了,我是你们的朋友全栈君。

本人将这几天面试的题目总结一些,如果出现错误请指正,谢谢。
1,谈一谈spring。
答:spring是为java程序开发提供的综合性的基础java开发平台,它提供了从表现层SpringMVC到业务层Spring再到持久层springData的一套完整的解决方案。spring的核心有两大块,第一块是AOP,面向切面编程,它将程序与业务分离,集中来解决一些公共问题。第二块是IOC,控制反转,由容器来帮助对象寻找依赖并实现注入。
spring实现了低耦合,它可以与很多主流框架进行集成,如mybbatis,struts等。
2,谈一谈spring IOC/DI。
答:IOC,就是将对象的创建权,交给IOC容器来进行管理,IOC帮助对象寻找对象依赖并注入,而不是由对象主动去找。
IOC容器就像一个婚介所一样,我们先在婚介所登记我们需要怎么样的女朋友,然后婚介所会根据条件来为你提供一个女朋友,你需要做的就是和女朋友谈恋爱就可以。
3,依赖注入的几种方式?你一般选择用哪种注入?
答:三种方式。setter方法注入、构造器注入、接口注入。
一般使用注解注入方式
4,spring 是如何管理bean的?
spring是通过容器来对bean进行管理。通常我们理解的容器有BeanFactory和ApplicationContext.BeanFactory使用了工厂模式,负责读取bean的配置文档,负责bean的加载,实例化,维护bean之间的依赖关系,负责bean的生命周期。ApplicationContext具有beanfactory的所有功能,同时还提供国际化支持,事件管理,AOP等,因此一般使用ApplicationContext。
spring管理bean的生命周期,先是实例化一个bean,然后使用IOC/DI将需要的对象进行依赖注入,然后进过一系列的调用与使用,最后如果bean不再被使用或者容器销毁则会调用destroy方法进行销毁,生命周期结束。
5,spring的常用注解:
答:@controller,@service,@Repository,@ComPonent
6,springMVC和struts的区别:
答:
(1) springmvc的入口是个DispatcherServlet,前端控制器;struts的入口是一个监听器
(2)springmvc是基于方法的实现,传入方法的形参,可以设计为单例模式或者多例模式。struts是基于类的实现,参数为方法的属性。
(3)struts更符合OOP编程思想,springmvc更谨慎,在servlet上扩展。
(4)springmvc可以和spring可以认为是零配置,管理方面和安全方面较struts高。
7,为什么在项目中使用springmvc而不使用struts2?
答:首先,springMVC是基于方法开发的,struts是基于类开发的;
其次,springMVC可以进行单例开发,struts只能进行多例开发;
最后,springMVC的速度比struts快。
8,说一下Mybatis和Hibernate的区别?
答:1,mybatis是轻量级的半自动化框架;hibernate是轻量级的全自动框架;
2,使用hibernate开发时开发量要小一点,不用写sql语句,全自动生成;mybatis相对工作量要大,需要写大量的sql语句;
3,mybatis对于sql优化方面要比hibernate好,heibernate会查询出所有的字段,性能会有一点损耗;mybatis可以根据需求自己定制sql语句,实现sql优化。
4,hibernate数据库移植性很强,而mybatis对数据库的依赖性比较强,更换数据库一般需要修改sql语句。
9,sql优化。
答:1,对查询进行优化,避免权标扫描;
2,避免在where子句中对字段进行null判断;
3,避免在where子句中使用<>、!=等操作符;
4,少用in、not in;
5,避免使用like;
6,避免在where子句中进行表达式操作;
7,不要使用太多的索引;
8,不要使用select *,应尽力查询需要的字段。
10,mysql创建自增长列关键词:auto_increment
11,mysql查询前10条数据:select * from employee limit 0,10;
12,oracle三层分页关键词:rownum
13,将一张表数据复制到另一张表:create table sss as (select * from aaa)
14,hashmap和hashtable的区别:
答:hashmap与hasptable都完成了map接口。最主要的区别是hashtable是线程安全的,hashtable不是线程安全的,在多个线程访问hashtable时,不需要为它的方法实现同步,访问hashmap的时候需要实现同步。
hashmap允许空的键值对,hashtable不允许,因此效率上hashmap要高于hashtable。
15,hashmap的底层实现原理:
答:HashMap底层就是一个数组结构,数组中的每一项又是一个链表。当新建一个HashMap的时候,就会初始化一个数组。(具体自查)
16,ArrayList和LinkedListd的区别:
答:ArrayList是基于数组的,linkedList是基于链表的;
arrayList查询速度快,添加速度慢;linkedlist添加速度快,查询速度慢;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/126914.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python中用来抛出异常的关键字是( )_python异常抛出

    python中用来抛出异常的关键字是( )_python异常抛出广告关闭腾讯云11.11云上盛惠,精选热门产品助力上云,云服务器首年88元起,买的越多返的越多,最高返5000元!主动抛出异常raisetypeerror(类型错误)#7.触发异常try:raisetypeerror(类型错误)exceptexceptionase:print(e)#8.自定义异常classmy…syntaxerror语法错误python代码非…

    2022年10月17日
    0
  • SQL的多表查询

    SQL的多表查询

    2021年7月20日
    49
  • [Unity3D]Unity3D游戏开发之ACT游戏三连击效果实现综述

    [Unity3D]Unity3D游戏开发之ACT游戏三连击效果实现综述

    2021年12月14日
    62
  • nrm使用报错_重大错报

    nrm使用报错_重大错报nrm使用错误:ERR_INVALID_ARG_TYPE

    2022年10月28日
    0
  • 超详细的MySQL三万字总结[通俗易懂]

    超详细的MySQL三万字总结[通俗易懂]文章目录MySQL基础数据库的介绍数据库概述数据的存储方式数据库的概念常见数据库排行榜数据库的安装与卸载数据库的安装数据库的卸载数据库服务的启动与登录Windows服务方式启动DOS命令方式启动控制台连接数据库SQLyog图形化工具——客户端使用SQLyog登录数据库数据库管理系统数据库管理系统、数据库和表的关系SQL的概念什么是SQLSQL作用SQL语句分类MySQL的语法DDL操作数据库创建数据库创建数据库的几种方式查看数据库修改数据库删除数据库使用数据库DDL操作表结构创建表M

    2022年5月13日
    38
  • 软件定义网络(SDN)基础概念学习笔记(下)

    软件定义网络(SDN)基础概念学习笔记(下)第四章1.南向接口协议设计目标/主要任务承上启下,分离控制平面与数据平面实现网络配置与管理实现路径计算,包括网络开销、链路状态等已实现的南向接口协议Openflow:Openflow交换机与控制器的信息交互OF-Config:Openflow交换机的配置和管理NETCONF:网络设备的配置与管理OVSDB:OpenvSwitch的配置与管理XMPP:用于即时通讯(O…

    2022年9月4日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号