欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring AOP的入門教程

 更新時(shí)間:2024年11月18日 09:54:07   作者:這個(gè)名字應(yīng)該沒(méi)人用吧  
Spring AOP是Spring框架的一個(gè)模塊,本文主要介紹了Spring AOP的入門教程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

引言

在現(xiàn)代軟件開發(fā)中,AOP(面向切面編程)已經(jīng)成為一種關(guān)鍵的編程范式,特別是在Java生態(tài)系統(tǒng)中,它提供了一種強(qiáng)大的方法來(lái)處理那些跨越多個(gè)點(diǎn)的橫切關(guān)注點(diǎn),如日志記錄、事務(wù)管理、安全性和異常處理。

第一章:Spring AOP簡(jiǎn)介

1.1 什么是Spring AOP

Spring AOP是Spring框架的一個(gè)模塊,它提供了面向切面編程的實(shí)現(xiàn)。在Spring框架中,AOP被用來(lái)增強(qiáng)應(yīng)用的特定部分,例如日志記錄、事務(wù)管理、安全性等。Spring AOP基于代理機(jī)制,允許開發(fā)者定義切面和通知(Advice),這些通知可以在不修改源代碼的情況下,為方法的執(zhí)行添加額外的行為。

Spring AOP與Spring框架的關(guān)系:

Spring AOP是Spring框架的一個(gè)補(bǔ)充,它與Spring的IoC容器緊密集成。Spring AOP利用Spring容器管理的對(duì)象生命周期,通過(guò)代理機(jī)制將切面應(yīng)用到Spring管理的bean上。Spring AOP通常用于處理那些與業(yè)務(wù)邏輯無(wú)關(guān)的橫切關(guān)注點(diǎn),如日志記錄、事務(wù)管理等,這樣可以保持業(yè)務(wù)邏輯的清晰和專注。

1.2 為什么使用Spring AOP

  • 代碼解耦:通過(guò)將橫切關(guān)注點(diǎn)(如日志記錄、安全性、事務(wù)管理)從業(yè)務(wù)邏輯中分離出來(lái),Spring AOP有助于降低模塊之間的耦合度。
  • 提高可維護(hù)性:當(dāng)橫切關(guān)注點(diǎn)被模塊化后,維護(hù)和更新這些關(guān)注點(diǎn)變得更加容易,因?yàn)樗鼈儽患泄芾怼?/li>
  • 提高代碼的重用性:通用的橫切關(guān)注點(diǎn)(如日志記錄或事務(wù)管理)可以被封裝在切面中,并在多個(gè)地方重用。
  • 減少代碼冗余:通過(guò)在切面中集中處理橫切關(guān)注點(diǎn),減少了在多個(gè)類或方法中重復(fù)相同代碼的需要。
  • 動(dòng)態(tài)行為添加:Spring AOP允許在運(yùn)行時(shí)動(dòng)態(tài)地添加額外的行為,而不需要修改現(xiàn)有的代碼。
  • 事務(wù)管理簡(jiǎn)化:Spring AOP提供了聲明式事務(wù)管理,使得事務(wù)管理變得更加簡(jiǎn)單和直觀。
  • 異常處理集中化:通過(guò)使用AOP,可以將異常處理邏輯集中到一個(gè)或幾個(gè)切面中,而不是在每個(gè)方法中單獨(dú)處理。
  • 性能監(jiān)控:使用AOP可以輕松地添加性能監(jiān)控邏輯,如方法執(zhí)行時(shí)間的記錄,而不影響業(yè)務(wù)邏輯。

第二章:Spring AOP的核心概念

2.1 切面(Aspect)

定義: 切面是Spring AOP中的核心概念之一,它將橫切關(guān)注點(diǎn)(cross-cutting concerns)封裝成可重用的模塊。橫切關(guān)注點(diǎn)是指那些在多個(gè)地方出現(xiàn),并且與業(yè)務(wù)邏輯無(wú)關(guān)的代碼,如日志記錄、事務(wù)管理、安全性控制等。

