40個常用的springBoot注解

一、Spring Web MVC注解

@RequestMapping

@RequestMapping注解的主要用途是將Web請求與請求處理類中的方法進行映射。
Spring MVC和Spring WebFlux都通過RquestMappingHandlerMappingRequestMappingHndlerAdapter兩個類來提供對@RequestMapping注解的支持。
@RequestMapping注解對請求處理類中的請求處理方法進行標注;

@RequestMapping注解擁有以下的六個配置屬性:

value: 映射的請求URL或者其別名

? 指定請求的實際地址,指定的地址可以是URI Template 模式;

method: 兼容HTTP的方法名

? 指定請求的method類型, GET、POST、PUT、DELETE等;

params: 根據HTTP參數的存在、缺省或值對請求進行過濾

? 指定request中必須包含某些參數值時,才讓該方法處理。

header: 根據HTTP Header的存在、缺省或值對請求進行過濾

? 指定request中必須包含某些指定的header值,才能讓該方法處理請求。

consume: 設定在HTTP請求正文中允許使用的媒體類型

? 指定處理請求的提交內容類型(Content-Type),例如application/json, text/html;

product: 在HTTP響應體中允許使用的媒體類型

? 指定返回的內容類型,僅當request請求頭中的(Accept)類型中包含該指定類型才返回;

提示:在使用@RequestMapping之前,請求處理類還需要使用@Controller@RestController進行標記

示例

@RestController
public class ControllerTest {@RequestMapping(value = "/demo/home", method = RequestMethod.GET)public String home() {return "home";}// controller–限制接收post 請求以及consumes="application/json"。@RequestMapping(value = "/testMethod", method = RequestMethod.POST,consumes="application/json")public String testMethod() {System.out.println("testMethod");return "SUCCESS";}// 返回值類型是json格式// text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8// 其中最后一項 : */*;q=0.8。// 該項表明可以接收任何類型的,權重系數0.8表明如果前面幾種類型不能正常接收。則使用該項進行自動分析。// application/json 幾種主流瀏覽器都可以自動解析。@RequestMapping(value = "/testMethod", method = RequestMethod.POST,produces="application/json")@ResponseBodypublic RestMessage testMethod2(Model model) throws IOException {return new RestMessage("SUCCESS");}// 設定必須包含username 和age兩個參數,且age參數不為10 (可以有多個參數)。@RequestMapping(value = "testParams", params = { "username","age!=10" })public String testParams() {System.out.println("testParamsAndHeaders");return "SUCCESS";}// 設定請求頭中第一語言必須為US。// 必須包含username 和age兩個參數,且age參數不為10 (可以有多個參數)。@RequestMapping(value = "testParamsAndHeaders", params = { "username","age!=10" }, headers = { "Accept-Language=US,zh;q=0.8" })public String testParamsAndHeaders() {System.out.println("testParamsAndHeaders");return "SUCCESS";}
}

@RequestBody

@RequestBody在處理請求方法的參數列表中使用,它可以將請求主體中的參數綁定到一個對象中,請求主體參數是通過HttpMessageConverter傳遞的,
根據請求主體中的參數名與對象的屬性名進行匹配并綁定值。
此外,還可以通過@Valid注解對請求主體中的參數進行校驗。
示例

@PostMapping("/user")
public User createUser(@Valid @RequestBody User user) {return sava(user);
}

@GetMapping

@GetMapping注解用于處理HTTP GET請求,并將請求映射到具體的處理方法中。
具體來說,@GetMapping是一個組合注解,它相當于是@RequestMapping(method=RequestMethod.GET)的快捷方式。

@PostMapping

@PostMapping注解用于處理HTTP POST請求,并將請求映射到具體的處理方法中。@PostMapping@GetMapping一樣,也是一個組合注解,它相當于是@RequestMapping(method=HttpMethod.POST)的快捷方式。

@PutMapping

@PutMapping注解用于處理HTTP PUT請求,并將請求映射到具體的處理方法中,@PutMapping是一個組合注解,相當于是@RequestMapping(method=HttpMethod.PUT)的快捷方式。

@DeleteMapping

@DeleteMapping注解用于處理HTTP DELETE請求,并將請求映射到刪除方法中。@DeleteMapping是一個組合注解,它相當于是@RequestMapping(method=HttpMethod.DELETE)的快捷方式。

@PatchMapping

