Основные вопросы на собеседовании по Spring Framework

Эта статья является частью серии: • Вопросы для собеседования по коллекциям Java

• Вопросы для собеседования по системе типов Java

• Вопросы на собеседовании по параллелизму Java (+ ответы)

• Вопросы для собеседования по структуре классов Java и инициализации

• Вопросы для собеседования по Java 8 (+ ответы)

• Управление памятью в Java Вопросы на собеседовании (+ ответы)

• Вопросы для собеседования по Java Generics (+ ответы)

• Вопросы на собеседовании по Java Flow Control (+ ответы)

• Вопросы на собеседовании по исключениям Java (+ ответы)

• Вопросы для собеседования по Java Annotations (+ ответы)

• Основные вопросы на собеседовании по Spring Framework (текущая статья)

Содержание

  • 1. Введение
  • 2. Spring Core
  • Q1. Что такое Spring Framework?
  • Q2. Каковы преимущества использования Spring?
  • Q3. Какие весенние подпроекты вы знаете? Кратко опишите их.
  • Q4. Что такое внедрение зависимостей?
  • Q5. Как можно вводить фасоль весной?
  • Q6. Какой способ инъекции фасоли лучше всего и почему
  • Q7. В чем разница между Beanfactory и Applicationcontext?
  • Q8. Что такое Spring Bean?
  • Q9. Какова область действия компонента по умолчанию в Spring Framework?
  • Q10. Как определить объем фасоли?
  • Q11. Являются ли одинарные бобы потокобезопасными?
  • Q12. Как выглядит жизненный цикл Spring Bean?
  • Q13. Что такое конфигурация Spring на основе Java?
  • В14. Можно ли иметь несколько файлов конфигурации Spring в одном проекте?
  • Q15. Что такое Spring Security?
  • Q16. Что такое Spring Boot?
  • В17. Назовите некоторые из шаблонов дизайна, используемых в Spring Framework?
  • В18. Как работает прототип осциллографа?
  • 3. Spring Web MVC
  • В19. Как получить объекты Servletcontext и Servletconfig в Spring Bean?
  • Q20. Что такое контроллер в Spring Mvc?
  • В21. Как работает аннотация @Requestmapping?
  • 4. Доступ к данным Spring
  • В22. Что такое класс Spring Jdbctemplate и как его использовать?
  • В23. Как бы вы разрешили транзакции весной и каковы их преимущества?
  • В24. Что такое Spring Dao?
  • 5. Spring аспектно-ориентированное программирование (AOP)
  • В25. Что такое аспектно-ориентированное программирование?
  • В26. Что такое Aspect, Advice, Pointcut и Joinpoint в Aop?
  • В27. Что такое ткачество?
  • 6. Весна 5
  • В28. Что такое реактивное программирование?
  • В29. Что такое Spring Webflux?
  • Q30. Что такое типы Mono и Flux?
  • В31. Какая польза от Webclient и Webtestclient?
  • В32. Каковы недостатки использования реактивных потоков?
  • В33. Совместима ли Spring 5 со старыми версиями Java?
  • В34. Как Ow Spring 5 интегрируется с модульностью Jdk 9?
  • В35. Можем ли мы использовать и Web Mvc, и Webflux в одном приложении?
  • 7. Заключение

1. Введение

В этой статье мы рассмотрим некоторые из наиболее распространенных вопросов, связанных с Spring, которые могут возникнуть во время собеседования.

2. Spring Core

Q1. Что такое Spring Framework?

Spring - это наиболее широко используемая среда для разработки приложений Java Enterprise Edition. Основные функции Spring можно использовать при разработке любого приложения Java.

Мы можем использовать его расширения для создания различных веб-приложений поверх платформы Jakarta EE, или мы можем просто использовать его положения внедрения зависимостей в простых автономных приложениях.

Q2. Каковы преимущества использования Spring?

Spring стремится упростить разработку Jakarta EE. Вот преимущества его использования:

  • Легковесность: использование фреймворка в разработке требует незначительных затрат.
  • Инверсия управления (IoC): контейнер Spring заботится о связях зависимостей различных объектов вместо создания или поиска зависимых объектов.
  • Аспектно-ориентированное программирование (АОП): Spring поддерживает АОП для отделения бизнес-логики от системных служб.
  • Контейнер IoC: он управляет жизненным циклом Spring Bean и конфигурациями проекта.
  • Платформа MVC: используется для создания веб-приложений или веб-служб RESTful, способных возвращать ответы XML / JSON.
  • Управление транзакциями: уменьшает количество стандартного кода в операциях JDBC, загрузке файлов и т. Д. С помощью аннотаций Java или XML-файла конфигурации Spring Bean.
  • Exception Handling: Spring provides a convenient API for translating technology-specific exceptions into unchecked exceptions