示例: 假設(shè)我們有一個(gè)日志記錄的需求,每當(dāng)用戶執(zhí)行某個(gè)操作時(shí),我們都需要記錄操作的時(shí)間和結(jié)果。這可以通過(guò)創(chuàng)建一個(gè)日志切面來(lái)實(shí)現(xiàn):

@Aspect
@Component
public class OperationLoggingAspect {
 
    // 定義切點(diǎn)
    @Pointcut("execution(* com.example.service.*.*(..))")
    public void serviceMethods() {}
 
    // 在方法執(zhí)行之前記錄開始時(shí)間
    @Before("serviceMethods()")
    public void logBefore(JoinPoint joinPoint) {
        LocalDateTime startTime = LocalDateTime.now();
        System.out.println("方法 " + joinPoint.getSignature().getName() + " 開始執(zhí)行,時(shí)間: " + startTime);
    }
 
    // 在方法執(zhí)行之后記錄結(jié)果和結(jié)束時(shí)間
    @AfterReturning(pointcut = "serviceMethods()", returning = "result")
    public void logAfterReturning(JoinPoint joinPoint, Object result) {
        LocalDateTime endTime = LocalDateTime.now();
        System.out.println("方法 " + joinPoint.getSignature().getName() + " 結(jié)束執(zhí)行,時(shí)間: " + endTime);
        System.out.println("方法 " + joinPoint.getSignature().getName() + " 返回結(jié)果: " + result);
    }
}

在這個(gè)例子中,LoggingAspect是一個(gè)切面,它定義了兩個(gè)通知(Before和AfterReturning),用于在方法執(zhí)行前后記錄日志。

2.2 連接點(diǎn)(Join Point)

解釋: 連接點(diǎn)是指在程序執(zhí)行過(guò)程中能夠插入切面的具體點(diǎn)。

作用: 連接點(diǎn)用于指定切面應(yīng)該應(yīng)用到程序的哪些部分。通過(guò)連接點(diǎn),我們可以定義通知應(yīng)該在哪些方法執(zhí)行時(shí)觸發(fā)。

2.3 通知(Advice)

不同類型的通知:

  • Before Advice:在目標(biāo)方法執(zhí)行之前執(zhí)行的通知。
  • After Returning Advice:在目標(biāo)方法成功執(zhí)行后執(zhí)行的通知。
  • After Throwing Advice:在目標(biāo)方法拋出異常后執(zhí)行的通知。
  • After Advice:無(wú)論目標(biāo)方法正常返回還是拋出異常,都會(huì)執(zhí)行的通知。
  • Around Advice:在目標(biāo)方法執(zhí)行前后都可以執(zhí)行的通知,允許開發(fā)者控制方法的執(zhí)行。

示例:

@Before("execution(* com.example.service.*.*(..))")
public void beforeAdvice(JoinPoint joinPoint) {
    System.out.println("方法開始執(zhí)行: " + joinPoint.getSignature().getName());
}
 
@AfterReturning(pointcut = "execution(* com.example.service.*.*(..))", returning = "result")
public void afterReturningAdvice(Object result) {
    System.out.println("方法返回結(jié)果: " + result);
}
 
@AfterThrowing(pointcut = "execution(* com.example.service.*.*(..))", throwing = "error")
public void afterThrowingAdvice(Throwable error) {
    System.out.println("方法拋出異常: " + error.getMessage());
}
 
@After("execution(* com.example.service.*.*(..))")
public void afterAdvice() {
    System.out.println("方法執(zhí)行完成。");
}
 
@Around("execution(* com.example.service.*.*(..))")
public Object aroundAdvice(ProceedingJoinPoint joinPoint) throws Throwable {
    long start = System.currentTimeMillis();
    Object result = joinPoint.proceed();
    long elapsedTime = System.currentTimeMillis() - start;
    System.out.println("方法執(zhí)行耗時(shí): " + elapsedTime + "ms");
    return result;
}