@PatchMapping注解用于處理HTTP PATCH請求,并將請求映射到對應的處理方法中。@PatchMapping相當于是@RequestMapping(method=HttpMethod.PATCH)的快捷方式。

@ControllerAdvice

@ControllerAdvice@Component注解的一個延伸注解,Spring會自動掃描并檢測被@ControllerAdvice所標注的類。

@ControllerAdvice需要和@ExceptionHandler@InitBinder以及@ModelAttribute注解搭配使用,主要是用來處理控制器所拋出的異常信息。

首先,我們需要定義一個被@ControllerAdvice所標注的類,在該類中,定義一個用于處理具體異常的方法,并使用@ExceptionHandler注解進行標記。

此外,在有必要的時候,可以使用@InitBinder在類中進行全局的配置,還可以使用@ModelAttribute配置與視圖相關的參數。

使用@ControllerAdvice注解,就可以快速的創建統一的,自定義的異常處理類。

示例

@ControllerAdvice(basePackages = {"com.xie.controller"})
public class UserControllerAdvice {@InitBinderpublic void binder(WebDataBinder binder) {SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.getDefault());// String dob= "1/55/1999";// SimpleDateFormat的setLenient(true)// 這種情況下java會把你輸入的日期進行計算,比如55個月那么就是4年以后,這時候年份就會變成03年了// SimpleDateFormat的setLenient(false)// 這種情況下java不會把你輸入的日期進行計算,比如55個月那么就是不合法的日期了,直接異常dateFormat.setLenient(false);binder.registerCustomEditor(Date.class, "user", new CustomDateEditor(dateFormat, true));}@ModelAttributepublic void modelAttribute(Model model) {model.addAttribute("messgae", "User not found exception.");}@ExceptionHandler(UserNotFoundException.class)public ModelAndView userNotFoundExceptionHandler(UserNotFoundException exception) {ModelAndView modelAndView = new ModelAndView();modelAndView.addObject("exception", exception);modelAndView.setViewName("erro");return modelAndView;}
}

@ResponseBody

@ResponseBody會自動將控制器中方法的返回值寫入到HTTP響應中。

特別的,@ResponseBody注解只能用在被@Controller注解標記的類中。

如果在被@RestController標記的類中,則方法不需要使用@ResponseBody注解進行標注。

@RestController相當于是@Controller@ResponseBody的組合注解。

@RequestMapping(value = "/testMethod")
@ResponseBody
public RestMessage testMethod2(Model model) throws IOException {return new RestMessage("SUCCESS");
}

@ExceptionHandler

@ExceptionHander注解用于標注處理特定類型異常類所拋出異常的方法。

當控制器中的方法拋出異常時,Spring會自動捕獲異常,并將捕獲的異常信息傳遞給被@ExceptionHandler標注的方法。

@ExceptionHandler(UserNotFoundException.class)
public ModelAndView userNotFoundExceptionHandler(UserNotFoundException exception) {ModelAndView modelAndView = new ModelAndView();modelAndView.addObject("exception", exception);modelAndView.setViewName("erro");return modelAndView;
}

@ResponseStatus

@ResponseStatus注解可以標注請求處理方法。使用此注解,可以指定響應所需要的HTTP STATUS

特別地,我們可以使用HttpStauts類對該注解的value屬性進行賦值。

@ResponseStatus(HttpStatus.BAD_REQUEST)
@ExceptionHandler(UserNotFoundException.class)
public ModelAndView userNotFoundExceptionHandler(UserNotFoundException exception) {ModelAndView modelAndView = new ModelAndView();modelAndView.addObject("exception", exception);modelAndView.setViewName("erro");return modelAndView;
}

@PathVariable

@PathVariable注解是將方法中的參數綁定到請求URI中的模板變量上。

可以通過@RequestMapping注解來指定URI的模板變量,然后使用@PathVariable注解將方法中的參數綁定到模板變量上。

特別地,@PathVariable注解允許我們使用valuename屬性來給參數取一個別名

@GetMapping("users/{id}/roles/{roleId}")public Role getUserRole(@PathVariable(name = "id") long id, @PathVariable(name = "roleId") long roleId) {return new Role();
}

@RequestParam

@RequestParam注解用于將方法的參數與Web請求的傳遞的參數進行綁定。

使用@RequestParam可以輕松的訪問HTTP請求參數的值

@GetMapping("/role")public Role getUserRole(@RequestParam(name = "id") long id, @RequestParam(name = "roleId") long roleId) {return new Role();
}
// 特別的,如果傳遞的參數為空,還可以通過defaultValue設置一個默認值。

