Java for Beginner
698 subscribers
609 photos
166 videos
12 files
948 links
Канал от новичков для новичков!
Изучайте Java вместе с нами!
Здесь мы обмениваемся опытом и постоянно изучаем что-то новое!

Наш YouTube канал - https://www.youtube.com/@Java_Beginner-Dev

Наш канал на RUTube - https://rutube.ru/channel/37896292/
Download Telegram
Установка Maven на Linux

Требования
JDK: Установленный JDK (версия 8 или выше).
Интернет: Для загрузки Maven.
Терминал: Доступ к командной строке.



Шаги установки

Проверка JDK:
Выполните:
java -version


Вывод должен показать версию Java. Если JDK отсутствует, установите, например, OpenJDK:
sudo apt update
sudo apt install openjdk-11-jdk # Ubuntu/Debian
sudo dnf install java-11-openjdk-devel # Fedora


Скачивание Maven:
Перейдите на сайт Apache Maven.

Скачайте архив, например, apache-maven-3.9.9-bin.tar.gz:
wget https://downloads.apache.org/maven/maven-3/3.9.9/binaries/apache-maven-3.9.9-bin.tar.gz


Распакуйте в /opt:
sudo tar -xzvf apache-maven-3.9.9-bin.tar.gz -C /opt


Настройка переменных окружения:
Откройте файл /etc/environment или ~/.bashrc:
nano ~/.bashrc


Добавьте строки:
export M2_HOME=/opt/apache-maven-3.9.9
export PATH=$M2_HOME/bin:$PATH
export JAVA_HOME=/usr/lib/jvm/java-11-openjdk-amd64 # Путь к JDK


Примените изменения:
source ~/.bashrc


Проверка установки:
Выполните:
mvn -version


Вывод:

Apache Maven 3.9.9
Maven home: /opt/apache-maven-3.9.9
Java version: 11.0.16, vendor: Ubuntu


Настройка локального репозитория:
По умолчанию используется ~/.m2/repository.

Опционально настройте ~/.m2/settings.xml для кастомного пути или зеркал:
<settings>
<localRepository>/custom/m2/repository</localRepository>
</settings>

В памяти: На Linux Maven запускается через скрипт mvn, который вызывает JVM. Процесс аналогичен Windows: Maven Core, плагины и зависимости загружаются в память. Локальный репозиторий кэширует артефакты, снижая сетевую нагрузку.


Нюансы:
Убедитесь, что JAVA_HOME указывает на правильный JDK.
Для системного доступа установите Maven в /opt и настройте права: sudo chown -R
$USER /opt/apache-maven-3.9.9.
Используйте mvnw для согласованности версий в проектах.


#Java #middle #Maven #Maven_install
👍3
Введение в Java


Что такое Java?

Java — это высокоуровневый, объектно-ориентированный язык программирования, созданный компанией Sun Microsystems (ныне принадлежит Oracle) в 1995 году. Главная идея Java — "Write Once, Run Anywhere" (Напиши один раз, запускай везде). Это значит, что программа, написанная на Java, может работать на любом устройстве или операционной системе, где есть подходящая среда выполнения.

Java используется повсеместно: от веб-приложений и мобильных приложений (например, Android) до серверных систем, больших корпоративных проектов и даже встраиваемых устройств, таких как "умные" телевизоры или IoT-устройства.

Её популярность обусловлена несколькими факторами:
Кроссплатформенность: Работает на Windows, macOS, Linux и других системах.
Надежность:
Java имеет строгую типизацию и встроенные механизмы обработки ошибок.
Большое сообщество: Огромное количество библиотек, фреймворков и документации.
Широкая применимость: От небольших скриптов до сложных распределенных систем.



Кроссплатформенность Java

Кроссплатформенность — это способность программы работать на разных операционных системах без необходимости переписывать код. В отличие от языков, таких как C или C++, где код компилируется в машинный код, специфичный для конкретной платформы (например, процессора или ОС), Java использует другой подход.

Когда вы пишете программу на Java, ваш код компилируется не в машинный код, а в байт-код. Это промежуточное представление программы, которое одинаково для всех платформ. Байт-код создается компилятором Java (javac) и сохраняется в файлах с расширением .class. Но сам по себе байт-код не может выполняться напрямую на вашем компьютере. Здесь на сцену выходит JVM — виртуальная машина Java.

JVM (
Java Virtual Machine) интерпретирует или компилирует байт-код в машинный код, который может быть выполнен на конкретной аппаратной платформе. Например, JVM для Windows преобразует байт-код в инструкции, понятные процессорам на Windows, а JVM для Linux делает то же самое для Linux. Таким образом, вам не нужно писать разные версии программы для каждой операционной системы — достаточно написать код один раз, а JVM позаботится об остальном.

Но чтобы запустить Java-программу, вам нужно больше, чем просто JVM. Здесь появляются JRE и JDK.


JVM: Сердце Java

JVM (Java Virtual Machine) — это виртуальная машина, которая исполняет байт-код Java-программ. Она является ключевым компонентом, обеспечивающим кроссплатформенность.

JVM выполняет несколько важных функций:
Интерпретация и JIT-компиляция: JVM может интерпретировать байт-код построчно или использовать JIT-компилятор (Just-In-Time), чтобы преобразовать байт-код в машинный код для повышения производительности.
Управление памятью: JVM включает сборщик мусора (Garbage Collector), который автоматически освобождает память, занятую объектами, которые больше не используются.
Безопасность: JVM предоставляет песочницу (sandbox), которая ограничивает доступ программ к системным ресурсам, что делает
Java-программы безопасными.

JVM — это, по сути, "переводчик" между вашим байт-кодом и конкретной аппаратной платформой. Без JVM Java-программа не сможет работать.

#Java #для_новичков #beginner
👍3
JRE: Среда выполнения

JRE (Java Runtime Environment) — это среда выполнения Java, которая включает в себя всё необходимое для запуска Java-программ.

