Решение ошибки "module java.base does not open" Android Studio
Быстрый ответ
Чтобы исправить ошибку "module java.base does not 'opens java.io' to unnamed module", вам необходимо добавить следующую опцию JVM:
--add-opens=java.base/java.io=ALL-UNNAMED
Для этого в Android Studio перейдите в меню Run > Edit Configurations, выберите конфигурацию вашего приложения и добавьте эту опцию в настройки JVM.

Разбор ошибки и пошаговое решение
Ошибка "module java.base does not 'opens java.io' to unnamed module" возникает из-за системы контроля доступа, заложенной в Java Platform Module System (JPMS) и введенной в Java 9. Система JPMS предоставляет надежный контроль инкапсуляции, но иногда противоречит использованию рефлексии, требующей доступа к приватным модулям.
Настройки для решения проблемы
Для устранения ошибки рекомендую выполнить следующие шаги:
Обновите Android Studio: Используйте последнюю стабильную версию, чтобы минимизировать вероятность возникновения известных ошибок. Обновление можно найти здесь.
Обновите Gradle и Android Gradle Plugin: В файле
gradle-wrapper.properties
укажите дистрибутив Gradle 7.1.1, а в файлеbuild.gradle
установите версию Android Gradle Plugin, наиболее подходящую для вашего проекта.Добавьте аргументы JVM в свойства Gradle: Добавьте следующий код в файл
gradle.properties
для избежания ошибки:propertiesСкопировать кодorg.gradle.jvmargs=-Xmx1536m --add-opens=java.base/java.io=ALL-UNNAMED
Проверка совместимости
Чтобы предотвратить возникновение конфликтов, убедитесь, что:
- Версия Java установлена правильно: Она должна соответствовать требованиям используемого плагина Gradle.
- Структура проекта настроена корректно: Необходимо это провести в настройках SDK.
- Переменные среды корректно указывают на используемую JDK.
Визуализация
Визуализация процесса устранения ошибки выглядит следующим образом:
Box (📦): "модуль java.base"
Locked (🔒): "Стандартные настройки модуля"
Открытие неименованных модулей можно сравнить с использованием ключа для доступа:
Before: 🔒📦 (Ограниченный доступ к содержимому)
After: 🔓📦➡️🧰 (Доступ открыт с помощью специальных настроек)
Легенда:
🔒 — Закрытый модуль
🔓 – Открытый модуль
🧰 – Инструменты для доступа
Главная цель — обеспечить максимальный доступ к ресурсам Android Studio.
Устранение возможных дополнительных проблем
Зачастую решение основной проблемы может вызвать дополнительные сложности, например:
Взаимодействие с Multidex: Включение этой функции может увеличить количество методов в файлах dex. Отслеживайте их число, чтобы не превышать установленный лимит.
Очистка кеша: Для справления с общими ошибками рекомендуется периодически использовать функцию File > Invalidate Caches / Restart для сброса кешей Android Studio.
Полезные материалы
- Android Studio Hedgehog | 2023.1.1 | Android Developers — последние обновления Android Studio.
- Документация JDK 21 – Главная — официальная документация Java, уделяющая внимание системе модулей.
- Понимание модулей Java 9 — детальный анализ модульной системы Java 9.
- Блог разработчиков Android — официальный блог для разработчиков Android.
- Модули | Документация IntelliJ IDEA — руководство по управлению модулями в IntelliJ IDEA, применимое также в Android Studio.
- Новые вопросы с тегом 'module-info' – Stack Overflow — обсуждения и решения проблем с модульной системой Java от сообщества разработчиков.