String无法跳转源码需先检查Sources是否被IDEA标记为excluded;若Sourcepath显示Not found或红叉,应手动Attach合规结构的-sources.jar(如openjdk-17.0.1+12-sources.jar),注意路径不能含中文/空格、顶层须有java/lang/String.java;JDK 9+因模块系统限制com.sun.*类默认不可见,需加JVM参数-Didea.jdk.attach.internal.sources=true或requires static jdk.unsupported;Gradle中downloadSources = true须配置在idea.module下并Reload project;不同JDK版本src.zip路径不兼容,应查阅对应发行版文档。

点不了String跳转?先确认Sources没被IDEA自动屏蔽
IDEA有时会把已下载的源码标记为“excluded”,尤其在Maven多模块项目里。这时候哪怕src.zip明明存在,Ctrl+Click也只会停在class文件反编译结果上。
检查路径:File → Project Structure → Modules → Dependencies,找到对应jar,展开它,看Sourcepath那一栏是否显示Not found或被红叉覆盖。如果是,说明IDEA没认出源码包,得手动重挂。
- 右键jar →
Download Sources(仅对Maven/Gradle依赖有效) - 如果灰显,说明仓库没发布
-sources.jar,得换手动Attach方式 - 别信“Auto-import”勾选框——它只管pom.xml变更,不负责源码同步
Attach Sources失败?常见三种路径错位
手动Attach时最常卡在路径匹配上。IDEA要求-sources.jar或解压目录必须严格满足:顶层目录里要有java/lang/String.java这类结构,不能是src/main/java/...或者直接塞了一堆.java文件。
- 从Maven中央下载的
openjdk-17.0.1+12-sources.jar可直接Attach——它结构合规 - 自己用
./gradlew sourcesJar打的包,往往套了src/main/java前缀,得解压后选src/main/java子目录再Attach - Windows下路径含中文或空格(比如
C:\Users\张三\.m2\...),Attach会静默失败,建议改用英文路径
为什么java.*类能看源码,但com.sun.*还是灰色?
这是JDK版本和模块系统共同导致的。JDK 9+默认隐藏com.sun.*等内部API,即使Attach了完整src.zip,IDEA也会按module-info.java的exports规则过滤可访问类。
立即学习“Java免费学习笔记(深入)”;
想强制查看(仅限调试):
- 启动IDEA时加JVM参数:
-Didea.jdk.attach.internal.sources=true - 或在项目
module-info.java里临时加:requires static jdk.unsupported; - 注意:
com.sun.nio.*这类NIO扩展源码,在JDK 11+后已移入jdk.nio.zipfs模块,需单独Attach对应模块的sources
Gradle项目里downloadSources = true没生效?检查这个配置位置
很多人把downloadSources = true写在build.gradle最外层,但它只对dependencies块内声明的依赖生效;而IDEA读取的是idea插件的module配置。
正确写法(Groovy DSL):
idea {
module {
downloadSources = true
downloadJavadoc = false
}
}
如果用了Kotlin DSL(build.gradle.kts),必须用idea.project.settings嵌套写法,平级写idea { module { ... } }会被忽略。
改完后要触发Reload project(右键pom.xml或build.gradle → Reload project),不是单纯刷新Maven面板。
src.zip里java.base模块源码路径和JDK 8完全不兼容,强行Attach只会让所有java.lang.*类变红。遇到这种,别硬试,先查对应JDK发行版文档里写的source layout。