JRE состоит из:
JVM: Виртуальная машина, о которой мы только что говорили.
Библиотеки
Java: Стандартные классы и API (например, для работы с файлами, сетью, графикой).
Дополнительные компоненты: Например, средства для загрузки классов и управления безопасностью.


Если вы хотите просто запускать Java-программы (например, запустить готовое приложение, такое как IDE или сервер), вам достаточно установить JRE. Однако JRE не включает инструменты для разработки — для этого нужен JDK.


JDK: Набор для разработки

JDK (Java Development Kit) — это комплект инструментов для разработки Java-программ.

JDK включает в себя всё, что есть в JRE, плюс дополнительные утилиты для программистов:

Компилятор (javac): Преобразует исходный код на Java в байт-код.
Отладчик (jdb): Помогает находить и исправлять ошибки в коде.
Инструменты для создания документации (javadoc): Генерирует документацию из комментариев в коде.

Другие утилиты: Например, jar для создания архивов Java.

JDK — это то, что вам нужно установить, если вы хотите писать и компилировать свои Java-программы. Без JDK вы не сможете превратить ваш код (файлы с расширением .java) в исполняемый байт-код.


Как всё это связано?

Давайте разберем процесс работы Java-программы:
Вы пишете код на Java в файле с расширением .java (например, HelloWorld.java).
С помощью компилятора из JDK (javac) ваш код компилируется в байт-код (файл .class).
Байт-код передается в JVM, которая является частью JRE.
JVM интерпретирует или компилирует байт-код в машинный код, который выполняется на вашей системе.


Вот простая схема:
Исходный код (.java) → Компилятор (javac, часть JDK) → Байт-код (.class) → JVM (часть JRE) → Выполнение на устройстве


Зачем это новичку?

Понимание JVM, JRE и JDK важно, чтобы вы могли правильно настроить свою рабочую среду и понимать, как работает ваша программа.

Вот несколько практических советов:
Установите JDK: Если вы начинаете учить Java, скачайте и установите JDK с официального сайта Oracle или используйте OpenJDK (бесплатная альтернатива). JRE уже будет включена в JDK.
Проверьте версию: Убедитесь, что вы используете актуальную версию
Java (на момент 2025 года это, например, Java 17 или новее). Команда java -version в терминале покажет, какая версия JRE установлена, а javac -version — версия JDK.
Настройте IDE: Для удобной разработки используйте среды, такие как IntelliJ IDEA, Eclipse или VS Code с плагинами для
Java.

#Java #для_новичков #beginner
👍5
Введение в Gradle и концептуальная архитектура

Что такое Gradle? Эволюция от Ant и Maven

Gradle — это инструмент автоматизации сборки с открытым исходным кодом, предназначенный для управления проектами на Java, Kotlin, Scala, C++ и других языках. Он сочетает декларативный подход Maven с гибкостью Ant, используя Groovy или Kotlin для описания сборки. Gradle был создан в 2007 году Хансом Доктером и Адамом Мердоком и с тех пор стал стандартом для многих современных проектов, включая Android и Spring Boot.

Эволюция

Ant (2000): Первый широко используемый инструмент сборки для Java. Ant применяет императивный подход, где разработчик вручную описывает задачи в XML-файле (build.xml). Он не предоставляет встроенного управления зависимостями или жизненного цикла, что делает его гибким, но сложным для крупных проектов.

Maven (2004): Ввел декларативный подход с жизненным циклом (clean, build, site) и управлением зависимостями через репозитории. Maven использует XML (POM.xml), что обеспечивает стандартизацию, но ограничивает гибкость для нестандартных сценариев.

Gradle (2007): Объединяет преимущества Ant и Maven, предлагая:
Гибкость: Возможность писать программную логику для задач с помощью Groovy или Kotlin.
Производительность: Инкрементальная сборка и кэширование задач.
Декларативность: Простое описание зависимостей и плагинов, аналогичное Maven.
Многопроектная поддержка: Эффективное управление многомодульными проектами.


Gradle стал популярным благодаря поддержке Android Studio, высокой производительности и активному сообществу.
В памяти: Gradle работает как
Java-приложение, загружая конфигурационные файлы (build.gradle, settings.gradle), плагины и зависимости в оперативную память. В отличие от Maven, Gradle использует Groovy/Kotlin для парсинга скриптов, что увеличивает потребление памяти из-за динамической природы этих языков, но оптимизируется за счет кэширования и инкрементальности.


Архитектура Gradle

Архитектура Gradle построена вокруг концепции задач (tasks) и графа выполнения, что отличает его от жизненного цикла Maven. Рассмотрим ключевые аспекты.


Task-based Model vs Lifecycle-based (в Maven)

Task-based Model (Gradle):
Gradle использует модель, основанную на задачах, где каждая задача (task) — это атомарная единица работы (например, компиляция, тестирование, упаковка).
Задачи определяются в build.gradle и могут быть связаны через зависимости (например, задача build зависит от compileJava).
Разработчик может создавать кастомные задачи с программной логикой, что обеспечивает гибкость.


Пример:
task hello {
doLast {
println 'Hello, Gradle!'
}
}


Lifecycle-based Model (Maven):
Maven использует фиксированный жизненный цикл (clean, default, site) с фазами (compile, test, package), к которым привязаны плагины.
Ограниченная гибкость: задачи определяются через плагины, а не напрямую.


В памяти:
В Gradle каждая задача представлена как объект в памяти, содержащий конфигурацию и зависимости. Это увеличивает потребление памяти по сравнению с Maven, где фазы жизненного цикла имеют более жесткую структуру. Однако Gradle оптимизирует выполнение, пропуская неизмененные задачи (см. инкрементальность).


Directed Acyclic Graph (DAG) исполнения задач

Gradle строит Directed Acyclic Graph (DAG) для задач, где:
Узлы — это задачи.
Ребра — зависимости между задачами (например, build зависит от test, а test — от compileJava).

Gradle анализирует DAG, чтобы определить порядок выполнения задач и избежать циклов.


Процесс:
Gradle парсит build.gradle и создает объекты задач в памяти.
Формируется DAG на основе зависимостей, указанных в dependsOn или неявно через плагины.
Gradle выполняет задачи в порядке, определенном топологической сортировкой DAG, пропуская те, которые не требуются.


