如何決定idea項目中使用的是哪個版本的jdk?是idea中配置決定的?還是maven中配置決定的


? IDEA 項目中使用哪個 JDK,是由以下幾部分共同決定的:

階段決定因素舉例
項目編譯(編譯器)IDEA 設置的 Project SDK 和模塊 SDKProject Structure → Project / Modules 中配置的 JDK
Maven 構建Maven 使用的 JDK(即 Maven 的 JAVA_HOME 環境變量)mvn -v 看的是哪個 JDK
Java 源碼兼容性(編譯目標)pom.xml 中設置的 <maven.compiler.source><target>決定生成的 class 文件兼容哪個 JDK 版本
程序運行運行配置中設置的 JDK(Run Configuration)IDEA 里每個 Main class 的運行設置

🧠 所以答案是:

? IDEA 和 Maven 的 JDK 都有影響,但:

  • 最終使用的 JDK 是你在哪個地方運行的決定的
  • 而生成的 class 文件兼容性,是由 Maven 中 <source>/<target> 決定的

🛠 舉例說明

情況 1:你點擊 IDEA 的綠色運行按鈕

  • IDEA 使用 Project Structure → Project SDK 設置的 JDK 來運行。
  • 如果你設置了 JDK 17,就會用它來運行(和 Maven 無關)。

情況 2:你用 mvn compile 構建項目

  • Maven 使用系統環境變量 JAVA_HOME 或 IDEA 設置的 Maven JDK。

  • mvn -v 可以查看當前 Maven 用的 JDK:

    mvn -v
    