Q3. What Spring Sub-Projects Do You Know? Describe Them Briefly.

  • Core – a key module that provides fundamental parts of the framework, like IoC or DI
  • JDBC – this module enables a JDBC-abstraction layer that removes the need to do JDBC coding for specific vendor databases
  • ORM integration – provides integration layers for popular object-relational mapping APIs, such as JPA, JDO, and Hibernate
  • Web – a web-oriented integration module, providing multipart file upload, Servlet listeners, and web-oriented application context functionalities
  • MVC framework – a web module implementing the Model View Controller design pattern
  • AOP module – aspect-oriented programming implementation allowing the definition of clean method-interceptors and pointcuts

Q4. What Is Dependency Injection?

Dependency Injection, an aspect of Inversion of Control (IoC), is a general concept stating that you do not create your objects manually but instead describe how they should be created. An IoC container will instantiate required classes if needed.

For more details, please refer here.

Q5. How Can We Inject Beans in Spring?

A few different options exist:

  • Setter Injection
  • Constructor Injection
  • Field Injection

The configuration can be done using XML files or annotations.

For more details, check this article.

Q6. Which Is the Best Way of Injecting Beans and Why?

The recommended approach is to use constructor arguments for mandatory dependencies and setters for optional ones. Constructor injection allows injecting values to immutable fields and makes testing easier.

Q7. What Is the Difference Between Beanfactory and Applicationcontext?

BeanFactory is an interface representing a container that provides and manages bean instances. The default implementation instantiates beans lazily when getBean() is called.

ApplicationContext is an interface representing a container holding all information, metadata, and beans in the application. It also extends the BeanFactory interface but the default implementation instantiates beans eagerly when the application starts. This behavior can be overridden for individual beans.

For all differences, please refer to the reference.

Q8. What Is a Spring Bean?

The Spring Beans are Java Objects that are initialized by the Spring IoC container.

Q9. What Is the Default Bean Scope in Spring Framework?

By default, a Spring Bean is initialized as a singleton.

Q10. How to Define the Scope of a Bean?

To set Spring Bean's scope, we can use @Scope annotation or “scope” attribute in XML configuration files. There are five supported scopes:

  • singleton
  • prototype
  • request
  • session
  • global-session

For differences, please refer here.

Q11. Are Singleton Beans Thread-Safe?

No, singleton beans are not thread-safe, as thread safety is about execution, whereas the singleton is a design pattern focusing on creation. Thread safety depends only on the bean implementation itself.

Q12. What Does the Spring Bean Lifecycle Look Like?

First, a Spring bean needs to be instantiated, based on Java or XML bean definition. It may also be required to perform some initialization to get it into a usable state. After that, when the bean is no longer required, it will be removed from the IoC container.

The whole cycle with all initialization methods is shown on the image (source):

Q13. What Is the Spring Java-Based Configuration?

It's one of the ways of configuring Spring-based applications in a type-safe manner. It's an alternative to the XML-based configuration.

Also, if you want to migrate your project from XML to Java config, please refer to this article.

Q14. Can We Have Multiple Spring Configuration Files in One Project?

Yes, in large projects, having multiple Spring configurations is recommended to increase maintainability and modularity.

You can load multiple Java-based configuration files:

@Configuration @Import({MainConfig.class, SchedulerConfig.class}) public class AppConfig {

Or load one XML file that will contain all other configs:

ApplicationContext context = new ClassPathXmlApplicationContext("spring-all.xml");

And inside this XML file you'll have:

Q15. What Is Spring Security?

Spring Security is a separate module of the Spring framework that focuses on providing authentication and authorization methods in Java applications. It also takes care of most of the common security vulnerabilities such as CSRF attacks.

To use Spring Security in web applications, you can get started with a simple annotation: @EnableWebSecurity.

You can find the whole series of articles related to security on Baeldung.

Q16. What Is Spring Boot?

Spring Boot is a project that provides a pre-configured set of frameworks to reduce boilerplate configuration so that you can have a Spring application up and running with the smallest amount of code.

Q17. Name Some of the Design Patterns Used in the Spring Framework?

