标签:des style class code java tar
This is a summary of some of the most important questions concerning the Spring Framework, that you may be asked to answer in an interview or in an interview test procedure! There is no need to worry for your next interview test, because Java Code Geeks are here for you!
The majority of the things you may be asked is collected in the list below. All core modules, from basic Spring functionality such as Spring Beans, up to Spring MVC framework are presented and described in short. After checking the interview questions, you should check our Spring Tutorials page.
So, let’s go…!
Spring is an open source development framework for Enterprise Java. The core features of the Spring Framework can be used in developing any Java application, but there are extensions for building web applications on top of the Java EE platform. Spring framework targets to make Java EE development easier to use and promote good programming practice by enabling a POJO-based programming model.
The basic modules of the Spring framework are :
This is the basic Spring module, which provides the fundamental functionality 
of the Spring framework. BeanFactory is the heart of any 
spring-based application. Spring framework was built on the top of this module, 
which makes the Spring container.
A BeanFactory is an implementation of the factory 
pattern that applies Inversion of Control to separate the application’s 
configuration and dependencies from the actual application code.
The most commonly used BeanFactory implementation is 
the XmlBeanFactory class.
The most useful one 
is org.springframework.beans.factory.xml.XmlBeanFactory, which 
loads its beans based on the definitions contained in an XML file. This 
container reads the configuration metadata from an XML file and uses it to 
create a fully configured system or application.
The AOP module is used for developing aspects for our Spring-enabled application. Much of the support has been provided by the AOP Alliance in order to ensure the interoperability between Spring and other AOP frameworks. This module also introduces metadata programming to Spring.
With the JDBC abstraction and DAO module we can be sure that we keep up the database code clean and simple, and prevent problems that result from a failure to close database resources. It provides a layer of meaningful exceptions on top of the error messages given by several database servers. It also makes use of Spring’s AOP module to provide transaction management services for objects in a Spring application.
Spring also supports for using of an object/relational mapping (ORM) tool over straight JDBC by providing the ORM module. Spring provides support to tie into several popular ORM frameworks, including Hibernate, JDO, and iBATIS SQL Maps. Spring’s transaction management supports each of these ORM frameworks as well as JDBC.
The Spring web module is built on the application context module, providing a context that is appropriate for web-based applications. This module also contains support for several web-oriented tasks such as transparently handling multipart requests for file uploads and programmatic binding of request parameters to your business objects. It also contains integration support with Jakarta Struts.
MVC framework is provided by Spring for building web applications. Spring can easily be integrated with other MVC frameworks, butSpring’s MVC framework is a better choice, since it uses IoC to provide for a clean separation of controller logic from business objects. With Spring MVC you can declaratively bind request parameters to your business objects.
Spring configuration file is an XML file. This file contains the classes information and describes how these classes are configured and introduced to each other.
The Spring IoC is responsible for creating the objects,managing them (with dependency injection (DI)), wiring them together, configuring them, as also managing their complete lifecycle.
IOC or dependency injection minimizes the amount of code in an application. It makes easy to test applications, since no singletons or JNDI lookup mechanisms are required in unit tests. Loose coupling is promoted with minimal effort and least intrusive mechanism. IOC containers support eager instantiation and lazy loading of services.
The FileSystemXmlApplicationContext container 
loads the definitions of the beans from an XML file. The full path of the XML 
bean configuration file must be provided to the 
constructor.
The ClassPathXmlApplicationContext container 
also loads the definitions of the beans from an XML file. Here, you need to 
setCLASSPATH properly because this container will look bean 
configuration XML file 
in CLASSPATH.
The WebXmlApplicationContext: container 
loads the XML file with definitions of all beans from within a web 
application.
Application contexts provide a means for resolving text messages, a generic 
way to load file resources (such as images), they can publish events to beans 
that are registered as listeners. In addition, operations on the container or 
beans in the container, which have to be handled in a programmatic fashion with 
a bean factory, can be handled declaratively in an application context. The 
application context implements MessageSource, an interface 
used to obtain localized messages, with the actual implementation being 
pluggable.
Dependency Injection, an aspect of Inversion of Control (IoC), is a general concept, and it can be expressed in many different ways.This concept says that you do not create your objects but describe how they should be created. You don’t directly connect your components and services together in code but describe which services are needed by which components in a configuration file. A container (the IOC container) is then responsible for hooking it all up.
You can use both Constructor-based and Setter-based Dependency Injection. The best solution is using constructor arguments for mandatory dependencies and setters for optional dependencies.
The Spring 
Beans are Java Objects that form the backbone of a Spring application. 
They are instantiated, assembled, and managed by the Spring IoC container. These 
beans are created with the configuration metadata that is supplied to the 
container, for example, in the form of 
XML <bean/> definitions.
Beans defined in spring framework are singleton beans. There is an attribute 
in bean tag named "singleton" if specified true then bean 
becomes singleton and if set to false then the bean becomes a prototype bean. By 
default it is set to true. So, all the beans in spring framework are by 
default singleton beans.
A Spring Bean definition contains all configuration metadata which is needed for the container to know how to create a bean, its lifecycle details and its dependencies.
There are three important methods to provide configuration metadata to the Spring Container:
When defining a <bean> in Spring, we can also 
declare a scope for the bean. It can be defined through 
the scope attribute in the bean definition. For example, 
when Spring has to produce a new bean instance each time one is needed, the 
bean’s scope attribute to beprototype. On 
the other hand, when the same instance of a bean must be returned by Spring 
every time it is needed, the the beanscope attribute must be 
set to singleton.
There are five scoped provided by the Spring Framework supports following five scopes:
The default scope of a Spring Bean is Singleton.
No, singleton beans are not thread-safe in Spring framework.
BeanNameAware interface, 
  spring passes the bean’s id 
  to setBeanName() method.BeanFactoryAware interface, 
  spring passes 
  the beanfactory to setBeanFactory() method.BeanPostProcessors associated 
  with the bean, Spring 
  calls postProcesserBeforeInitialization()method.IntializingBean, 
  its afterPropertySet() method is called. If the bean 
  has init method declaration, the specified initialization method is 
  called.DisposableBean, it will call 
  the destroy() method.There are two important bean lifecycle methods. The first one 