Пример:
task compileJava {
doLast { println 'Compiling Java' }
}
task test(dependsOn: compileJava) {
doLast { println 'Running tests' }
}
task build(dependsOn: test) {
doLast { println 'Building artifact' }
}


#Java #middle #Gradle
👍3
Инкрементальность и кэширование

Gradle оптимизирует производительность за счет:
Инкрементальности: Gradle проверяет входные и выходные данные задач (например, исходные файлы, скомпилированные классы). Если они не изменились, задача пропускается.

Пример:
Задача compileJava проверяет хэши исходных файлов и пропускает компиляцию, если они не изменились.

Кэширование:
Локальный кэш: Gradle хранит результаты задач в ~/.gradle/caches, что позволяет повторно использовать артефакты между сборками.
Build Cache: Gradle может кэшировать результаты задач на удаленном сервере (например, в CI/CD), что ускоряет сборку на разных машинах.


Настройка в settings.gradle:
buildCache {
local {
enabled = true
}
remote(HttpBuildCache) {
url = 'https://cache.example.com/'
push = true
}
}


В памяти:
Инкрементальность требует хранения хэшей входных/выходных данных в памяти для сравнения, что добавляет overhead. Build Cache минимизирует повторные вычисления, но требует дополнительной памяти для управления метаданными кэша.


Сравнение Gradle vs Maven

Гибкость, декларативность, производительность

Гибкость:
Gradle: Позволяет писать программную логику в задачах, используя Groovy/Kotlin. Подходит для нестандартных сценариев (например, кастомные процессы сборки).
Maven: Ограничивает кастомизацию плагинами и XML, что менее гибко для сложных задач.


Декларативность:
Maven: Полностью декларативный подход через XML (POM.xml), что упрощает стандартизацию, но ограничивает выразительность.
Gradle: Сочетает декларативность (зависимости, плагины) с императивной логикой, что делает его более выразительным.


Производительность:
Gradle: Быстрее за счет инкрементальной сборки, кэширования и параллельного выполнения задач. Флаг --parallel ускоряет многомодульные проекты.
Maven: Медленнее из-за последовательного выполнения фаз и отсутствия встроенной инкрементальности. Флаг -T частично компенсирует это.


В памяти:
Gradle потребляет больше памяти из-за динамической природы Groovy/Kotlin и сложных DAG. Maven экономичнее, так как использует фиксированную структуру жизненного цикла, но менее эффективен по времени выполнения.


Groovy DSL vs XML (Maven)

Groovy DSL (Gradle):
Использует Groovy для описания сборки, что делает синтаксис компактным и выразительным.

Пример:
plugins {
id 'java'
}
dependencies {
implementation 'org.springframework:spring-core:5.3.20'
}


Преимущества: Легко читаемый код, поддержка программной логики, динамическая конфигурация.
Недостатки: Требует изучения Groovy, потенциальные ошибки из-за динамической типизации.


XML (Maven):
Использует XML (POM.xml), что делает конфигурацию строгой и стандартизированной.

Пример:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.3.20</version>
</dependency>

Преимущества: Простота для новичков, строгая структура, поддержка инструментами (IDE).
Недостатки: Многословность, ограниченная гибкость.


В памяти:
Парсинг Groovy DSL в Gradle требует загрузки Groovy-библиотек и динамической компиляции скриптов, что увеличивает потребление памяти по сравнению с XML-парсингом Maven, который использует более легковесные парсеры (например, StAX).

#Java #middle #Gradle
👍3
Поддержка Groovy DSL и Kotlin DSL

Gradle поддерживает два языка для написания скриптов сборки:

Groovy DSL:
Основной язык Gradle, используемый в build.gradle.
Динамическая типизация, лаконичный синтаксис.


Пример:
plugins {
id 'java'
}
repositories {
mavenCentral()
}


Kotlin DSL:
Введен для статической типизации и лучшей поддержки в IDE.
Используется в build.gradle.kts.


Пример:
plugins {
java
}
repositories {
mavenCentral()
}

Преимущества: Статическая типизация, автодополнение в IDE, меньше ошибок на этапе выполнения.
Недостатки: Более строгий синтаксис, требует изучения Kotlin.


Выбор:

Используйте Groovy для простоты и совместимости с существующими проектами.
Выберите Kotlin для новых проектов, особенно если команда знакома с Kotlin или требуется строгая типизация.



Build Scans — что это и зачем

Build Scans — это инструмент Gradle для анализа и отладки сборок.

Они представляют собой веб-отчеты, содержащие:
Детали выполнения задач (время, зависимости, пропущенные задачи).
Информацию о конфигурации (плагины, зависимости, свойства).
Логи ошибок и предупреждений.


Настройка:
Добавьте плагин в build.gradle:
plugins {
id 'com.gradle.build-scan' version '3.17.4'
}
buildScan {
termsOfServiceUrl = 'https://gradle.com/terms-of-service'
termsOfServiceAgree = 'yes'
}

Запустите сборку:./gradlew build --scan
Получите ссылку на Build Scan в консоли.


Зачем:
Отладка: Выявление узких мест (например, медленных задач).
Оптимизация: Анализ пропущенных задач и кэширования.
Совместная работа: Делитесь Build Scans с командой для диагностики проблем.
CI/CD: Интеграция с Gradle Enterprise для хранения и анализа сборок.


В памяти: Build Scan собирает метаданные о сборке в памяти, включая DAG, время выполнения задач и конфигурацию. Это увеличивает потребление памяти, особенно для крупных проектов. Данные отправляются на сервер Gradle Enterprise, что требует сетевых операций.


#Java #middle #Gradle
👍3
Конфигурационные файлы: build.gradle, settings.gradle, gradle.properties

Gradle использует три основных файла конфигурации:

build.gradle:

Основной файл сборки, определяющий задачи, плагины и зависимости.