  • Singleton Pattern: Singleton-scoped beans
  • Factory Pattern: Bean Factory classes
  • Prototype Pattern: Prototype-scoped beans
  • Adapter Pattern: Spring Web and Spring MVC
  • Proxy Pattern: Spring Aspect Oriented Programming support
  • Template Method Pattern:JdbcTemplate, HibernateTemplate, etc.
  • Front Controller: Spring MVC DispatcherServlet
  • Data Access Object: Spring DAO support
  • Model View Controller: Spring MVC

Q18. How Does the Scope Prototype Work?

Scope prototype means that every time you call for an instance of the Bean, Spring will create a new instance and return it. This differs from the default singleton scope, where a single object instance is instantiated once per Spring IoC container.

3. Spring Web MVC

Q19. How to Get ServletContext and ServletConfig Objects in a Spring Bean?

You can do either by:

  1. Implementing Spring-aware interfaces. The complete list is available here.
  2. Using @Autowired annotation on those beans:
@Autowired ServletContext servletContext; @Autowired ServletConfig servletConfig;

Q20. What Is a Controller in Spring Mvc?

Simply put, all the requests processed by the DispatcherServlet are directed to classes annotated with @Controller. Each controller class maps one or more requests to methods that process and execute the requests with provided inputs.

If you need to take a step back, we recommend having a look at the concept of the Front Controller in the typical Spring MVC architecture.

Q21. How Does the @Requestmapping Annotation Work?

The @RequestMapping annotation is used to map web requests to Spring Controller methods. In addition to simple use cases, we can use it for mapping of HTTP headers, binding parts of the URI with @PathVariable, and working with URI parameters and the @RequestParam annotation.

More details on @RequestMapping are available here.

For more Spring MVC questions, please check out Spring MVC Interview Questions article.

4. Spring Data Access

Q22. What Is Spring Jdbctemplate Class and How to Use It?

The Spring JDBC template is the primary API through which we can access database operations logic that we’re interested in:

  • creation and closing of connections
  • executing statements and stored procedure calls
  • iterating over the ResultSet and returning results

To use it, we'll need to define the simple configuration of DataSource:

@Configuration @ComponentScan("org.baeldung.jdbc") public class SpringJdbcConfig { @Bean public DataSource mysqlDataSource() { DriverManagerDataSource dataSource = new DriverManagerDataSource(); dataSource.setDriverClassName("com.mysql.jdbc.Driver"); dataSource.setUrl("jdbc:mysql://localhost:3306/springjdbc"); dataSource.setUsername("guest_user"); dataSource.setPassword("guest_password"); return dataSource; } }

For further explanation, you can go through this quick article.

Q23. How Would You Enable Transactions in Spring and What Are Their Benefits?

There are two distinct ways to configure Transactions – with annotations or by using Aspect Oriented Programming (AOP) – each with their advantages.

The benefits of using Spring Transactions, according to the official docs, are:

  • Provide a consistent programming model across different transaction APIs such as JTA, JDBC, Hibernate, JPA, and JDO
  • Support declarative transaction management
  • Provide a simpler API for programmatic transaction management than some complex transaction APIs such as JTA
  • Integrate very well with Spring's various data access abstractions

Q24. What Is Spring Dao?

Spring Data Access Object is Spring's support provided to work with data access technologies like JDBC, Hibernate, and JPA in a consistent and easy way.

You can, of course, go more in-depth on persistence, with the entire series discussing persistence in Spring.

5. Spring Aspect-Oriented Programming (AOP)

Q25. What Is Aspect-Oriented Programming?

Aspects enable the modularization of cross-cutting concerns such as transaction management that span multiple types and objects by adding extra behavior to already existing code without modifying affected classes.

Here is the example of aspect-based execution time logging.

Q26. What Are Aspect, Advice, Pointcut, and Joinpoint in Aop?

  • Aspect: a class that implements cross-cutting concerns, such as transaction management
  • Advice: the methods that get executed when a specific JoinPoint with matching Pointcut is reached in the application
  • Pointcut: a set of regular expressions that are matched with JoinPoint to determine whether Advice needs to be executed or not
  • JoinPoint: a point during the execution of a program, such as the execution of a method or the handling of an exception

Q27. What Is Weaving?

According to the official docs, weaving is a process that links aspects with other application types or objects to create an advised object. This can be done at compile time, load time, or at runtime. Spring AOP, like other pure Java AOP frameworks, performs weaving at runtime.

6. Spring 5

Q28. What Is Reactive Programming?

Reactive programming is about non-blocking, event-driven applications that scale with a small number of threads, with back pressure being a key ingredient that aims to ensure producers don't overwhelm consumers.

The primary benefits of reactive programming are:

  • increased utilization of computing resources on multicore and multi-CPU hardware
  • and increased performance by reducing serialization

Reactive programming is generally event-driven, in contrast to reactive systems, which are message-driven. Thus, using reactive programming does not mean we're building a reactive system, which is an architectural style.

However, reactive programming may be used as a means to implement reactive systems if we follow the Reactive Manifesto, which is quite vital to understand.

Based on this, reactive systems have four important characteristics:

  • Responsive: the system should respond in a timely manner
  • Resilient: in case the system faces any failure, it should stay responsive
  • Elastic: reactive systems can react to changes and stay responsive under varying workload
  • Message-driven: reactive systems need to establish a boundary between components by relying on asynchronous message passing

Q29. What Is Spring Webflux?

Spring WebFlux is Spring's reactive-stack web framework, and it's an alternative to Spring MVC.

In order to achieve this reactive model and be highly scalable, the entire stack is non-blocking. Check out our tutorial on Spring 5 WebFlux for additional details.

Q30. What Are the Mono and Flux Types?

The WebFlux framework in Spring Framework 5 uses Reactor as its async foundation.

This project provides two core types: Mono to represent a single async value, and Flux to represent a stream of async values. They both implement the Publisher interface defined in the Reactive Streams specification.

Mono implements Publisher and returns 0 or 1 elements:

public abstract class Mono implements Publisher {...}

Also, Flux implements Publisher and returns N elements:

public abstract class Flux implements Publisher {...}

By definition, the two types represent streams, hence they're both lazy, which means nothing is executed until we consume the stream using the subscribe() method. Both types are immutable, therefore calling any method will return a new instance of Flux or Mono.

Q31. What Is the Use of Webclient and Webtestclient?

WebClient is a component in the new Web Reactive framework that can act as a reactive client for performing non-blocking HTTP requests. Being a reactive client, it can handle reactive streams with back pressure, and it can take full advantage of Java 8 lambdas. It can also handle both sync and async scenarios.

On the other hand, the WebTestClient is a similar class that we can use in tests. Basically, it's a thin shell around the WebClient. It can connect to any server over an HTTP connection. It can also bind directly to WebFlux applications using mock request and response objects, without the need for an HTTP server.

Q32. What Are the Disadvantages of Using Reactive Streams?

The major disadvantages of using reactive streams are:

  • Troubleshooting a Reactive application is a bit difficult; be sure to check out our tutorial on debugging reactive streams for some handy debugging tips
  • There is limited support for reactive data stores, as traditional relational data stores have yet to embrace the reactive paradigm
  • There's an extra learning curve when implementing

Q33. Is Spring 5 Compatible With Older Versions of Java?

In order to take advantage of Java 8 features, the Spring codebase has been revamped. This means older versions of Java cannot be used. Hence, the framework requires a minimum of Java 8.

Q34. How Does Spring 5 Integrate With Jdk 9 Modularity?

In Spring 5, everything has been modularized, thus we won't be forced to import jars that may not have the functionalities we're looking for.

Please have a look at our guide to Java 9 modularity for an in-depth understanding of how this technology works.

Let's see an example to understand the new module functionality in Java 9 and how to organize a Spring 5 project based on this concept.

To start, let's create a new class that contains a single method to return a String “HelloWorld”. We'll place this within a new Java project – HelloWorldModule:

package com.hello; public class HelloWorld { public String sayHello(){ return "HelloWorld"; } }

Then let's create a new module:

module com.hello { export com.hello; }

Now, let's create a new Java Project, HelloWorldClient, to consume the above module by defining a module:

module com.hello.client { requires com.hello; }

The above module will be available for testing now:

public class HelloWorldClient { public static void main(String[] args){ HelloWorld helloWorld = new HelloWorld(); log.info(helloWorld.sayHello()); } }

Q35. Can We Use Both Web Mvc and Webflux in the Same Application?

As of now, Spring Boot will only allow either Spring MVC or Spring WebFlux, as Spring Boot tries to auto-configure the context depending on the dependencies that exist in its classpath.

Кроме того, Spring MVC не может работать в Netty. Более того, MVC - это парадигма блокировки, а WebFlux - это неблокирующий стиль, поэтому мы не должны смешивать оба вместе, поскольку они служат разным целям.

7. Заключение

В этой обширной статье мы рассмотрели некоторые из наиболее важных вопросов технического интервью о Spring.

Мы надеемся, что эта статья поможет вам в предстоящем весеннем интервью. Удачи!

« Предыдущие вопросы на собеседовании по аннотациям Java (+ ответы)