macOS 安装JDK17

embedded/2025/1/22 5:49:02/

文章目录

    • 前言
    • 介绍
    • 新特性
    • 下载
    • 安装
      • 1.下载完成后打开downloads 双击进行安装
      • 2.配置环境变量
      • 3.测试快速切换JDK
    • 小结

前言

近期找开源软件,发现很多都已经使用JDK17+springboot3 了,之前的JDK8已经被替换下场,所以今天就在本机安装了JDK17,拥抱变化。

介绍

JDK 17 是 Java 平台标准版(Java SE)的一个功能发布版本,于2021年9月14日正式发布。

新特性

  • 移除未命名模块:JDK 17 永久移除了“未命名模块”,这是模块化系统成熟和进一步发展的体现,标志着 Java 正式从类路径时代过渡到了模块时代。开发者需要对遗留项目进行模块化处理,定义模块描述符module-info.java来明确模块之间的依赖关系。
  • 增强型switch表达式:引入了模式匹配的switch语句,允许在switch表达式中使用模式匹配,从而简化了对不同类型数据的处理。
  • 文本块:允许开发人员在Java代码中表示多行字符串文本,以三个双引号(“”")开头和结尾,为编写多行文本提供了简洁的语法。
  • 密封类:JDK 17 引入了密封类,允许开发者限制一个类或接口的继承或实现。通过使用sealed修饰符,可以指定哪些类可以继承或实现密封类,从而增强代码的封装性和安全性。
    等等…

下载

到oracle官网下载:https://www.oracle.com/java/
在这里插入图片描述
选择下载历史版本
在这里插入图片描述
选择JDK17
在这里插入图片描述
选择适配自己电脑的安装包
在这里插入图片描述
至此安装包下载完成。

安装

1.下载完成后打开downloads 双击进行安装

在这里插入图片描述
双击pkg
在这里插入图片描述
双击继续
在这里插入图片描述
一直下一步即可
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
至此JDK17安装完成。

2.配置环境变量

输入命令记录JDK的安装路径

/usr/libexec/java_home -V

在这里插入图片描述
输入命令编辑环境变量

sudo vi ~/.zshrc

添加JAVA_HOME配置,JAVA_HOME切记地址要修改成自己的

export JAVA_8_HOME="/Library/Java/JavaVirtualMachines/jdk1.8.0_361.jdk/Contents/Home"
export JAVA_17_HOME="/Library/Java/JavaVirtualMachines/jdk-17.jdk/Contents/Home"#多版本切换(取了别名,更方便切换)
alias jdk8="export JAVA_HOME=$JAVA_8_HOME"
alias jdk17="export JAVA_HOME=$JAVA_17_HOME"# 默认JDK版本
export JAVA_HOME=$JAVA_17_HOME#在path中添加$JAVA_HOME
export PATH=$PATH:$JAVA_HOME/bin:$MAVEN_HOME/bin

配置如下:
在这里插入图片描述
加载环境变量

source ~/.zshrc

3.测试快速切换JDK

输入jdk8 进行验证
在这里插入图片描述

小结

至此安装JDK17完成。最后很多项目也会用OpenJDK,特附上OpenJDK地址,下载地址:https://bell-sw.com/pages/downloads/#jdk-17-lts
在这里插入图片描述


http://www.ppmy.cn/embedded/155978.html

相关文章

#前端网址

网址 CSS color 属性 (w3school.com.cn) MDN Web Docs (mozilla.org) Can I use... Support tables for HTML5, CSS3, etc

如何将自己本地项目开源到github上?

环境: LLMB项目 问题描述: 如何将自己本地项目开源到github上? 解决方案: 步骤 1: 准备本地项目 确保项目整洁 确认所有的文件都在合适的位置,并且项目的 README.md 文件已经完善。检查是否有敏感信息&#xff0…

Elasticsearch:Jira 连接器教程第二部分 - 6 个优化技巧

作者:来自 Elastic Gustavo Llermaly 将 Jira 连接到 Elasticsearch 后,我们现在将回顾最佳实践以升级此部署。 在本系列的第一部分中,我们配置了 Jira 连接器并将对象索引到 Elasticsearch 中。在第二部分中,我们将回顾一些最佳实…

PIL——抗锯齿修改分辨率

1. PIL 中的抗锯齿与齿轮图像的平滑处理 如果用户的问题是希望使用 PIL 处理齿轮图像(例如绘制或缩放齿轮图像),并避免锯齿问题,可以参考以下方法: (1)使用 Image.ANTIALIAS 进行抗锯齿处理 …

PostgreSQL插件pg_repack介绍和简单使用【2】

文章目录 pg_repack用法介绍OPTIONS指定选项重组选项连接选项通用选项 pg_repack用法介绍 OPTIONS指定选项 -a, --all 重新打包所有数据库-t, --tableTABLE 仅打包指定表-I, --parent-tableTABLE 重新打包特定的父表及其继承表-c, --schemaSCHEMA 仅打包指定模式内的表-s, --…

Flink在流处理中,为什么还会有窗口的概念呢

窗口操作在流处理中看似有些反直觉,因为流处理通常处理的是无限数据流,数据不断流入而没有明确的结束点。然而,窗口操作却是流处理的一个核心概念,特别是在需要对流数据进行 聚合、统计、处理 等操作时,窗口的概念就显…

22. C语言 输入与输出详解

本章目录: 前言1. 输入输出的基础概念1.1 标准输入输出流1.2 输入输出函数 2. 格式化输出与输入2.1 使用 printf() 进行输出示例 1: 输出字符串示例 2: 输出整数示例 3: 输出浮点数 2.2 使用 scanf() 进行输入示例 4: 读取整数和字符改进方案:使用getchar()清理缓冲…

“大模型横扫千军”背后的大数据挖掘--浅谈MapReduce

文章目录 O 背景知识1 数据挖掘2 邦费罗尼原则3 TF.IDF4 哈希函数5 分布式文件系统 一、MapReduce基本介绍1. Map 任务2. 按键分组3. Reduce 任务4. 节点失效处理5.小测验:在一个大型语料库上有100个map任务和若干reduce任务: 二、基于MapReduce的基本运…