Пример:
plugins {
id 'java'
id 'org.springframework.boot' version '2.7.18'
}
repositories {
mavenCentral()
}
dependencies {
implementation 'org.springframework.boot:spring-boot-starter'
testImplementation 'junit:junit:4.13.2'
}

В памяти: Парсится в объектную модель Gradle, включая задачи и зависимости. Динамическая компиляция Groovy/Kotlin увеличивает overhead.


settings.gradle:

Определяет структуру многомодульного проекта и настройки (например, корневое имя проекта, включенные модули).

Пример:
rootProject.name = 'my-project'
include 'module-api', 'module-core', 'module-web'

В памяти: Формирует модель проекта, включая граф модулей. Меньше по объему, чем build.gradle, но влияет на DAG.


gradle.properties:

Хранит свойства для настройки Gradle и JVM.

Пример:
org.gradle.jvmargs=-Xmx2048m
org.gradle.parallel=true
myVersion=1.0.0

В памяти: Свойства загружаются как часть конфигурации Gradle, минимально влияя на память.


Нюансы:
Храните build.gradle и settings.gradle в корне проекта, а gradle.properties — в корне или ~/.gradle.
Используйте
gradle.properties для чувствительных данных (например, ключи API) с осторожностью, предпочтительно шифруйте их.
В многомодульных проектах каждый модуль имеет свой build.gradle, но общий settings.gradle.



Нюансы и внутренние механизмы

Управление памятью:
Gradle загружает модель проекта, задачи и зависимости в JVM. Groovy/Kotlin DSL увеличивают overhead из-за динамической компиляции.
Инкрементальность и кэширование снижают повторные вычисления, но требуют памяти для хранения хэшей и метаданных.
Настройте org.gradle.jvmargs в
gradle.properties для увеличения кучи: -Xmx2048m.

Кэширование:
Локальный кэш (~/.gradle/caches) хранит зависимости, плагины и результаты задач.
Build Cache (локальный или удаленный) минимизирует повторные сборки, но требует настройки и дискового пространства.
Очистка кэша: ./gradlew --stop и rm -rf ~/.gradle/caches.


Производительность:
Инкрементальная сборка и --parallel ускоряют выполнение, но увеличивают пиковое потребление памяти.
Используйте --no-daemon для одноразовых сборок, чтобы избежать постоянного процесса Gradle Daemon.


Отладка:
Флаг --info или --debug выводит подробные логи:./gradlew build --debug
Build Scans предоставляют визуальный анализ.
Используйте ./gradlew tasks для списка доступных задач.



Многомодульные проекты:
Gradle эффективно управляет модулями через settings.gradle, строя DAG для определения порядка сборки.
Используйте ./gradlew :module-name:task для выполнения задачи в конкретном модуле.


Совместимость:

Gradle требует JDK 8+ (рекомендуется 11+). Убедитесь, что JAVA_HOME указывает на правильный JDK.
Некоторые плагины Maven (например, maven-release-plugin) требуют адаптации для Gradle (например, nebula-release-plugin).


#Java #middle #Gradle
👍3
Области применения Java: Веб-приложения, мобильные приложения (Android), Big Data

1. Веб-приложения

Что такое веб-приложения?

Веб-приложения — это программы, которые работают через браузер (например, Google Chrome, Firefox) и доступны через интернет. Это могут быть интернет-магазины, социальные сети, системы управления контентом, банковские платформы и многое другое. Java широко используется для создания серверной части (backend) таких приложений, то есть той логики, которая обрабатывает запросы пользователей, взаимодействует с базами данных и обеспечивает работу сайта.

Почему Java для веб-приложений?

Java популярна в веб-разработке благодаря своей надежности, масштабируемости и большому количеству готовых инструментов.

Вот несколько причин:

Надежность: Java имеет строгую типизацию и встроенные механизмы обработки ошибок, что снижает вероятность багов.
Масштабируемость:
Java-приложения легко справляются с высокими нагрузками, что важно для крупных веб-сервисов.
Экосистема: Огромное количество фреймворков и библиотек упрощает разработку.



Основные инструменты для веб-разработки на Java
Spring Framework: Самый популярный фреймворк для создания веб-приложений. Spring Boot, его упрощённая версия, позволяет быстро создавать серверные приложения с минимальной настройкой. Например, с помощью Spring Boot вы можете создать REST API для мобильного приложения за пару часов.
Java EE (Jakarta EE): Платформа для создания корпоративных приложений. Она предоставляет API для работы с базами данных, веб-сервисами, транзакциями и многим другим.
Hibernate: ORM-фреймворк (Object-Relational Mapping), который упрощает взаимодействие с базами данных, позволяя работать с данными как с объектами
Java.
Servlets и JSP: Базовые технологии для обработки HTTP-запросов и создания динамических веб-страниц.


Примеры использования

Интернет-магазины: Платформы вроде eBay или Amazon используют Java (или аналогичные технологии) для обработки миллионов запросов.
Банковские системы:
Java применяется для создания безопасных и надежных систем интернет-банкинга.
Социальные сети: Серверная часть платформ, таких как LinkedIn, частично построена на
Java.


2. Мобильные приложения (Android)


Java и Android

Java долгое время была основным языком для разработки приложений под Android. Хотя сейчас Kotlin стал предпочтительным языком для Android-разработки (и он тоже работает на JVM!), Java всё ещё активно используется, особенно в крупных и устаревших проектах. Большинство приложений в Google Play Store, таких как мессенджеры, игры или утилиты, имеют код на Java.

Почему Java для Android?

Интеграция с Android SDK: Java была основным языком Android с момента его создания, и Android SDK (Software Development Kit) предоставляет богатый набор инструментов для работы с Java.
Кроссплатформенность:
Java-приложения для Android работают на миллиардах устройств благодаря JVM (в Android используется Dalvik или ART — аналоги JVM).
Большое сообщество: Огромное количество документации, примеров и библиотек для Android-разработки на
Java.

Как Java используется в Android?

Когда вы разрабатываете Android-приложение, вы пишете код на Java (или Kotlin), который взаимодействует с Android SDK. Этот код управляет интерфейсом, обрабатывает действия пользователя (например, нажатия на кнопки) и взаимодействует с аппаратными функциями устройства (камера, GPS, уведомления).