2.4 切點(diǎn)(Pointcut)

定義: 切點(diǎn)用于定義一組連接點(diǎn),即通知應(yīng)該應(yīng)用到哪些方法。

@Aspect
@Component
public class LoggingAspect {
 
    // 定義切點(diǎn),匹配com.example.service包下的所有類的所有方法
    @Pointcut("execution(* com.example.service.*.*(..))")
    public void serviceMethods() {}
 
    // 使用切點(diǎn)引用,簡(jiǎn)化通知定義
    @Before("serviceMethods()")
    public void logBefore(JoinPoint joinPoint) {
        System.out.println("Before method: " + joinPoint.getSignature().getName());
    }
 
    @AfterReturning(pointcut = "serviceMethods()", returning = "result")
    public void logAfterReturning(Object result) {
        System.out.println("After method returned: " + result);
    }
}

在這個(gè)例子中,serviceMethods是一個(gè)切點(diǎn),它定義了一組連接點(diǎn),即com.example.service包下的所有類的所有方法。然后,我們?cè)谕ㄖ型ㄟ^(guò)pointcut屬性引用這個(gè)切點(diǎn),使得通知應(yīng)用到這些方法上。

通過(guò)切點(diǎn),我們可以精確地控制通知應(yīng)用的位置,使得AOP的使用更加靈活和強(qiáng)大。

第三章:Spring AOP的簡(jiǎn)單應(yīng)用

3.1 配置AOP

添加依賴:首先,確保項(xiàng)目中包含了Spring AOP的依賴。如果是Maven,可以在pom.xml文件中添加以下依賴:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
    <version>3.3.4</version>
</dependency>
 
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-aop</artifactId>
    <version>3.3.4</version>
</dependency>

啟用AOP:在Spring配置文件中或者通過(guò)Java配置啟用AOP。如果使用的是Java配置,可以添加@EnableAspectJAutoProxy注解到配置類:

@Configuration
@EnableAspectJAutoProxy
public class AppConfig {
    // 其他Bean配置
}

從Spring Boot 1.3版本開始,@EnableAspectJAutoProxy注解不再是必須的,因?yàn)镾pring Boot的自動(dòng)配置機(jī)制會(huì)自動(dòng)配置AOP代理

組件掃描:默認(rèn)情況下,Spring Boot會(huì)掃描啟動(dòng)類所在包及其子包中的所有組件。這意味著,如果組件(使用@Component、@Service等注解的類)位于啟動(dòng)類的同級(jí)或子級(jí)包中,它們將被自動(dòng)掃描并注冊(cè)為Spring容器中的Bean。

如果組件不在啟動(dòng)類的包或子包中,可以使用@ComponentScan注解來(lái)指定額外的包進(jìn)行掃描。例如:

@Configuration
@ComponentScan(basePackages = "con.example")
public class AppConfig {
    // 其他Bean配置
}

3.2 創(chuàng)建切面

定義切面類:創(chuàng)建一個(gè)新的類,并使用@Aspect注解標(biāo)注它是一個(gè)切面。

@Aspect
@Component
public class LoggingAspect {
}

定義切點(diǎn):使用@Pointcut注解定義一個(gè)切點(diǎn),指定通知應(yīng)該應(yīng)用到哪些方法。

@Pointcut("execution(* com.example.service.*.*(..))")
public void serviceMethods() {
    // 這個(gè)切點(diǎn)匹配com.example.service包下的所有類的所有方法
}

定義通知:使用@Before、@After、@AfterReturning、@AfterThrowing、@Around等注解定義通知。

@Before("serviceMethods()")
public void logBefore(JoinPoint joinPoint) {
    System.out.println("方法執(zhí)行之前: " + joinPoint.getSignature().getName());
}
 