情況 3:你用的是 profile(如 -P jdk-1.8

  • 決定了 <source>/<target>,即 class 文件是否兼容 1.8,但不影響真正用哪個 JDK 運行。

? 檢查步驟(建議)

IDEA 設置檢查:

  1. Project SDK 設置:

    • File → Project Structure → Project → Project SDK
  2. 模塊 SDK 設置:

    • Project Structure → Modules → 使用的 SDK
  3. 運行配置 JDK:

    • Run → Edit Configurations → JDK
  4. Maven 構建用的 JDK:

    • File → Settings → Build Tools → Maven → Runner → JDK

🔍 檢查當前 Maven 使用哪個 JDK:

在終端運行:

mvn -v

輸出類似:

Apache Maven 3.9.3
Java version: 1.8.0_241, vendor: Oracle Corporation
Java home: D:\Software\Java\jdk1.8.0_241

? 最推薦的統一做法

設置推薦配置
IDEA 項目 JDKJDK 17(長期支持)
Maven JAVA_HOME指向同一個 JDK 17
pom.xml設置 <source>/<target>17
Maven Profile可選,如果要支持多版本構建
所有插件(如 Lombok)兼容 JDK 17 的版本

🎯 總結一句話:

IDEA 的 JDK 決定“你在開發和運行時使用哪個 JDK”,Maven 的配置決定“你的 class 文件編譯成哪個版本的兼容格式”,兩者都重要,建議統一為同一個 JDK 版本(如 JDK 17)避免混亂。


需要我幫你一步步配置 IDEA 使用 JDK 17 嗎?可以提供你操作系統(Windows/macOS)我來圖解。

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

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

相關文章

Docker拉取bladex 、 sentinel-dashboard

docker pull bladex/sentinel-dashboard 是用于從 Docker Hub 拉取 Alibaba Cloud Sentinel Dashboard 鏡像的命令&#xff0c;默認會拉取最新版本。以下是詳細的操作步驟及注意事項&#xff1a; 操作步驟 1. 拉取鏡像 &#xff1a;在終端輸入 docker pull bladex/sentinel-…

從零開始理解 JavaScript 中的 `window.parent`、`top` 和 `self`

從零開始理解 JavaScript 中的 window.parent、top 和 self 在 JavaScript 開發中&#xff0c;window 對象是瀏覽器環境中最重要的全局對象之一。它不僅代表了瀏覽器窗口本身&#xff0c;還提供了對窗口層級關系的訪問能力。對于處理嵌套框架&#xff08;iframe&#xff09;或…

vue3引入海康監控視頻組件并實現非分屏需求一個頁面同時預覽多個監控視頻;

海康監控視頻非分屏需求&#xff0c;一個頁面引用多個視頻組件; js文件位置index.html 引入js文件//根據自己路徑引入哈<script src"static/haiKangWeb3.0/jquery-1.7.1.min.js"></script><script type"text/javascript" id"videonode…

Policy Gradient【強化學習的數學原理】

目錄 policy 與表格方式的區別&#xff1a; metric to define optimal policies 1. weighted averge 2. the average reward 問題&#xff1a; 梯度計算 如何理解policy-gradient&#xff1f; policy gradient與表格方式(value based)的區別&#xff1a; policy 通過參…

【深圳大學機器學習】實驗一:PCA算法

實驗目的 1、實現PCA算法的人臉重構&#xff0c;即用20,40,60,80,...,160個投影來重構圖像的效果。 2、實現PCA算法的人臉識別&#xff0c;給出不少于三個人臉數據庫上 10,20,30,...,160維的人臉識別識別率&#xff0c;并打印出識別率變化曲線圖。 3、用PCA用來進行人臉圖像…

編程中的英語

case this are mixed case version case在這里表示大小寫&#xff1f;為什么case可以表示大小寫的含義&#xff1f; “case”在這里的含義 在句子“This are mixed case version”中&#xff0c;“case”確實表示“大小寫”&#xff0c;用于描述字母的形式&#xff08;大寫字母…

LabVIEW開發關節軸承試驗機

LabVIEW通過NI硬件&#xff08;CompactRIO 實時控制器、FPGA 模塊等&#xff09;與模塊化軟件設計的結合&#xff0c;實現試驗參數采集、多工況控制、數據存儲的并行處理&#xff0c;體現LabVIEW 在工業自動化中對多任務并發場景的高效支持能力。 ? 應用場景 關節軸承試驗機…

【Linux庖丁解牛】— 動靜態庫的制作和使用!

1. 什么是庫庫是寫好的現有的&#xff0c;成熟的&#xff0c;可以復?的代碼。現實中每個程序都要依賴很多基礎的底層庫&#xff0c;不可能 每個?的代碼都從零開始&#xff0c;因此庫的存在意義?同尋常。 本質上來說庫是?種可執?代碼的?進制形式&#xff0c;可以被操作系統…

Hadoop集群啟動 (ZooKeeper、HDFS、YARN、Hbase)

一、啟動ZooKeeper集群 sh /opt/modules/zookeeper-3.4.14/bin/zkServer.sh start[hadoopcentos01 ~]$ sh /opt/modules/zookeeper-3.4.14/bin/zkServer.sh start ZooKeeper JMX enabled by default Using config: /opt/modules/zookeeper-3.4.14/bin/../conf/zoo.cfg Startin…

React Hooks全面解析:從基礎到高級的實用指南

React Hooks全面解析&#xff1a;從基礎到高級的實用指南 React Hooks自2018年16.8版本引入以來&#xff0c;徹底改變了React組件的開發方式。** Hooks使函數組件獲得了與類組件同等的表達能力&#xff0c;同時簡化了代碼結構&#xff0c;提升了可維護性**。本文將系統介紹Rea…

LINUX75 LAMP

LAMP 環境 yum NetworkManager systemctl status firewalld setenforce 0 Last login: Fri Jul 4 19:21:47 2025 from 192.168.235.1 [rootweb ~]# cd /usr/local/apache2/conf/ [rootweb conf]# ls extra httpd.conf httpd.conf.bak magic mime.types original [root…

cloudflare配合github搭建免費開源影視LibreTV一個獨享視頻網站 詳細教程

一、項目簡介 LibreTV 是一個開源的 IPTV/影視聚合前端項目&#xff0c;支持 M3U 播放列表、EPG 電子節目單等。它本身是純前端項目&#xff0c;非常適合用 GitHub Pages Cloudflare 免費托管。 二、準備工作 GitHub 賬號 注冊并登錄 GitHub Cloudflare 賬號 注冊并登錄 …

Linux/Unix進程概念及基本操作(PID、內存布局、虛擬內存、環境變量、fork、exit、wait、exec、system)

進程 文章目錄 進程I 進程基本概念1、進程和程序2、進程號和父進程號3、進程內存布局4、虛擬內存管理&#xff08;1&#xff09;程序的兩種局部性&#xff08;2&#xff09;虛擬內存的規劃&#xff08;3&#xff09;虛擬內存的優點 5、棧和棧幀6、命令行參數argc和argv7、環境變…

0基礎學Python系列【25】 單元測試入門教程

大家好,歡迎來到Python學習的第三站!?? 這部分會涉及一些Python的進階技術,雖然不一定是必需的,但學會這些,你會覺得編程更得心應手。 本章要學什么? Python調試器(pdb)裝飾器lambda函數代碼性能分析單元測試入門 —— 今天講這里聽起來有點多?別擔心,我們慢慢來,…

iOS常見內存錯誤碼

一、經典十六進制錯誤碼0xDEADBEEF&#xff08;EXC_BAD_ACCESS&#xff09; 含義&#xff1a;野指針訪問&#xff08;訪問已釋放的內存地址&#xff09;。 記憶點&#xff1a;“DEAD BEEF” 可理解為 “死亡牛肉”&#xff0c;象征指針指向的內存已 “死亡”。 觸發場景&#x…

CSS01:CSS的快速入門及優勢

CSS快速入門 style 練習格式&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>CSS</title><!-- 規范,<style>可以編寫css代碼,每一個聲明最好用分號結尾語法&#xff1a;…

springsecurity5配置之后啟動項目報錯:authenticationManager cannot be null

目錄 配置代碼 報錯信息 解決辦法 配置代碼 下面的配置為響應式的配置方式 //這個配置只是配置springboot admin的一個例子,具體的配置可能比較復雜 @EnableWebFluxSecurity public class SecurityConfig {private final AdminServerProperties adminServer;public Securi…

攻防世界-Rerverse-game

知識點 1.ida逆向 2.函數分析逆向 步驟 用Exeinfo打開&#xff0c;為32位exe文件。 方法一&#xff1a; 玩游戲通關&#xff0c;根據游戲規則&#xff0c;m1&#xff0c;n依次為1到8即可得到flag。 方法二&#xff1a; 用32位IDA打開 ctrlF搜索main&#xff0c;點擊_main,…

openEuler 24.03 全流程實戰:用 Ansible 5 分鐘部署分布式 MinIO 高可用集群

目錄 0 | 為什么要寫這篇教程&#xff1f; 1 | 準備工作 1.1 控制節點手工下載 MinIO 1.2 SSH 互信&#xff08;可跳過&#xff0c;本教程已有互信&#xff09; 1.3 安裝 Ansible & SELinux 依賴 2 | 項目目錄 3 | Inventory hosts.ini 4 | 變量文件 group_vars/al…

最左匹配原則

導讀&#xff1a; 首先創建一張 test 表&#xff0c;并插入一些數據&#xff1a; CREATE TABLE test ( id int(11) NOT NULL AUTO_INCREMENT COMMENT 主鍵, a int(11) NOT NULL, b int(11) NOT NULL, c int(11) NOT NULL, d int(11) NOT NULL, PRIMARY KEY (id), KEY idx_abc …