#Java #для_новичков #beginner
👍4
3. Big Data

Что такое Big Data?

Big Data — это обработка огромных объемов данных, которые невозможно обработать традиционными инструментами. Это может быть анализ логов, данных с датчиков IoT, пользовательской активности в интернете или финансовых транзакций. Java играет ключевую роль в Big Data благодаря своей производительности и мощным инструментам.

Почему Java для Big Data?

Производительность: Java обеспечивает высокую скорость обработки благодаря JIT-компиляции и оптимизации JVM.
Экосистема:
Java имеет множество фреймворков для работы с большими данными.
Масштабируемость:
Java-приложения легко масштабируются на кластерах из сотен или тысяч серверов.

Основные инструменты для Big Data на Java

Apache Hadoop: Платформа для распределенной обработки больших данных. Hadoop написан на
Java и используется для анализа больших наборов данных, например, логов веб-сайтов.
Apache Spark: Быстрая и универсальная платформа для обработки данных в реальном времени. Spark также написан на
Java (и Scala) и часто используется для машинного обучения и анализа данных.
Apache Kafka: Система для обработки потоков данных в реальном времени, например, для обработки сообщений или событий.
Elasticsearch: Поисковая и аналитическая система, которая используется для индексации и анализа больших объемов данных.

Примеры использования

Рекомендательные системы: Netflix и Amazon используют Java и Big Data-технологии для анализа поведения пользователей и рекомендаций фильмов или товаров.
Финансовый анализ: Банки используют Hadoop и Spark для обнаружения мошенничества и анализа транзакций.
IoT: Обработка данных с миллионов датчиков (например, в "умных" городах) часто выполняется с помощью
Java и Kafka.


Почему это важно для новичков?

Понимание областей применения Java даёт вам представление о том, где вы можете применить свои знания.

Java — это не просто язык, это инструмент для решения реальных задач:

Веб-приложения научат вас создавать серверную логику и работать с API.
Android-разработка позволит создавать приложения для миллиардов устройств.
Big Data откроет двери в мир анализа данных и машинного обучения.


#Java #для_новичков #beginner
👍4
Структура build-файла Gradle

Файл build.gradle (или build.gradle.kts) является основным конфигурационным файлом Gradle, определяющим, как собирать проект. Он состоит из ключевых блоков, которые задают плагины, репозитории, зависимости, задачи и конфигурации.

Основные элементы

Plugins:
Блок plugins определяет плагины, которые добавляют задачи, настройки и функциональность.

Пример (Groovy DSL):
plugins {
id 'java'
id 'org.springframework.boot' version '2.7.18'
}


Пример (Kotlin DSL):
plugins {
java
id("org.springframework.boot") version "2.7.18"
}


Плагины могут быть:
Core plugins (например, java, application): встроены в Gradle.
Community plugins: загружаются из репозиториев (например, Maven Central).


В памяти: Плагины загружаются как Java-классы в JVM, увеличивая потребление памяти пропорционально их зависимостям и сложности.


Repositories:
Указывают, откуда Gradle загружает зависимости и плагины (например, Maven Central, JCenter).

Пример:
repositories {
mavenCentral()
maven { url 'https://repo.example.com' }
}


В памяти: Gradle загружает метаданные репозиториев (POM-файлы, индексы) в память для разрешения зависимостей, что требует временного увеличения ресурсов.


Dependencies:
Определяют библиотеки и модули, необходимые проекту.


Пример:
dependencies {
implementation 'org.springframework:spring-core:5.3.20'
testImplementation 'junit:junit:4.13.2'
}


Конфигурации (например, implementation, testImplementation) определяют область видимости зависимостей (аналогично scope в Maven).
В памяти: Gradle строит граф зависимостей (Directed Acyclic Graph, DAG), хранящий метаданные каждой зависимости. Это увеличивает потребление памяти, особенно для крупных проектов.



Tasks:
Задачи — это атомарные единицы работы (например, компиляция, тестирование).

Пример кастомной задачи:
task hello {
doLast {
println 'Hello, Gradle!'
}
}


Задачи могут зависеть друг от друга через dependsOn:task build(dependsOn:
['test', 'jar']) {
doLast { println 'Building project' }
}


В памяти: Каждая задача представлена как объект в JVM, содержащий конфигурацию, зависимости и действия. Gradle хранит DAG задач в памяти, что увеличивает overhead для сложных проектов.


Configurations:
Конфигурации определяют группы зависимостей для разных целей (например, implementation для компиляции, testImplementation для тестов).

Пример:
configurations {
customConfig
}
dependencies {
customConfig 'com.example:library:1.0'
}


В памяти: Конфигурации хранятся как часть графа зависимостей, добавляя метаданные для каждой группы. Это увеличивает объем памяти, особенно при использовании кастомных конфигураций.


Пример полного build.gradle
plugins {
id 'java'
id 'org.springframework.boot' version '2.7.18'
}
repositories {
mavenCentral()
}
dependencies {
implementation 'org.springframework.boot:spring-boot-starter'
testImplementation 'junit:junit:4.13.2'
}
tasks.register('customTask') {
doLast {
println 'Custom task executed'
}
}


В памяти: Файл build.gradle парсится в объектную модель, включающую плагины, зависимости и задачи. Groovy DSL требует загрузки Groovy-библиотек, а Kotlin DSL — Kotlin-библиотек, что увеличивает потребление памяти.


#Java #middle #Gradle #Build_gradle
👍4
Скриптовый движок (Groovy/Kotlin)

Gradle использует два языка для описания сборки:

Groovy DSL:
Основан на Groovy, динамически типизированном языке.
Преимущества: Простота, лаконичный синтаксис, широкая совместимость.
Недостатки: Ошибки могут обнаруживаться только на этапе выполнения из-за динамической типизации.


Пример:
dependencies {
implementation 'org.springframework:spring-core:5.3.20'
}