@AfterReturning(pointcut = "serviceMethods()", returning = "result")
public void logAfterReturning(Object result) {
    System.out.println("方法執(zhí)行后的返回值: " + result);
}

3.3 應(yīng)用通知

將通知應(yīng)用到切點(diǎn),可以通過(guò)在通知注解中指定切點(diǎn)表達(dá)式來(lái)實(shí)現(xiàn):

指定切點(diǎn):在通知注解中使用pointcut屬性指定切點(diǎn)。

@Before("serviceMethods()")
public void logBefore(JoinPoint joinPoint) {
    // 這個(gè)方法將在匹配serviceMethods切點(diǎn)的每個(gè)方法執(zhí)行前調(diào)用
}

使用切點(diǎn)表達(dá)式:切點(diǎn)表達(dá)式定義了一組匹配的方法,通知將應(yīng)用到這些方法上。

@Pointcut("execution(* com.example.service.*.*(..))")
public void serviceMethods() {
    // 這個(gè)切點(diǎn)表達(dá)式匹配com.example.service包下的所有類的所有方法
}

定義通知邏輯:在通知方法中定義希望在切點(diǎn)處執(zhí)行的邏輯。

@AfterThrowing(pointcut = "serviceMethods()", throwing = "error")
public void logAfterThrowing(JoinPoint joinPoint, Throwable error) {
    System.out.println("方法 " + joinPoint.getSignature().getName() + " 拋出異常: " + error.getMessage());
}

通過(guò)這種方式,Spring AOP允許將橫切關(guān)注點(diǎn)(如日志記錄)以聲明式的方式添加到應(yīng)用程序中,而不需要修改業(yè)務(wù)邏輯代碼。這不僅提高了代碼的可維護(hù)性,也使得橫切關(guān)注點(diǎn)的管理變得更加集中和一致。

第四章:Spring AOP的示例

4.1 日志記錄

通過(guò)Spring AOP記錄方法調(diào)用的日志是一個(gè)常見的應(yīng)用場(chǎng)景。以下是如何實(shí)現(xiàn)日志記錄的示例:

定義切面:創(chuàng)建一個(gè)切面類,并定義一個(gè)切點(diǎn)來(lái)匹配想要記錄日志的方法。

@Aspect
@Component
public class LoggingAspect {
 
    // 定義切點(diǎn),匹配com.example.service包下的所有類的所有方法
    @Pointcut("execution(* com.example.service.*.*(..))")
    public void serviceMethods() {
    }
 
    // 前置通知:在方法執(zhí)行前記錄日志
    @Before("serviceMethods()")
    public void logBefore(JoinPoint joinPoint) {
        // 獲取方法的執(zhí)行信息
        String methodName = joinPoint.getSignature().toShortString();
        Object[] args = joinPoint.getArgs();
        System.out.println("Entering method: " + methodName + " with arguments " + Arrays.toString(args));
    }
 
    // 后置通知:在方法成功執(zhí)行后記錄日志
    @AfterReturning(pointcut = "serviceMethods()", returning = "result")
    public void logAfterReturning(Object result) {
        System.out.println("Method returned: " + result);
    }
 
    // 異常通知:在方法拋出異常后記錄日志
    @AfterThrowing(pointcut = "serviceMethods()", throwing = "error")
    public void logAfterThrowing(Throwable error) {
        System.out.println("Method threw exception: " + error.getMessage());
    }
 
    // 最終通知:無(wú)論方法正常返回還是拋出異常,都會(huì)執(zhí)行
    @After("serviceMethods()")
    public void logAfter() {
        System.out.println("Method execution completed.");
    }
}

配置AOP:確保Spring配置能夠掃描到切面類。

@Configuration
@EnableAspectJAutoProxy
@ComponentScan(basePackages = "com.example")
public class AppConfig {
    // 其他Bean配置
}

4.2 性能監(jiān)控

使用Spring AOP進(jìn)行性能監(jiān)控,可以幫助測(cè)量方法的執(zhí)行時(shí)間,這對(duì)于識(shí)別性能瓶頸非常有用。以下是如何實(shí)現(xiàn)性能監(jiān)控的示例:

定義切面:創(chuàng)建一個(gè)切面類,并定義一個(gè)切點(diǎn)來(lái)匹配想要監(jiān)控性能的方法。

@Aspect
@Component
public class PerformanceAspect {
 
    // 定義切點(diǎn),匹配com.example.service包下的所有類的所有方法
    @Pointcut("execution(* com.example.service.*.*(..))")
    public void serviceMethods() {
    }
 
    // 環(huán)繞通知:在方法執(zhí)行前后記錄時(shí)間
    @Around("serviceMethods()")
    public Object logPerformance(ProceedingJoinPoint joinPoint) throws Throwable {
        long startTime = System.currentTimeMillis();
        Object result = joinPoint.proceed(); // 執(zhí)行方法
        long timeTaken = System.currentTimeMillis() - startTime;
        System.out.println("Execution time of " + joinPoint.getSignature().toShortString() + " is " + timeTaken + "ms");
        return result;
    }
}

配置AOP:確保Spring配置能夠掃描到切面類。

@Configuration
@EnableAspectJAutoProxy
@ComponentScan(basePackages = "com.example")
public class AppConfig {
    // 其他Bean配置
}

通過(guò)這兩個(gè)示例,可以看到Spring AOP如何幫助輕松地實(shí)現(xiàn)日志記錄和性能監(jiān)控,而不需要在業(yè)務(wù)邏輯代碼中添加額外的邏輯。這不僅提高了代碼的可維護(hù)性,也使得橫切關(guān)注點(diǎn)的管理變得更加集中和一致。

第五章:Spring AOP的優(yōu)缺點(diǎn)

5.1 優(yōu)點(diǎn)

Spring AOP提供了許多優(yōu)點(diǎn),使其成為現(xiàn)代Java開發(fā)中一個(gè)非常有價(jià)值的工具:

  • 代碼模塊化:通過(guò)將橫切關(guān)注點(diǎn)(如日志記錄、安全性和事務(wù)管理)從業(yè)務(wù)邏輯中分離出來(lái),Spring AOP有助于實(shí)現(xiàn)代碼的模塊化。
  • 提高可維護(hù)性:當(dāng)橫切關(guān)注點(diǎn)被模塊化后,維護(hù)和更新這些關(guān)注點(diǎn)變得更加容易,因?yàn)樗鼈儽患泄芾怼?/li>
  • 增強(qiáng)可測(cè)試性:由于業(yè)務(wù)邏輯和橫切關(guān)注點(diǎn)的分離,編寫單元測(cè)試變得更加簡(jiǎn)單,因?yàn)榭梢詥为?dú)測(cè)試業(yè)務(wù)邏輯。
  • 提高代碼的重用性:通用的橫切關(guān)注點(diǎn)(如日志記錄或事務(wù)管理)可以被封裝在切面中,并在多個(gè)地方重用。
  • 減少代碼冗余:通過(guò)在切面中集中處理橫切關(guān)注點(diǎn),減少了在多個(gè)類或方法中重復(fù)相同代碼的需要。
  • 動(dòng)態(tài)行為添加:Spring AOP允許在運(yùn)行時(shí)動(dòng)態(tài)地添加額外的行為,而不需要修改現(xiàn)有的代碼。
  • 事務(wù)管理簡(jiǎn)化:Spring AOP提供了聲明式事務(wù)管理,使得事務(wù)管理變得更加簡(jiǎn)單和直觀。
  • 異常處理集中化:通過(guò)使用AOP,可以將異常處理邏輯集中到一個(gè)或幾個(gè)切面中,而不是在每個(gè)方法中單獨(dú)處理。
  • 性能監(jiān)控:使用AOP可以輕松地添加性能監(jiān)控邏輯,如方法執(zhí)行時(shí)間的記錄,而不影響業(yè)務(wù)邏輯。
  • 安全性控制:AOP可以用于實(shí)現(xiàn)方法級(jí)別的安全性控制,確保只有授權(quán)用戶才能訪問(wèn)特定的方法。

