Detailed explanation of SpringIOC and AOP principles
IoC (Inversion of Control)
(1) . IoC (Inversion of Control) refers to the relationship between container-controlled program objects, rather than being directly controlled by program code in traditional implementations. Control is transferred from the application code to the external container. The transfer of control is called inversion. For Spring, Spring controls the life cycle of objects and the relationship between objects; IoC has another name - "Dependency Injection". As the name suggests, the so-called dependency injection means that the dependencies between components are determined by the container during runtime, that is, the container dynamically injects certain dependencies into the components.
(2). In the way Spring works, all classes will be registered in the spring container, telling spring what it is and what you need, and then spring will run it when the system is appropriate. Offer to give you what you want, and also give you to other things that need you. The creation and destruction of all classes are controlled by spring, which means that the object's life cycle is no longer controlled by the object that references it, but by spring. For a specific object, it used to control other objects, but now all objects are controlled by spring, so this is called inversion of control.
(3). During system operation, dynamically provide an object with other objects it needs.
(4). The idea of ??dependency injection is realized through the reflection mechanism. When instantiating a class, it calls the set method in the class through reflection to inject the class attributes previously saved in the HashMap into the class. All in all, in the traditional method of object creation, the caller usually creates an instance of the callee. In Spring, the work of creating the callee is completed by Spring, and then the caller is injected, which is the so-called dependency injection or control reflection. change. There are two injection methods: dependency injection and setting injection; The advantages of IoC: reduce the coupling between components, reduce the complexity of replacement between business objects, and enable flexible management of objects.
AOP (Aspect Oriented Programming)
(1). AOP aspect-oriented programming is based on IoC and is a useful supplement to OOP;
(2 ). AOP uses a technology called "cross-cutting" to dissect the inside of the encapsulated object and encapsulate the public behaviors that affect multiple classes into a reusable module and name it "Aspect". That is, aspects. The so-called "aspect", simply put, is to encapsulate the logic or responsibilities that have nothing to do with the business but are jointly called by the business modules, such as logging, so as to reduce the duplication of code in the system, reduce the coupling between modules, and have Conducive to future operability and maintainability.
(3). AOP represents a horizontal relationship, comparing the "object" to a hollow cylinder, which encapsulates the properties and behavior of the object; the method of aspect-oriented programming is to This cylinder is cut into sections to selectively provide business logic. And the cut sections are the so-called "aspects". Then it restored these cut sections with uncanny skills, leaving no trace but completing the effect.
(4). The technology to implement AOP is mainly divided into two categories: one is to use dynamic proxy technology to decorate the message by intercepting the message to replace the execution of the original object behavior; The second is to use static weaving to introduce specific syntax to create "aspects", so that the compiler can weave code related to "aspects" during compilation.
(5). Spring implements AOP: JDK dynamic proxy and CGLIB proxy JDK dynamic proxy: its proxy object must be the implementation of a certain interface, which is completed by creating an implementation class of the interface during runtime The proxy of the target object; its two core classes are InvocationHandler and Proxy. CGLIB proxy: The implementation principle is similar to JDK dynamic proxy, except that the proxy object it generates during runtime is a subclass extended for the target class. CGLIB is an efficient code generation package. The bottom layer is implemented by relying on ASM (open source java bytecode editing class library) to operate bytecode. Its performance is better than JDK; the packages asm.jar and cglib.jar need to be introduced. Using AspectJ-injected aspects and @AspectJ annotation-driven aspects are actually implemented through dynamic proxies at the bottom level.
(6). AOP usage scenarios: ???????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????
##Context passing Content passing- Error handling Error handling
- Lazy loading Lazy loading
-
- Performance optimization ? Performance optimization , efficiency examine
Persistence
-
#Resource pooling step
#Transactions Transaction Management - In addition, the implementation of Filter and the implementation of struts2 interceptor are both manifestations of AOP ideas.
-
Recommended tutorial: "
Java Tutorial "
The above is the detailed content of Detailed explanation of Spring IoC and AOP principles. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

To correctly handle JDBC transactions, you must first turn off the automatic commit mode, then perform multiple operations, and finally commit or rollback according to the results; 1. Call conn.setAutoCommit(false) to start the transaction; 2. Execute multiple SQL operations, such as INSERT and UPDATE; 3. Call conn.commit() if all operations are successful, and call conn.rollback() if an exception occurs to ensure data consistency; at the same time, try-with-resources should be used to manage resources, properly handle exceptions and close connections to avoid connection leakage; in addition, it is recommended to use connection pools and set save points to achieve partial rollback, and keep transactions as short as possible to improve performance.

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

Use classes in the java.time package to replace the old Date and Calendar classes; 2. Get the current date and time through LocalDate, LocalDateTime and LocalTime; 3. Create a specific date and time using the of() method; 4. Use the plus/minus method to immutably increase and decrease the time; 5. Use ZonedDateTime and ZoneId to process the time zone; 6. Format and parse date strings through DateTimeFormatter; 7. Use Instant to be compatible with the old date types when necessary; date processing in modern Java should give priority to using java.timeAPI, which provides clear, immutable and linear

Pre-formanceTartuptimeMoryusage, Quarkusandmicronautleadduetocompile-Timeprocessingandgraalvsupport, Withquarkusoftenperforminglightbetterine ServerLess scenarios.2.Thyvelopecosyste,

Java's garbage collection (GC) is a mechanism that automatically manages memory, which reduces the risk of memory leakage by reclaiming unreachable objects. 1.GC judges the accessibility of the object from the root object (such as stack variables, active threads, static fields, etc.), and unreachable objects are marked as garbage. 2. Based on the mark-clearing algorithm, mark all reachable objects and clear unmarked objects. 3. Adopt a generational collection strategy: the new generation (Eden, S0, S1) frequently executes MinorGC; the elderly performs less but takes longer to perform MajorGC; Metaspace stores class metadata. 4. JVM provides a variety of GC devices: SerialGC is suitable for small applications; ParallelGC improves throughput; CMS reduces

Networkportsandfirewallsworktogethertoenablecommunicationwhileensuringsecurity.1.Networkportsarevirtualendpointsnumbered0–65535,withwell-knownportslike80(HTTP),443(HTTPS),22(SSH),and25(SMTP)identifyingspecificservices.2.PortsoperateoverTCP(reliable,c

defer is used to perform specified operations before the function returns, such as cleaning resources; parameters are evaluated immediately when defer, and the functions are executed in the order of last-in-first-out (LIFO); 1. Multiple defers are executed in reverse order of declarations; 2. Commonly used for secure cleaning such as file closing; 3. The named return value can be modified; 4. It will be executed even if panic occurs, suitable for recovery; 5. Avoid abuse of defer in loops to prevent resource leakage; correct use can improve code security and readability.

ExecutorService is suitable for asynchronous execution of independent tasks, such as I/O operations or timing tasks, using thread pool to manage concurrency, submit Runnable or Callable tasks through submit, and obtain results with Future. Pay attention to the risk of unbounded queues and explicitly close the thread pool; 2. The Fork/Join framework is designed for split-and-governance CPU-intensive tasks, based on partitioning and controversy methods and work-stealing algorithms, and realizes recursive splitting of tasks through RecursiveTask or RecursiveAction, which is scheduled and executed by ForkJoinPool. It is suitable for large array summation and sorting scenarios. The split threshold should be set reasonably to avoid overhead; 3. Selection basis: Independent