Kotlin DSL:
Основан на Kotlin, статически типизированном языке.
Преимущества: Автодополнение в IDE, раннее обнаружение ошибок, лучшая интеграция с Kotlin-проектами.
Недостатки: Более строгий синтаксис, требует знания Kotlin.


Пример:
dependencies {
implementation("org.springframework:spring-core:5.3.20")
}



В памяти: Groovy DSL компилируется динамически, загружая Groovy-библиотеки (например, groovy-all) в JVM, что увеличивает потребление памяти (около 50-100 МБ дополнительно). Kotlin DSL требует загрузки Kotlin-библиотек (kotlin-stdlib, kotlin-scripting), что добавляет аналогичный overhead, но статическая типизация снижает вероятность ошибок. Gradle кэширует результаты парсинга в ~/.gradle/caches для ускорения повторных сборок.



Gradle Project Object Model

Gradle Project Object Model (POM, не путать с Maven POM) — это внутренняя модель, представляющая проект в памяти.

Она включает:
Project: Корневой объект, содержащий свойства (group, name, version), задачи, зависимости и плагины.
Tasks: Объекты задач, связанные через DAG.
Dependencies: Граф зависимостей, организованный по конфигурациям.
Properties: Свойства проекта, доступные через ${
project.property}.
Subprojects: Для многомодульных проектов, каждый подпроект имеет свою модель.


Пример доступа:
println project.name
println project.version


В памяти: Gradle загружает модель проекта в JVM во время фазы конфигурации (см. ниже). Для многомодульных проектов каждый подпроект создает отдельную модель, увеличивая потребление памяти пропорционально количеству модулей. Кэширование метаданных в ~/.gradle/caches снижает повторные вычисления



Gradle Lifecycle Overview: Initialization → Configuration → Execution

Gradle выполняет сборку в три фазы:

Initialization:
Gradle загружает settings.gradle для определения структуры проекта (корневое имя, модули).
Создает объекты Project для корневого проекта и подпроектов.

В памяти: Загружаются settings.gradle и плагины, необходимые для инициализации. Это минимальная фаза по потреблению памяти.


Configuration:
Gradle парсит все build.gradle-файлы, создавая модель проекта и DAG задач.
Выполняются все скрипты конфигурации, даже для задач, которые не будут выполняться.
Пример: Определение зависимостей и задач в build.gradle.

В памяти: Самая ресурсоемкая фаза, так как Gradle загружает и компилирует все скрипты, плагины и зависимости. Для крупных проектов может потребоваться несколько сотен МБ.


Execution:
Gradle выполняет задачи, указанные в командной строке (например, ./gradlew build), в порядке, определенном DAG.
Инкрементальность пропускает задачи, чьи входные/выходные данные не изменились.

В памяти: Зависит от сложности задач. Например, compileJava загружает исходные файлы и зависимости, а test — тестовые классы и фреймворки.


Нюансы:
Конфигурация выполняется всегда, даже если задачи не запускаются, что увеличивает время инициализации.
Используйте флаг --configure-on-demand для конфигурации только необходимых модулей:./gradlew build --configure-on-demand
Gradle Daemon сохраняет JVM между сборками, ускоряя повторные запуски, но увеличивая базовое потребление памяти.



#Java #middle #Gradle #Build_gradle
👍4
Gradle Properties

Gradle поддерживает свойства на разных уровнях, которые используются для настройки сборки.

Project-level:
Определяются в build.gradle или settings.gradle.

Пример:
version = '1.0.0'
ext.myProperty = 'value'


Доступ:
project.version, project.myProperty.


System-level:
Задаются через командную строку (-D) или gradle.properties.
Пример (
gradle.properties):org.gradle.jvmargs=-Xmx2048m

Доступ:
System.getProperty('org.gradle.jvmargs').

Environment-level:
Переменные окружения, доступные через System.getenv().
Пример:println System.getenv('JAVA_HOME')


Приоритет: Свойства командной строки (-D) > gradle.properties > свойства проекта > переменные окружения.
В памяти: Свойства загружаются как часть модели проекта или JVM, требуя минимальных ресурсов. Однако большое количество свойств в gradle.properties увеличивает время парсинга.



Различия Groovy DSL и Kotlin DSL
Groovy DSL
Kotlin DSL



Файл
build.gradle
build.gradle.kts

Типизация
Динамическая
Статическая


Синтаксис
Лаконичный, гибкий
Более строгий, с явными типами


IDE-поддержка
Хорошая, но ограниченное автодополнение
Отличная, с сильным автодополнением


Пример зависимости

implementation 'org.example:lib:1.0'
implementation("org.example:lib:1.0")


Ошибки

Обнаруживаются на этапе выполнения
Обнаруживаются на этапе компиляции


Производительность
Быстрее парсинг, но больше памяти на Groovy
Медленнее парсинг, но меньше ошибок


В памяти: Kotlin DSL требует загрузки Kotlin-библиотек, что увеличивает потребление памяти на 50-100 МБ по сравнению с Groovy. Однако статическая типизация снижает вероятность ошибок, что может уменьшить затраты на отладку.


Рекомендации:

Используйте Groovy для простых проектов или совместимости с существующими скриптами.
Выберите Kotlin для новых проектов, особенно если команда использует Kotlin или требуется строгая типизация.



#Java #middle #Gradle #Build_gradle
👍3
Распределение конфигурации: build.gradle, settings.gradle, gradle.properties

build.gradle:
Содержит конфигурацию сборки: плагины, зависимости, задачи.
Один файл на модуль в многомодульных проектах.
Роль: Определяет, как собирать проект или модуль.


В памяти: Парсится в модель проекта, включая DAG задач и граф зависимостей.


settings.gradle:
Определяет структуру проекта: корневое имя, подмодули, настройки кэширования.

Пример:

rootProject.name = 'my-project'
include 'module-api', 'module-core'


Роль: Управляет инициализацией многомодульного проекта.


В памяти: Загружается первым, формируя модель проекта и граф модулей. Меньше по объему, чем build.gradle.


gradle.properties:
Хранит свойства для настройки Gradle, JVM и проекта.
Пример:

org.gradle.parallel=true
myVersion=1.0.0


Роль: Централизует глобальные настройки, доступные всем модулям.


В памяти: Загружается как часть конфигурации Gradle, минимально влияя на память.


Распределение конфигурации:
Общие настройки: Храните в gradle.properties (например, JVM-аргументы, версии).
Структура проекта: Определяйте в settings.gradle (модули, кэш).
Логика сборки: Описывайте в build.gradle (задачи, зависимости).


Нюансы:
Для многомодульных проектов используйте allprojects или subprojects в build.gradle для общих настроек:
allprojects {
repositories {
mavenCentral()
}
}


Храните чувствительные данные (например, ключи API) в ~/.gradle/
gradle.properties с ограниченными правами доступа.

В памяти: Конфигурационные файлы загружаются последовательно: gradle.properties → settings.gradle → build.gradle. Gradle кэширует результаты парсинга в ~/.gradle/caches, снижая overhead при повторных сборках.
Нюансы и внутренние механизмы


Управление памятью:
Gradle загружает модель проекта, задачи и зависимости в JVM. Для крупных проектов с сотнями задач и зависимостей потребление памяти может достигать 1-2 ГБ.
Groovy/Kotlin DSL увеличивают overhead из-за динамической/статической компиляции.
Gradle Daemon сохраняет JVM между сборками, ускоряя выполнение, но увеличивая базовое потребление памяти (около 200-300 МБ).
Оптимизируйте с помощью org.gradle.jvmargs=-Xmx2048m и --no-daemon для одноразовых сборок.


Кэширование:

Локальный кэш (~/.gradle/caches) хранит зависимости, плагины и результаты задач, снижая сетевые запросы.
Build Cache (локальный или удаленный) минимизирует повторные вычисления, но требует настройки и дискового пространства.
Очистка кэша: ./gradlew --stop и rm -rf ~/.gradle/caches.


Производительность:
Инкрементальная сборка пропускает неизмененные задачи, проверяя хэши входных/выходных данных.
Параллельное выполнение (--parallel) ускоряет многомодульные проекты, но увеличивает пиковое потребление памяти.
Используйте --configure-on-demand для сокращения времени конфигурации.


Отладка:
Флаг --info или --debug выводит подробные логи:./gradlew build --debug
Используйте ./gradlew tasks для списка задач или ./gradlew dependencies для анализа зависимостей.
Build Scans предоставляют визуальный анализ сборки.


Многомодульные проекты:
Gradle эффективно управляет модулями через settings.gradle, строя DAG для определения порядка сборки.
Выполняйте задачи для конкретного модуля: ./gradlew :module-name:build.


Совместимость:
Gradle требует JDK 8+ (рекомендуется 11+). Убедитесь, что JAVA_HOME указывает на правильный JDK.
Некоторые Maven-плагины требуют аналогов в Gradle (например, nebula-release-plugin вместо maven-release-plugin).



#Java #middle #Gradle #Build_gradle
👍4
Как установить JDK

Что такое JDK и зачем он нужен?

JDK (Java Development Kit) — это комплект инструментов для разработки, компиляции и отладки Java-программ.

Он включает:
Компилятор (javac) для преобразования кода в байт-код.
Среда выполнения
Java (JRE), которая содержит JVM для запуска программ.
Утилиты, такие как javadoc (для документации) и jar (для создания архивов).


LTS-версии (17, 21, 24) рекомендуются для обучения и работы, так как они поддерживаются Oracle и сообществом в течение многих лет. На момент июля 2025 года Java 24 — самая новая LTS-версия, но Java 17 и 21 также популярны в проектах.

Шаг 1: Выберите и скачайте JDK

Существует два основных варианта JDK: Oracle JDK и OpenJDK. Для новичков я рекомендую OpenJDK, так как он бесплатный, open-source и подходит для большинства задач.

Вот как скачать JDK:

Перейдите на сайт
Для OpenJDK: посетите
https://jdk.java.net.
Для Oracle JDK: посетите
https://www.oracle.com/java/technologies/javase-downloads.html.

Выберите версию:
На сайте OpenJDK найдите разделы для Java 17, 21 или 24 (LTS). Например, для Java 21 это может быть OpenJDK 21.
Для Oracle JDK выберите нужную версию из списка загрузок.


Выберите вашу операционную систему:
Windows: .zip или .exe (для Oracle JDK).
macOS: .tar.gz или .dmg.
Linux: .tar.gz или пакеты для дистрибутивов (например, .deb для Ubuntu).


Скачайте файл:
Для OpenJDK выберите архив или установщик для вашей системы.
Для Oracle JDK вам может потребоваться создать учетную запись Oracle и принять лицензионное соглашение.


Совет: Если вы не уверены, какую версию выбрать, начните с OpenJDK 17 — она наиболее распространена в учебных и рабочих проектах.



Шаг 2: Установка JDK

Для Windows

Скачайте и запустите установщик:
Если вы выбрали Oracle JDK, запустите .exe и следуйте инструкциям мастера установки. Обычно достаточно нажать «Next» и выбрать папку установки (например, C:\Program Files\Java\jdk-17).
Для OpenJDK скачайте .zip, распакуйте его в папку, например, C:\Program Files\
Java\jdk-17.

Настройте переменную PATH:
Найдите папку, где установлен JDK (например, C:\Program Files\Java\jdk-17\bin).
Добавьте её в системную переменную PATH:
Нажмите Win + R, введите sysdm.cpl и нажмите Enter.
Перейдите во вкладку «Дополнительно» → «Переменные среды».
В разделе «Системные переменные» найдите или создайте переменную PATH, добавьте путь к папке bin вашего JDK (например, C:\Program Files\
Java\jdk-17\bin).

Создайте переменную JAVA_HOME:

В «Системных переменных» нажмите «Создать», укажите имя JAVA_HOME и значение — путь к папке JDK (например, C:\Program Files\Java\jdk-17).