5.2 缺點(diǎn)

盡管Spring AOP提供了許多優(yōu)點(diǎn),但它也有一些潛在的缺點(diǎn):

  • 復(fù)雜性:對(duì)于初學(xué)者來(lái)說(shuō),AOP的概念可能難以理解,特別是對(duì)于那些習(xí)慣于傳統(tǒng)的OOP編程模式的開發(fā)者。
  • 性能影響:雖然通常影響不大,但AOP可能會(huì)對(duì)應(yīng)用程序的性能產(chǎn)生輕微影響,因?yàn)樾枰~外的代理和織入過(guò)程。
  • 調(diào)試?yán)щy:由于AOP將代碼邏輯分散到不同的切面中,調(diào)試可能會(huì)變得更加困難,特別是在跟蹤方法調(diào)用和執(zhí)行流程時(shí)。
  • 類型兼容性問(wèn)題:在使用動(dòng)態(tài)代理時(shí),可能會(huì)遇到類型兼容性問(wèn)題,因?yàn)榇韺?duì)象可能不匹配目標(biāo)接口。
  • 過(guò)度使用的風(fēng)險(xiǎn):AOP提供了強(qiáng)大的能力,但過(guò)度使用可能導(dǎo)致項(xiàng)目結(jié)構(gòu)變得復(fù)雜和難以管理。
  • 織入時(shí)點(diǎn):在某些情況下,織入的時(shí)點(diǎn)(編譯時(shí)、類加載時(shí)或運(yùn)行時(shí))可能需要仔細(xì)考慮,以確保切面正確應(yīng)用。

結(jié)論

Spring AOP作為一種編程范式,為Java開發(fā)者提供了一種優(yōu)雅的方法來(lái)處理那些在多個(gè)地方重復(fù)出現(xiàn)的橫切關(guān)注點(diǎn)。通過(guò)將這些關(guān)注點(diǎn)從核心業(yè)務(wù)邏輯中分離出來(lái),Spring AOP不僅提高了代碼的可維護(hù)性和可讀性,還增強(qiáng)了代碼的模塊化和重用性。

