React Native w/Expo: странная ошибка при использовании run:android

Я работаю над простым приложением с реагирующим нативным (/expo). Когда я делаю что-то простое, например следующие 4 команды (по порядку в Windows 11, Expo 51):

  1. npx create-expo-app Test --template (выбран шаблон Blank; без Typescript)
  2. cd Test
  3. npm install
  4. npx expo run:android

Я получаю следующий вывод и ошибку:

📝  Android package Learn more: https://expo.fyi/android-package

√ What would you like your Android package name to be? ... com.pmaddineedi.Test

√ Created native directory
√ Updated package.json
» android: userInterfaceStyle: Install expo-system-ui in your project to enable this feature.
√ Finished prebuild
› Building app...
Configuration on demand is an incubating feature.

FAILURE: Build failed with an exception.

* What went wrong:
Could not open settings generic class cache for settings file 'C:\Users\pmadd\Mobile Development\Audacity\Test\android\settings.gradle' (C:\Users\pmadd\.gradle\caches\8.6\scripts\9jvl7af6mie02hkplgyjc1nfd).
> BUG! exception in phase 'semantic analysis' in source unit '_BuildScript_' Unsupported class file major version 66

* Try:
> Run with --stacktrace option to get the stack trace.
> Run with --info or --debug option to get more log output.
> Run with --scan to get full insights.
> Get more help at https://help.gradle.org.

BUILD FAILED in 758ms
Error: C:\Users\pmadd\Mobile Development\Audacity\Test\android\gradlew.bat app:assembleDebug -x lint -x test --configure-on-demand --build-cache -PreactNativeDevServerPort=8081 -PreactNativeArchitectures=x86_64,arm64-v8a exited with non-zero code: 1
Error: C:\Users\pmadd\Mobile Development\Audacity\Test\android\gradlew.bat app:assembleDebug -x lint -x test --configure-on-demand --build-cache -PreactNativeDevServerPort=8081 -PreactNativeArchitectures=x86_64,arm64-v8a exited with non-zero code: 1
    at ChildProcess.completionListener (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\@expo\spawn-async\build\spawnAsync.js:42:23)
    at Object.onceWrapper (node:events:634:26)
    at ChildProcess.emit (node:events:519:28)
    at cp.emit (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\cross-spawn\lib\enoent.js:34:29)
    at maybeClose (node:internal/child_process:1105:16)
    at ChildProcess._handle.onexit (node:internal/child_process:305:5)
    ...
    at spawnAsync (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\@expo\spawn-async\build\spawnAsync.js:7:23)
    at spawnGradleAsync (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\@expo\cli\build\src\start\platforms\android\gradle.js:96:48)
    at assembleAsync (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\@expo\cli\build\src\start\platforms\android\gradle.js:74:18)
    at runAndroidAsync (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\@expo\cli\build\src\run\android\runAndroidAsync.js:45:37)

Однако npm start работает отлично. Как это исправить?

Обратите внимание, что я видел в Интернете множество решений этой проблемы, но ни одно из них не работает.

РЕДАКТИРОВАТЬ

Я использую Java JDK 20, так как мне кажется, что мне нужна версия 17+, а версия 22 слишком новая.


1
163
1

Ответ:

Решено

Использование gradle init со следующим вводом сработало:

Тип проекта: Приложение (2)

Язык реализации: Котлин (4)

Создать несколько подпроектов для приложения: нет

Сборка сценария DSL: Котлин (1)

Целевая версия Java: 20

Генерация сборки с использованием новых API и поведения: да