Проверьте установку:
Откройте командную строку (Win + R → cmd).
Введите
java -version и javac -version. Вы должны увидеть информацию о версии Java и компилятора, например:
openjdk version "17.0.8" 2023-07-18
OpenJDK Runtime Environment (build 17.0.8+7)
javac 17.0.8


Для macOS

Скачайте и установите JDK:
Для Oracle JDK: запустите .dmg и следуйте инструкциям установщика.
Для OpenJDK: скачайте .tar.gz, распакуйте его в папку, например, /Library/
Java/JavaVirtualMachines/jdk-17.

Настройте переменную PATH:
Откройте терминал.
Отредактируйте файл профиля (например, ~/.zshrc для zsh или ~/.bashrc для bash):
nano ~/.zshrc


Добавьте строки:
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk-17
export PATH=$JAVA_HOME/bin:$PATH
(Замените путь на актуальный, если он отличается.)


Сохраните файл и выполните:
source ~/.zshrc


Проверьте установку:
В терминале введите java -version и javac -version. Вы должны увидеть информацию о версии, например:
openjdk version "17.0.8" 2023-07-18
OpenJDK Runtime Environment (build 17.0.8+7)
javac 17.0.8


#Java #для_новичков #beginner #JDK_install
👍4
Для Linux (на примере Ubuntu)

Установите JDK:
Через пакетный менеджер (рекомендуется для простоты):
sudo apt update
sudo apt install openjdk-17-jdk


Для Java 21 или 24 замените openjdk-17-jdk на openjdk-21-jdk или openjdk-24-jdk, если они доступны в репозитории.

Через архив:
Скачайте .tar.gz с сайта OpenJDK.
Распакуйте в /usr/lib/jvm/:
sudo tar -xzf jdk-17.tar.gz -C /usr/lib/jvm/


Настройте переменную JAVA_HOME:
sudo nano /etc/environment


Добавьте:

JAVA_HOME="/usr/lib/jvm/jdk-17"


Обновите PATH:
nano ~/.bashrc


Добавьте:
export PATH=$JAVA_HOME/bin:$PATH


Примените изменения:
source ~/.bashrc


Проверьте установку:
В терминале выполните:
java -version
javac -version


Ожидаемый вывод:
openjdk version "17.0.8" 2023-07-18
OpenJDK Runtime Environment (build 17.0.8+7)
javac 17.0.8



Шаг 3: Проверка и первые шаги

Напишите простую программу:
Создайте файл HelloWorld.java:
public class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello, World!");
}
}


Скомпилируйте и запустите:
В терминале или командной строке перейдите в папку с файлом:
cd путь/к/папке


Скомпилируйте:
javac HelloWorld.java


Запустите:
java HelloWorld


Ожидаемый вывод:
Hello, World!


Если возникли ошибки:
Убедитесь, что JAVA_HOME и PATH настроены правильно.
Проверьте, что вы используете правильную версию JDK (
java -version и javac -version).
Убедитесь, что файл называется точно
HelloWorld.java (с учётом регистра).

#Java #для_новичков #beginner #JDK_install
🔥4
Зависимости и конфигурации в Gradle

Dependency Configurations

Конфигурации в Gradle определяют группы зависимостей, используемых для разных целей (компиляция, выполнение, тестирование). Они заменяют концепцию scope в Maven, предоставляя более гибкий подход.


Основные конфигурации

implementation:
Используется для зависимостей, необходимых для компиляции и выполнения кода проекта.
Не транзитивны для потребителей (в отличие от api).


Пример:
dependencies {
implementation 'org.springframework:spring-core:5.3.20'
}

Использование: Для внутренних зависимостей, которые не должны быть видны внешним модулям.


api:
Используется для зависимостей, которые становятся частью публичного API модуля и транзитивно передаются потребителям.
Применяется в основном в плагине
java-library.

Пример:
plugins {
id 'java-library'
}
dependencies {
api 'org.apache.commons:commons-lang3:3.12.0'
}

Использование: Для библиотек, которые должны быть доступны в classpath потребителей (например, интерфейсы или DTO).


compileOnly:
Зависимости, необходимые только для компиляции, но не для выполнения.
Аналог provided в Maven.

Пример:
dependencies {
compileOnly 'javax.servlet:javax.servlet-api:4.0.1'
}

Использование: Для API, предоставляемых контейнером (например, Servlet API в веб-приложениях).


runtimeOnly:
Зависимости, необходимые только для выполнения, но не для компиляции.
Аналог runtime в Maven.


Пример:
dependencies {
runtimeOnly 'mysql:mysql-connector-java:8.0.28'
}

Использование: Для драйверов баз данных или библиотек, используемых только во время выполнения.


testImplementation:
Зависимости для компиляции и выполнения тестов.
Не транзитивны для основного кода.


Пример:
dependencies {
testImplementation 'junit:junit:4.13.2'
}

Использование: Для тестовых фреймворков и библиотек.


В памяти: Каждая конфигурация представлена как объект в модели Gradle, содержащий список зависимостей и их метаданные. Gradle хранит граф зависимостей в памяти как Directed Acyclic Graph (DAG), что увеличивает потребление памяти пропорционально количеству зависимостей и конфигураций.


Конфигурации в деталях: configurations {}
Gradle позволяет определять кастомные конфигурации через блок configurations для специфических нужд.

Пример:
configurations {
customConfig
}
dependencies {
customConfig 'com.example:library:1.0'
}
tasks.register('useCustomConfig') {
doLast {
configurations.customConfig.each { file ->
println "Using ${file.name}"
}
}
}

Назначение: Кастомные конфигурации позволяют группировать зависимости для нестандартных задач, таких как интеграционные тесты или обработка ресурсов.


Расширение конфигураций: Конфигурации могут наследовать друг от друга:
configurations {
customConfig.extendsFrom implementation
}

Это добавляет все зависимости implementation в customConfig.


В памяти: Кастомные конфигурации увеличивают объем графа зависимостей, так как Gradle создает дополнительные объекты для каждой конфигурации. Это требует больше памяти, особенно если конфигурации содержат много транзитивных зависимостей.


#Java #middle #Gradle #Configuration_gradle
👍3