北京百度Java岗面试真题(附答案)
岗位:Java高级
面试时间:10月10日
薪资:30*14
1.BeanFactory和ApplicationContext有什么区别
- >BeanFactory可以理解为含有bean集合的工厂类。.BeanFactory包含了种bean的定义,以便在接收到客户端请求时将对应的bean实例化。
- >BeanFactory还能在实例化对象的时生成协作类之间的关系。此举将bean自身与bean客户端的配置中解放出来。.BeanFactory还包含了bean生命周期的控制,调用客户端的初始化方法(initialization methods)和销毁方法(destruction methods)。
- >从表面上看,application context如同bean factory一样具有bean定义、bean关联关系的设置,根据请求分发bean的功能。但application在此基础上还提供了其他的功能。
- >提供了支持国际化的文本消息
- >统一的资源文件读取方式
- >已在监听器中注册的bean的事件
2.Spring Bean的生命周期
- >Spring Bean 的生命周期简单易懂。在一个bean实例被初始化时,需要执行一系列的初始化操作以达到可用的状态。同样的,当一个bean不在被调用时需要进行相关的析构操作,并从bean容器中移除。
- >Spring bean factory负责管理在spring容器中被创建的bean的生命周期。bean的生命周期由两组回调(call back)方法组成。
- >初始化之后调用的回调方法。
- >销毁之前调用的回调方法。
- >Spring框架提供了以下四种方式来管理 bean 的生命周期事件;
- >InitializingBean 和 DisposableBean 回调接口
- >针对特殊行为的其他Aware接口
- >Bean配置文件中的Custom init()方法和destroy()方法
- >@PostConstruct和@PreDestroy注解方式
3.Spring IOC如何实现
- >Spring中的org.springframework.beans 包和 org.springframework.context 包构成了Spring框架IOC容器的基础。
- >BeanFactory 接口提供了一个先进的配置机制,使得任何类型的对象的配置成为可能。ApplicationContex接口对BeanFactory(是一个子接口)进行了扩展,在BeanFactory的基础上添加了其他功能,比如与Spring的AOP更容易集成,也提供了处理message resource的机制(用于国际化)、事件传播以及应用层的特别配置,比如针对Web应用的WebApplicationContext。
- >org.springframework.beans.factory.BeanFactory是 Spring IOC容器的具体实现,用来包装和管理前面提到的各种 bean。.BeanFactory接口是Spring IOC容器的核心接口。
4.说说Spring AOP
- >面向切面编程,在我们的应用中,经常需要做一些事情,但是这些事情与核心业务无光,比如:要记录所有update*方法的执行事件,操作人等等信息,记录到日志。
- >通过spring的AOP技术,就可以在不修改 update*的代码情况下完成该需求。
5.Sspring AOP 实现原理
>Spring AOP中的动态代理主要有两种方式,JDK动态代理和CGLIB动态代理。JDK动态代理通过反射来接受被代理的类,并且要求被代理的类必须实现一个接口。JDK动态代理的核心是InvocationHandler接口和Proxy类。
>如果目标类没有实现接口,那么 Spring AOP 会选择使用 CGLIB 来动态处理目标类。CGLIB(Code Generation Library)是一个代码生成的类库,可以在运行时动态的生成某个类的子类,注意,CGLIB 是通过继承的方式做的动态代理,因此如果某个类被标记为final,那么它是无法使用CGLIB做动态代理的。
6.动态代理(cglib与JDK)
>JDK动态代理类和委托类需要都实现同一个接口。也就是说只有实现了某个接口的类可以使用Java动态代理机制。但是,事实上使用中并不是遇到的所有类都会给你实现一个接口。因此,对于没有实现接口的类,就不能使用该机制。而CGLIB则可以实现对类的动态代理。
7.Spring 事务实现方式
>编码方式:所谓编码式事务指的是通过编码方式实现实物,即类似于JDBC的编程实现事务管理。
>声明式事务管理方式:声明式事务管理又有两种实现方式:基于xml配置文件的方式;另一个是在业务方法上进行@Transaction注解,将事务规则应用到业务逻辑中。
7.Spring 事务底层原理
>a.划分处理单元——IOC 由于Spring解决的问题是对单个数据库进行局部事务处理的,具体的实现首先用Spring中的IOC划分了事务处理单元。并且将对事务的各种配置放到了IOC容器中(设置事务管理器,设置事务的传播特性及隔离机制)
>b.AOP拦截需要进行事务处理的类 Spring事务处理模块是荣国AOP功能来实现声明式事务处理的,具体操作(比如事务实行的配置和读取,事务对象的抽象)用TransactionProxyFactoryBean接口来使用AOP功能,生成proxy代理对象,通过TransactionInterceptor 完成对代理方法的拦截,将事务处理的功能编辑到拦截的方法中。读取ioc容器事务配置属性,转化为Spring事务处理需要的内部数据结构(TransationAttributeSoureAdvisor)转化为TransactionAttribute表示的数据对象
>c.对事务处理实现(事务的生成、提交、回滚、挂起): Spring委托给具体的事务处理器实现。实现了一个抽象和适配。适配的具体事务处理器:DataSource数据源支持、hibernate数据源事务处理支持、JDO数据源事务处理支持,JPA、JTA数据源事务处理支持。这些支持都是通过设计PlatformTransactionManager、AbstractPlatforTransaction一系列事务处理的支持。为常用数据源支持提供了一系列的TransactionManager。
>d.结合 PlatformTransactionManager 实现了 TransactionInterception 接口,让其与TransactionProxyFactoryBean结合起来,形成一个Spring声明式事务处理的设计体系。
8.如何自动义注解实现功能
>创建自动义注解和创建一个接口相似,但是注解的interface关键字需要以@符号开头;
>注解方法不能带有参数;
>注解方法返回值类型限定为:基本类型、String、Enums、Annotation或者是这些类型的数据;
>注解方法可以有默认值;
>注解本身能够包含元注解,元注解被用来注解其它注解;
9.Spring MVC运行流畅
>a.Spring MVC将所有的请求都提交给DispatcherServlet,它会委托应用系统的其他模块负责对请求进行真正的处理工作;
>b.DispatcherServlet查询一个或多个HandlerMapping,找到处理请求的Controller;
>c.DispatcherServle请求提交到目标Controller;
>d.Controller进行业务逻辑处理后,会返回一个ModelAndView;
>e.Dispathcher查询一个或多个ViewResoLver视图解析器,找到ModelAndView对象指定的视图对象;
>f.视图对象负责渲染返回给客户端;
10.Spring MVC 启动流程
>在web.xml文件中给 Spring MVC的 Servlet配置了 Ioad-on-startup,所以程序启动的时候会初始化Spring MVC,在HttpServletBean 中配置的 contextConfigLocation 属性设置到Servlet中,然后在 FrameworkServlet 中创建了 WebApplicationContext,DispatcherServlet 根据 contextConfigLocation配置的classpath下的xml文件初始化了 Spring MVC总的组件
11.Spring 的单例实现原理
>Spring对Bean 实例的创建是采用单例注册表的方式进行实现的,而这个注册表的缓存是ConcurrentHashMap对象。
12.Spring 框架中用到了哪些设计模式
>代理模式—在AOP和 remoting 中被用的比较多;
>单例模式—在Spring配置文件中定义的 bean 默认为单例模式;
>模板方法—用来解决代码重复的问题。比如:RestTemplate,JmsTemplate,JpaTemplate;
>前端控制器—Spring提供了 DispatcherServlet 来对请求进行分发;
>视图帮助(View Helper)—Spring 提供了一系列的JSP标签,高效回来辅助将分散的代码整合在视图里;
>工厂模式—BeanFactory 用来创建对象的实例;
13.为什么选择Netty
>a.API使用简单,开发门槛低;
>b.功能强大,预置了多种编解码功能,支持多种主流协议;
>c.定制能力强,可以通过ChannelHandler 对通信框架进行灵活的扩展;
>d.性能高,通过与其它业界主流的NIO框架对比,Netty的综合性能最优;
>e.成熟、稳定,Netty修复了已经发现的所有JDK NIO BUG,业务开发人员不需要再为NIO的BUG而烦恼;
>f.社区活跃,版本迭代周期段,发现的BUG可以被及时修复,同事,更多的新功能会被加入;
>g.经历了大规模的商业应用考验,质量已经得到验证。在互联网、大数据、网络游戏、企业应用、电信软件等众多行业得到成功商用,证明了它可以完全满足不同行业的商业应用;
正是因为这些优点,Netty逐渐成为Java NIO编程的首选框架
想拿高薪但是不知道如何下手。遇到瓶颈不知道怎么突破的。感觉自己的技术很迷茫不知道该怎么走的。我给你们推荐一个学习的地方,下面是一些视频资料:
有需要的朋友私信我哦已打包好