@Controller

@Controller@Component注解的一個延伸,Spring會自動掃描并配置被該注解標注的類。

此注解用于標注Spring MVC的控制器。

@RestController

@RestController是在Spring 4.0開始引入的,這是一個特定的控制器注解。

此注解相當于@Controller@ResponseBody的快捷方式。

當使用此注解時,不需要再在方法上使用@ResponseBody注解。

@ModelAttribute

通過此注解,可以通過模型索引名稱來訪問已經存在于控制器中的model。

@CrossOrigin

@CrossOrigin注解將為請求處理類或請求處理方法提供跨域調用支持。

如果我們將此注解標注類,那么類中的所有方法都將獲得支持跨域的能力。

使用此注解的好處是可以微調跨域行為。

@CrossOrigin
@GetMapping("/role")
public Role getUserRole(@RequestParam(name = "id") long id, @RequestParam(name = "roleId") long roleId) {return new Role();
}

@InitBinder

@InitBinder注解用于標注初始化WebDataBinider的方法,

該方法用于對Http請求傳遞的表單數據進行處理,如時間格式化、字符串處理等。

@InitBinder
public void binder(WebDataBinder binder) {SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.getDefault());// String dob= "1/55/1999";// SimpleDateFormat的setLenient(true)// 這種情況下java會把你輸入的日期進行計算,比如55個月那么就是4年以后,這時候年份就會變成03年了// SimpleDateFormat的setLenient(false)// 這種情況下java不會把你輸入的日期進行計算,比如55個月那么就是不合法的日期了,直接異常dateFormat.setLenient(false);binder.registerCustomEditor(Date.class, "user", new CustomDateEditor(dateFormat, true));
}

二、Spring Bean 注解

@ComponentScan

@ComponentScan注解用于配置Spring需要掃描的被組件注解注釋的類所在的包。

可以通過配置其basePackages屬性或者value屬性來配置需要掃描的包路徑。value屬性是basePackages的別名。

@Component

@Component注解用于標注一個普通的組件類,它沒有明確的業務范圍,只是通知Spring被此注解的類需要被納入到Spring Bean容器中并進行管理。

@Service

@Service注解是@Component的一個延伸(特例),它用于標注業務邏輯類。

@Component注解一樣,被此注解標注的類,會自動被Spring所管理。

@Repository

@Repository注解也是@Component注解的延伸,與@Component注解一樣,被此注解標注的類會被Spring自動管理起來,

@Repository注解用于標注DAO層的數據持久化類。

三、Spring Dependency Inject

@DependsOn

@DependsOn注解可以配置Spring IoC容器在初始化一個Bean之前,先初始化其他的Bean對象。

@Bean("firstBean")
@DependsOn(value = {"secondBean", "thirdBean"})
public firstBean firstBean() {return new FirstBean();
}

@Bean

@Bean注解主要的作用是告知Spring,被此注解所標注的類將需要納入到Bean管理工廠中。

@Bean注解的用法很簡單,在這里,著重介紹@Bean注解中initMethoddestroyMethod的用法。

@Component
public class DataBaseInitializer {public void init() {System.out.println("This is init method");}public void destroy() {System.out.println("This is destroy method");}
}// 引入bean
@Bean(initMethod = "init", destroyMethod = "destroy")
public DataBaseInitializer dataBaseInitializer() {return new DataBaseInitializer();
}

@Scope

@Scope注解可以用來定義@Component標注的類的作用范圍以及@Bean所標記的類的作用范圍。

@Scope所限定的作用范圍有:singleton、prototype、request、session、globalSession或者其他的自定義范圍。

這里以prototype為例子進行講解。

當一個Spring Bean被聲明為prototype(原型模式)時,在每次需要使用到該類的時候,Spring IoC容器都會初始化一個新的改類的實例。

在定義一個Bean時,可以設置Bean的scope屬性為prototype:scope=“prototype”,也可以使用@Scope注解設置,如下:

@Scope(value=ConfigurableBeanFactory.SCOPE_PROPTOTYPE)
兩種配置方式:// 第一種
@Bean
@Scope(value = ConfigurableBeanFactory.SCOPE_PROTOTYPE)
public DataBaseInitializer dataBaseInitializer() {return new DataBaseInitializer();
}// ----------------------------------------// 第二種
@Component
@Scope(value= ConfigurableBeanFactory.SCOPE_PROTOTYPE)
public class DataBaseInitializer {public void init() {System.out.println("This is init method");}public void destroy() {System.out.println("This is destroy method");}
}