到此這篇關(guān)于Spring AOP的入門教程的文章就介紹到這了,更多相關(guān)Spring AOP入門內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot2.6.x默認(rèn)禁用循環(huán)依賴后的問(wèn)題解決

    SpringBoot2.6.x默認(rèn)禁用循環(huán)依賴后的問(wèn)題解決

    由于SpringBoot從底層逐漸引導(dǎo)開發(fā)者書寫規(guī)范的代碼,同時(shí)也是個(gè)憂傷的消息,循環(huán)依賴的應(yīng)用場(chǎng)景實(shí)在是太廣泛了,所以SpringBoot 2.6.x不推薦使用循環(huán)依賴,本文給大家說(shuō)下SpringBoot2.6.x默認(rèn)禁用循環(huán)依賴后的應(yīng)對(duì)策略,感興趣的朋友一起看看吧
    2022-02-02
  • Java?Web防止同一用戶同時(shí)登錄幾種常見的實(shí)現(xiàn)方式

    Java?Web防止同一用戶同時(shí)登錄幾種常見的實(shí)現(xiàn)方式

    在JavaWeb開發(fā)中,實(shí)現(xiàn)同一賬號(hào)同一時(shí)間只能在一個(gè)地點(diǎn)登錄的功能,主要目的是為了增強(qiáng)系統(tǒng)的安全性,防止用戶賬戶被他人惡意登錄或同時(shí)在多個(gè)設(shè)備上使用,這篇文章主要給大家介紹了關(guān)于Java?Web防止同一用戶同時(shí)登錄幾種常見的實(shí)現(xiàn)方式,需要的朋友可以參考下
    2024-08-08
  • RabbitMQ進(jìn)階之消息可靠性詳解

    RabbitMQ進(jìn)階之消息可靠性詳解

    這篇文章主要介紹了RabbitMQ進(jìn)階之消息可靠性詳解,abbitmq消息的投遞過(guò)程中,怎么確保消息能不丟失,這是一個(gè)很重要的問(wèn)題,哪怕我們做了Rabbitmq持久化,也不能保證我們的業(yè)務(wù)消息不會(huì)被丟失,需要的朋友可以參考下
    2023-08-08
  • SpringMVC轉(zhuǎn)發(fā)與重定向參數(shù)傳遞的實(shí)現(xiàn)詳解

    SpringMVC轉(zhuǎn)發(fā)與重定向參數(shù)傳遞的實(shí)現(xiàn)詳解

    這篇文章主要介紹了SpringMVC轉(zhuǎn)發(fā)與重定向參數(shù)傳遞,對(duì)于重定向,可以通過(guò)FlashMap或RedirectAttributes來(lái)在請(qǐng)求間傳遞數(shù)據(jù),因?yàn)橹囟ㄏ蛏婕皟蓚€(gè)獨(dú)立的HTTP請(qǐng)求,而轉(zhuǎn)發(fā)則在同一請(qǐng)求內(nèi)進(jìn)行,數(shù)據(jù)可以直接通過(guò)HttpServletRequest共享,需要的朋友可以參考下
    2022-07-07
  • IDEA如何解決代碼沒(méi)有提示問(wèn)題

    IDEA如何解決代碼沒(méi)有提示問(wèn)題

    文章介紹了如何解決IDEA中代碼提示功能缺失的問(wèn)題,首先,需要調(diào)整快捷鍵設(shè)置,將CyclicExpandWord鍵映射為Ctrl+/,其次,確保輸入框中設(shè)置為Basic,然后添加鍵盤快捷鍵Alt+/,如果問(wèn)題依然存在,可能是由于電腦省電模式導(dǎo)致的,需要取消相關(guān)設(shè)置
    2024-11-11
  • XML解析四種方式代碼示例詳解

    XML解析四種方式代碼示例詳解

    這篇文章主要介紹了XML解析四種方式代碼示例詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-12-12
  • Spring-MVC異步請(qǐng)求之Servlet異步處理

    Spring-MVC異步請(qǐng)求之Servlet異步處理

    這篇文章主要介紹了Spring-MVC異步請(qǐng)求之Servlet異步處理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • Java ArrayList.toArray(T[]) 方法的參數(shù)類型是 T 而不是 E的原因分析

    Java ArrayList.toArray(T[]) 方法的參數(shù)類型是 T 而不是 E的原因分析

    這篇文章主要介紹了Java ArrayList.toArray(T[]) 方法的參數(shù)類型是 T 而不是 E的原因分析的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • Java中的事件處理機(jī)制詳解

    Java中的事件處理機(jī)制詳解

    這篇文章主要介紹了Java中的事件處理機(jī)制詳解,Java事件處理是采取"委派事件模型",當(dāng)事件發(fā)生時(shí),產(chǎn)生事件的對(duì)象,會(huì)把此"信息"傳遞給"事件的監(jiān)聽者"處理,這里所說(shuō)的"信息"實(shí)際上就是java.awt.event事件類庫(kù)里某個(gè)類創(chuàng)建對(duì)象,需要的朋友可以參考下
    2023-09-09
  • SpringBoot接口數(shù)據(jù)加解密實(shí)戰(zhàn)記錄

    SpringBoot接口數(shù)據(jù)加解密實(shí)戰(zhàn)記錄

    現(xiàn)今對(duì)于大多數(shù)公司來(lái)說(shuō),信息安全工作尤為重要,下面這篇文章主要給大家介紹了關(guān)于SpringBoot接口數(shù)據(jù)加解密的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07

最新評(píng)論