is setup which is called when the bean is loaded in to 
the container. The second method is the teardown method 
which is called when the bean is unloaded from the 
container.
The bean tag has two important attributes 
(init-method and destroy-method) with which 
you can define your own custom initialization and destroy methods. There are 
also the correspondive 
annotations(@PostConstruct and @PreDestroy).
When a bean is only used as a property of another bean it can be declared as 
an inner bean. Spring’s XML-based configuration metadata provides the use 
of <bean/> element inside 
the <property/> or <constructor-arg/> elements 
of a bean definition, in order to define the so-called inner bean. Inner beans 
are always anonymous and they are always scoped as prototypes.
Spring offers the following types of collection configuration elements:
<list> type is used for injecting a list 
  of values, in the case that duplicates are allowed.<set> type is used for wiring a set of 
  values but without any duplicates.<map> type is used to inject a collection 
  of name-value pairs where name and value can be of any type.<props> type can be used to inject a 
  collection of name-value pairs where the name and value are both 
Strings.Wiring, or else bean wiring is the case when beans are combined together within the Spring container. When wiring beans, the Spring container needs to know what beans are needed and how the container should use dependency injection to tie them together.
The Spring container is able to autowire 
relationships between collaborating beans. This means that it is 
possible to automatically let Spring resolve collaborators (other beans) for a 
bean by inspecting the contents of 
the BeanFactory without 
using <constructor-arg> and <property> elements.
The autowiring functionality has five modes which can be used to instruct Spring container to use autowiring for dependency injection:
byName, 
  the Spring container looks at the properties of the beans on 
  which autowire attribute is set 
  tobyName in the XML configuration file. It then tries to 
  match and wire its properties with the beans defined by the same names in the 
  configuration file.datatype, the Spring container looks at the properties of 
  the beans on which autowire attribute is set 
  to byType in the XML configuration file. It then tries 
  to match and wire a property if its type matches with exactly one of the beans 
  name in configuration file. If more than one such beans exist, a fatal 
  exception is thrown.byType, but type applies to constructor arguments. If 
  there is not exactly one bean of the constructor argument type in the 
  container, a fatal error is raised.byType.Limitations of autowiring are:
<constructor-arg> and <property> settings 
  which will always override autowiring.Yes, you can.
Java 
based configuration option enables you to write most of your Spring 
configuration without XML but with the help of few Java-based annotations.
An 
example is the @Configuration annotation, that indicates 
that the class can be used by the Spring IoC container as a source of bean 
definitions. Another example is the@Bean annotated method that 
will return an object that should be registered as a bean in the Spring 
application context.
An alternative to XML setups is provided by annotation-based configuration which relies on the bytecode metadata for wiring up components instead of angle-bracket declarations. Instead of using XML to describe a bean wiring, the developer moves the configuration into the component class itself by using annotations on the relevant class, method, or field declaration.
Annotation wiring is not turned on in the Spring container by default. In order to use annotation based wiring we must enable it in our Spring configuration file by configuring <context:annotation-config/< element.
This annotation simply indicates that the affected bean property must be 
populated at configuration time, through an explicit property value in a bean 
definition or through autowiring. The container 
throws BeanInitializationException if the affected bean 
property has not been populated.
The @Autowired annotation provides more fine-grained 
control over where and how autowiring should be accomplished. It can be used to 
autowire bean on the setter method just 
like @Required annotation, on the constructor, on a 
property or pn methods with arbitrary names and/or multiple arguments.
When there are more than one beans of the same type and only one is needed to 
be wired with a property, the @Qualifier annotation is 
used along with @Autowired annotation to remove the 
confusion by specifying which exact bean will be wired.
When using the Spring JDBC framework the burden of resource management and 
error handling is reduced. So developers only need to write the statements and 
queries to get the data to and from the database. JDBC can be used more 
efficiently with the help of a template class provided by Spring framework, 
which is the JdbcTemplate (example here).
JdbcTemplate class provides many convenience methods for 
doing things such as converting database data into primitives or objects, 
executing prepared and callable statements, and providing custom database error 
handling.
The Data Access Object (DAO) support in Spring is aimed at making it easy to work with data access technologies like JDBC, Hibernate or JDO in a consistent way. This allows us to switch between the persistence technologies fairly easily and to code without worrying about catching exceptions that are specific to each technology.
There are two ways to access Hibernate with Spring:
HibernateDAOSupport and Applying an AOP 
  Interceptor node.Spring supports the following ORM’s:
Use 
Spring’s SessionFactory called LocalSessionFactory. 
The integration process is of 3 steps:
HibernateDaoSupportSpring supports two types of transaction management:
Most users of the Spring Framework choose declarative transaction management because it is the option with the least impact on application code, and hence is most consistent with the ideals of a non-invasive lightweight container. Declarative transaction management is preferable over programmatic transaction management though it is less flexible than programmatic transaction management, which allows you to control transactions through your code.
Aspect-oriented programming, or AOP, is a programming technique that allows programmers to modularize crosscutting concerns, or behavior that cuts across the typical divisions of responsibility, such as logging and transaction management.
The core construct of AOP is the aspect, which encapsulates behaviors 
affecting multiple classes into reusable modules. It ia a module which has a set 
of APIs providing cross-cutting requirements. For example, a logging module 
would be called AOP aspect for logging. An application can have any number of 
aspects depending on the requirement. In Spring AOP, aspects are implemented 
using regular classes annotated with 
the @Aspect annotation 
(@AspectJ style).
The Concern is behavior we want to have in a module of an application. A 
Concern may be defined as a functionality we want to implement.
The 
cross-cutting concern is a concern which is applicable throughout the 
application and it affects the entire application. For example, logging, security and 
data transfer are the concerns which are needed in almost every module of an 
application, hence they are cross-cutting concerns.
The join point represents a point in an application where we can plug-in an AOP aspect. It is the actual place in the application where an action will be taken using Spring AOP framework.
The advice is the actual action that will be taken either before or after the method execution. This is actual piece of code that is invoked during the program execution by the Spring AOP framework.
Spring aspects can work with five kinds of advice:
The pointcut is a set of one or more joinpoints where an advice should be executed. You can specify pointcuts using expressions or patterns.
An Introduction allows us to add new methods or attributes to existing classes.
The target object is an object being advised by one or more aspects. It will always be a proxy object. It is also referred to as the advised object.
A proxy is an object that is created after applying advice to a target object. When you think of client objects the target object and the proxy object are the same.
Weaving is the process of linking aspects with other application types or 
objects to create an advised object.
Weaving can be done at compile time, at 
load time, or at runtime.
In this implementation case, aspects are implemented using regular classes along with XML based configuration.
This implementation case (@AspectJ based implementation) 
refers to a style of declaring aspects as regular Java classes annotated with 
Java 5 annotations.
Spring comes with a full-featured MVC framework for building web applications. Although Spring can easily be integrated with other MVC frameworks, such as Struts, Spring’s MVC framework uses IoC to provide a clean separation of controller logic from business objects. It also allows to declaratively bind request parameters to business objects.
The Spring Web MVC framework is designed around 
a DispatcherServlet that handles all the HTTP requests 
and responses.
The WebApplicationContext is an extension of the 
plain ApplicationContext that has some extra features 
necessary for web applications. It differs from a 
normal ApplicationContext in that it is capable of 
resolving themes, and that it knows which servlet it is associated with.
Controllers provide access to the application behavior that you typically define through a service interface. Controllers interpret user input and transform it into a model that is represented to the user by the view. Spring implements a controller in a very abstract way, which enables you to create a wide variety of controllers.
The @Controller annotation indicates that a particular 
class serves the role of a controller. Spring does not require you to extend any 
controller base class or reference the Servlet API.
@RequestMapping annotation is used to map a URL to either 
an entire class or a particular handler method.
Ok, so now you are ready for your interview! Don’t forget to check our dedicated page full of Spring Tutorials!
If you enjoyed this, then subscribe to our newsletter to enjoy weekly updates and complimentary whitepapers! Also, check out JCG Academy for more advanced training!
You are welcome to contribute with your comments and we will include them in the article!
reference from:http://www.javacodegeeks.com/2014/05/spring-interview-questions-and-answers.html
69 Spring Interview Questions and Answers – The ULTIMATE List--reference,布布扣,bubuko.com
69 Spring Interview Questions and Answers – The ULTIMATE List--reference
标签:des style class code java tar
原文地址:http://www.cnblogs.com/davidwang456/p/3712189.html