@Scope 單例模式

@Scope的作用范圍設置成Singleton時,被此注解所標注的類只會被Spring IoC容器初始化一次。

在默認情況下,Spring IoC容器所初始化的類實例都為Singleton

同樣的原理,此情形也有兩種配置方式,示例代碼如@Scope上述

@Autowired

@Autowired注解用于標記Spring將要解析和注入的依賴項。

此注解可以作用在構造函數、字段和setter方法上。

@Primary

當系統中需要配置多個具有相同類型的Bean時,@Primary可以定義這些Bean的優先級。

比如多個實現類ServiceImpl,有一個實現類注解加@Primary則優先實現該類。

@PostConstruct與@PreDestroy

值得注意的是,這兩個注解不屬于Spring,它們是源于JSR-250中的兩個注解,位于common-annotations.jar中。

@PostConstruct注解用于標注在Bean被Spring初始化之前需要執行的方法。

@PreDestroy注解用于標注Bean被銷毀前需要執行的方法。下面是具體的示例代碼:

@Component
public class DemoComponet {private List<String> list = new ArrayList<>();@PostConstructpublic void init() {list.add("q");list.add("w");}@PreDestroypublic void destroy() {list.clear();}
}

@Qualifier

當系統中存在同一類型的多個Bean時,@Autowired在進行依賴注入的時候就不知道該選擇哪一個實現類進行注入。

此時,我們可以使用@Qualifier注解來微調,幫助@Autowired選擇正確的依賴項。

@Qualifier("要使用的實現類")
// 個人理解 java多態特征

@SpringBootApplication

@SpringBootApplication注解是一個快捷的配置注解(啟動類注解),

在被它標注的類中,可以定義一個或多個Bean,并自動觸發自動配置Bean和自動掃描組件。

此注解相當于@Configuration@EnableAutoConfiguration@ComponentScan的組合。

在Spring Boot應用程序的主類中,就使用了此注解。示例代碼如下:

@SpringBootApplication
public class Application{public static void main(String \[\] args){SpringApplication.run(Application.class,args);}
}

@EnableAutoConfiguration

@EnableAutoConfiguration注解用于通知Spring,

根據當前類路徑下引入的依賴包,自動配置與這些依賴包相關的配置項。

@ConditionalOnClass與@ConditionalOnMissingClass

這兩個注解屬于類條件注解,它們根據是否存在某個類作為判斷依據來決定是否要執行某些配置。

下面是一個簡單的示例代碼:

@Configuration
@ConditionalOnClass(DataSource.class)
class MySQLAutoConfiguration {//...
}

@ConditionalOnBean與@ConditionalOnMissingBean

這兩個注解屬于對象條件注解,根據是否存在某個對象作為依據來決定是否要執行某些配置方法。

@Bean
@ConditionalOnBean(name="dataSource")
LocalContainerEntityManagerFactoryBean entityManagerFactory(){//...
}
@Bean
@ConditionalOnMissingBean
public MyBean myBean(){//...
}

@ConditionalOnProperty

@ConditionalOnProperty注解會根據Spring配置文件中的配置項是否滿足配置要求,從而決定是否要執行被其標注的方法。示例代碼如下:

@Bean
@ConditionalOnProperty(name="alipay",havingValue="on")
Alipay alipay(){return new Alipay();
}

@ConditionalOnResource

此注解用于檢測當某個配置文件存在使,則觸發被其標注的方法,下面是使用此注解的代碼示例:

@ConditionalOnResource(resources = "classpath:website.properties")
Properties addWebsiteProperties(){//...
}

@ConditionalOnWebApplication與@ConditionalOnNotWebApplication

這兩個注解用于判斷當前的應用程序是否是Web應用程序。如果當前應用是Web應用程序,則使用 Spring WebApplicationContext,并定義其會話的生命周期。下面是一個簡單的示例:

@ConditionalOnWebApplication
HealthCheckController healthCheckController(){//...
}

@ConditionalExpression

此注解可以讓我們控制更細粒度的基于表達式的配置條件限制。當表達式滿足某個條件或者表達式為真的時候,將會執行被此注解標注的方法。

@Bean
@ConditionalException("${localstore} && ${local == 'true'}")
LocalFileStore store(){//...
}

@Conditional

@Conditional注解可以控制更為復雜的配置條件。在Spring內置的條件控制注解不滿足應用需求的時候,可以使用此注解定義自定義的控制條件,以達到自定義的要求。下面是使用該注解的簡單示例:

@Conditioanl(CustomConditioanl.class)
CustomProperties addCustomProperties(){//...
}

歡迎一起來學習和指導,謝謝關注!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/284047.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/284047.shtml
英文地址,請注明出處:http://en.pswp.cn/news/284047.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

.NET MAUI 跨平臺應用開發 I|.NET MAUI 跨平臺基礎

編輯&#xff1a;Alan Wang排版&#xff1a;Rani Sun微軟 Reactor 為幫助廣開發者&#xff0c;技術愛好者&#xff0c;更好的學習 .NET Core, C#, Python&#xff0c;數據科學&#xff0c;機器學習&#xff0c;AI&#xff0c;區塊鏈, IoT 等技術&#xff0c;將每周三到周六&…

走出宣傳,國產VR手機盒子到底哪家強?

國產VR手機盒子作為入門機是一個不錯的選擇&#xff0c;不過你知道哪一款更適合你嗎&#xff1f; 從去年看虛擬現實還是一個遙不可及的夢&#xff0c;今年卻真正的火起來了。各大廠商紛紛推出自家的VR設備&#xff0c;宣傳活動如火如荼。愛嘗鮮的你是否按耐不住? 如果你覺得動…

Shell 學習筆記之運算符

基本運算符 算術運算符 val expr 2 2 需要注意的是 表達式和運算符之間需要有空格&#xff08;比如2 2&#xff0c;不能是22&#xff09;兩邊最外面的字符是&#xff0c;在esc鍵下面&#xff0c;不是引號哦乘號* 前面必須加上反斜杠 \ 才能實現乘法效果&#xff0c;比如 exp…

POJ 2353 DP

雙向DP記錄路徑。 // by SiriusRen #include <stack> #include <cstdio> #include <cstring> using namespace std; stack<int>s; int n,m,RECL,RECR,minn0x3fffffff,a[555][555],f[555][555],recl[555][555],recr[555][555]; int main(){memset(f,0x3…

【ArcGIS Pro微課1000例】0024:自定義坐標系統---以阿爾伯斯投影(Albers)為例

在實際工作中,經常需要進行矢量數據或柵格數據的投影轉換工作,但有時候ArcGIS中恰恰沒有我們需要的坐標系,此時,就需要我們自定義坐標系。本文以阿爾伯斯投影(Albers)為例,講解自定義投影的一般過程及注意事項。 文章目錄 一、自定義坐標系二、投影轉換一、自定義坐標系…

Linux 操作必備 150 個命令

linux 命令是對 Linux 系統進行管理的命令。對于 Linux 系統來說&#xff0c;無論是中央處理器、內存、磁盤驅動器、鍵盤、鼠標&#xff0c;還是用戶等都是文件&#xff0c; Linux 系統管理的命令是它正常運行的核心&#xff0c;與之前的 DOS 命令類似。 linux 命令在系統中有兩…

dotnet 6 為什么網絡請求不跟隨系統網絡代理變化而動態切換代理

本文記錄在 dotnet 6 的網絡和在 .NET Framework 的行為的變更。在 dotnet 6 下&#xff0c;默認的網絡請求在系統網絡代理變更的時候&#xff0c;是不會動態切換代理的。例如在應用運行進行網絡通訊之后&#xff0c;打開 Fiddler 抓包&#xff0c;此時將會發現 Fiddler 抓不到…

舊金山參議員提議發布“封殺令”,理由是馬路不為機器人所服務

說實話&#xff0c;這個理由有夠奇葩。 因為快遞無人機所受限制頗多&#xff0c;漸漸地&#xff0c;越來越多的快遞機器人被研制出來&#xff08;這里的“機器人”&#xff0c;包括無人車和及機器人&#xff09;&#xff0c;用于城市的快遞發送&#xff0c;比如國內的京東無人…

Socket編程:之雙機通信

服務端&#xff1a; 1 #include<sys/socket.h>2 #include<sys/types.h>3 #include<stdio.h>4 #include<unistd.h>5 #include<stdlib.h>6 #include<string.h>7 #include<netdb.h>8 #include<netinet/in.h>9 #include<arpa/i…

jquery中$each()

$.each()&#xff1a;可用于遍歷任何的集合(無論是數組或對象) $(selector).each()&#xff1a;專用于jquery對象的遍歷, 如果是數組,回調函數每次傳入數組的索引和對應的值(值亦可以通過this 關鍵字獲取,但javascript總會包裝this 值作為一個對象—盡管是一個字符串或是一個數…

【QGIS入門實戰精品教程】7.2:QGIS點狀數據符號化設置案例教程

點狀符號化的類型有:單一符號、分類、漸進、基于規則、點的位移、點聚類、熱圖。 相關閱讀: 【QGIS入門實戰精品教程】7.1:QGIS面狀數據符號化設置案例教程 文章目錄 一、單一符號二、分類三、漸進四、基于規則五、點的位移六、點聚類七、熱圖一、單一符號 跟面狀符號一樣,…

SpringCloud與Dubbo的比較

Dubbo 一、dubbo簡介 Dubbo是阿里巴巴公司開源的一個高性能優秀的服務框架&#xff0c;使得應用可通過高性能的RPC實現服務的輸出和輸入功能&#xff0c;可以和Spring框架無縫集成。 Dubbo是一款高性能、輕量級的開源Java RPC框架&#xff0c;它提供了三大核心能力&#xff…

VR 技術加上 8K 畫質! 2016 年里約奧運會亮點十足

據報道&#xff0c;2016 年里約奧運會將運用到 VR 技術。 最近&#xff0c;奧林匹克廣播服務公司&#xff08;OBS&#xff09;表示出對虛擬現實技術的興趣&#xff0c;其實用虛擬現實技術報道賽事已經不是什么新鮮的事了&#xff0c;之前 NBA 就這樣做過&#xff0c;但是將奧運…

POJ 1986 Distance Queries(LCA)

【題目鏈接】 http://poj.org/problem?id1986 【題目大意】 給出一棵樹&#xff0c;問任意兩點間距離。 【題解】 u,v之間距離為dis[u]dis[v]-2*dis[LCA(u,v)] 【代碼】 #include <cstdio> #include <algorithm> #include <cstring> using namespace std; c…

WPF 實現柱形統計圖

WPF 實現柱形統計圖WPF 實現柱形統計圖作者&#xff1a;WPFDevelopersOrg原文鏈接&#xff1a; https://github.com/WPFDevelopersOrg/WPFDevelopers框架使用大于等于.NET40&#xff1b;Visual Studio 2022;項目使用 MIT 開源許可協議&#xff1b;避免畫線發虛DrawingContext…

Win11卸載WSL,卸載Windows子系統

雖然 Linux 發行版可以通過 Microsoft Store 安裝&#xff0c;但不能通過 Microsoft Store 卸載。 可以通過下列命令卸載。 1、查看當前環境安裝的wsl wsl --list2、注銷&#xff08;卸載&#xff09;當前安裝的Linux的Windows子系統 wsl --unregister Ubuntu3、卸載成功&#…

100億人口會挨餓嗎?人工智能迎擊全球糧食問題

給作物看病的AI、走路“長眼”的拖拉機、上帝視角的衛星數據分析——未來吃飯就靠它們了。 圖片來源&#xff1a;Blue River Technology 人類又面臨了一項危機——隨著人口不斷膨脹&#xff0c;到2050年人類總人口也許要達到100億&#xff0c;然而&#xff0c;地球卻沒有等比例…

Python學習總結15:時間模塊datetime time calendar (二)

二 、datetime模塊 1. datetime中常量 1&#xff09;datetime.MINYEAR&#xff0c;表示datetime所能表示的最小年份&#xff0c;MINYEAR 1。 2&#xff09;datetime.MAXYEAR&#xff0c;表示datetime所能表示的最大年份&#xff0c;MAXYEAR 9999。 2. datetime中的常見類 da…

switch注意事項

Day03_SHJavaTraining_4-5-2017 switch注意事項&#xff1a;①switch語句接受的數據類型  switch語句中的表達式的數據類型,是有要求的    JDK1.0 - 1.4 數據類型接受 byte short int char    JDK1.5 數據類型接受 byte short int char enum(枚舉)  …

WSL1 和 WSL2對比

從 WSL1 更新到 WSL2的主要原因包括&#xff1a; 提高文件系統性能&#xff0c;支持完全的系統調用兼容性。 WSL 2 使用最新、最強大的虛擬化技術在輕量級實用工具虛擬機 (VM) 中運行 Linux 內核。 但是&#xff0c;WSL 2 不是傳統的 VM 體驗。 ? 本指南將比較 WSL 1 和 WSL …