Java | Фишки и трюки
7.21K subscribers
182 photos
29 videos
6 files
40 links
Java: примеры кода, интересные фишки и полезные трюки

Купить рекламу: https://telega.in/c/java_tips_and_tricks

✍️По всем вопросам: @Pascal4eg
Download Telegram
⌨️ Launch4j — это кроссплатформенный инструмент для упаковки Java-приложений, распространяемых в виде jar-файлов, в облегченные собственные исполняемые файлы Windows, Linux и Mac OS X. Исполняемый файл можно настроить для поиска определенной версии JRE или использования встроенной версии, а также можно установить параметры времени выполнения, такие как начальный/максимальный размер кучи.

Некоторые особенности:

👉 Пользовательский значок приложения с несколькими разрешениями и глубиной цвета.

👉 Собственный экран-заставка до JRE, отображаемый до запуска приложения Java.

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

👉 Поддерживает графический интерфейс и консольные приложения.

👉 Передаёт аргументы командной строки

👉 Легкий вес: 62 КБ.

👉 Это бесплатно и может использоваться в коммерческих целях.
Please open Telegram to view this post
VIEW IN TELEGRAM
12🔥4❤‍🔥1👍1🎄1💘1
⌨️ JDBC, Java DataBase Connectivity (соединение с базами данных на Java) — промышленный стандарт взаимодействия Java-приложений с различными СУБД. Реализован в виде пакета java.sql, входящего в состав Java SE.

JDBC основан на концепции драйверов, которые позволяют получать соединение с базой данных по специально описанному URL. При загрузке драйвер регистрирует себя в системе и в дальнейшем автоматически вызывается, когда программа требует URL, содержащий протокол, за который этот драйвер отвечает.

Преимущества JDBC:

👉 Лёгкость разработки: разработчик может не знать специфики базы данных, с которой работает;

👉 Код практически не меняется, если компания переходит на другую базу данных (количество изменений зависит исключительно от различий между диалектами SQL);

👉 Не нужно дополнительно устанавливать клиентскую программу;

👉 К любой базе данных можно подсоединиться через легко описываемый URL.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍11❤‍🔥3🔥1🆒1
😁26🤩3🤗1🤪1
double d = 1 / 3;
System.out.print(d);
👍61🔥1
Что выведет код?
Anonymous Quiz
25%
0.0
72%
0.3333333333333333
3%
3
🤯12🙈9😱4🔥2👾1
Принцип программирования YAGNI — «Вам это не понадобится»

Cледование данному принципу заключается в том, что возможности, которые не описаны в требованиях к системе, просто не должны реализовываться. Это позволяет вести разработку, руководствуясь экономическими критериями: Заказчик не должен оплачивать ненужные ему функции, а разработчики не должны тратить своё оплачиваемое время на реализацию того, что не требуется.

Основная проблема, которую решает принцип YAGNI — это устранение тяги программистов к излишней абстракции, к экспериментам «из интереса» и к реализации функционала, который сейчас не нужен, но, по мнению разработчика, может вскоре понадобиться или просто будет полезен, хотя в реальности такого часто не происходит.

«Бесплатных» функций в программных продуктах просто не бывает. Если рассматривать материальную сторону, то любые ненужные, но фактически реализованные «фичи» оплачиваются либо заказчиком (в бюджет закладываются расходы на те функции, которые не нужны), либо исполнителем из прибыли по проекту. И тот, и другой варианты с точки зрения бизнеса неверны. Если же говорить о нематериальных затратах, то любые «бонусные» возможности усложняют сопровождение, увеличивают вероятность ошибок и усложняют взаимодействие с продуктом, — между объёмом кодовой базы и описанными характеристиками есть прямая зависимость. Больше написанного кода — труднее сопровождать и выше вероятность появления «багов», тут очень уместна поговорка: «лучший код — это ненаписанный код».

Принципы YAGNI и KISS очень похожи, если KISS нацелен на упрощение и полезен в плане работы с теми требованиями, которые имеют место быть, то YAGNI более категоричен и применяется для ограждения проектов по разработке ПО от «размывания» их рамок.

Подход к реализации проектов строго по ТЗ бывает верен с нескольких ракурсов: заказчик не должен платить за то, что ему не надо, а продукт должен быть максимально сопровождаем и его качество не должно страдать от реализации ненужных функций.
🔥10👍3💯21🤝1
Что выведет код?
Anonymous Quiz
48%
0
14%
-2024
5%
1
32%
Ошибка компиляции
👍6😱4🥰1🤗1
Реализация стека с помощью интерфейса Deque

Deque
(Double-ended queue) представляет собой интерфейс, который расширяет функциональность обычной очереди (Queue). Он позволяет добавлять и удалять элементы как в начале, так и в конце очереди. Deque является частью Java Collections Framework и введен в Java 6.

Так же, Deque содержит методы для работы со стеком:

// помещает элемент в стек.
void push(E e);

// извлекает элемент из стека.
E pop();


Deque реализуется различными классами, такими как LinkedList и ArrayDeque. Выбор конкретной реализации зависит от требований к производительности и использования памяти.
👍93🔥2👏1
⌨️ Что такое статическое и динамическое связывание?

Присоединение вызова метода к телу метода называется связыванием. Если связывание проводится компилятором (компоновщиком) перед запуском программы, то оно называется статическим или ранним связыванием (early binding).

В свою очередь, позднее связывание (late binding) это связывание, проводимое непосредственно во время выполнения программы, в зависимости от типа объекта. Позднее связывание также называют динамическим (dynamic) или связыванием на стадии выполнения (runtime binding). В языках, реализующих позднее связывание, должен существовать механизм определения фактического типа объекта во время работы программы, для вызова подходящего метода. Иначе говоря, компилятор не знает тип объекта, но механизм вызова методов определяет его и вызывает соответствующее тело метода. Механизм позднего связывания зависит от конкретного языка, но нетрудно предположить, что для его реализации в объекты должна включаться какая-то дополнительная информация.

Для всех методов Java используется механизм позднего (динамического) связывания, если только метод не был объявлен как final, static или private (приватные методы являются final по умолчанию).
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7🔥21
JSON Web Token (JWT) — это открытый стандарт (RFC 7519) для создания токенов доступа, основанный на формате JSON. Как правило, используется для передачи данных для аутентификации в клиент-серверных приложениях. Токены создаются сервером, подписываются секретным ключем и передаются клиенту, который в дальнейшем использует данный токен для подтверждения подлинности аккаунта.

JWT состоит из трех частей, разделенных точкой: заголовок (Header), полезная нагрузка (Payload), и подпись (Signature). Каждая часть представлена в кодировке Base64.

Header содержит два элемента - тип токена (typ) и алгоритм хеширования (alg). Тип токена обычно установлен в "JWT", а алгоритм хеширования указывает, как будет создана подпись.

Payload содержит данные о пользователе, например идентификатор, имя и прочие.

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

В клиент-серверных приложениях используются два вида токена:

Access-токен — это токен, который предоставляет доступ его владельцу к защищённым ресурсам сервера. Обычно он имеет короткий срок жизни и может нести в себе дополнительную информацию, такую как IP-адрес стороны, запрашивающей данный токен.

Refresh-токен — это токен, позволяющий клиентам запрашивать новые access-токены по истечении их времени жизни. Данные токены обычно выдаются на длительный срок.

Как правило, при использовании JSON-токенов в клиент-серверных приложениях реализована следующая схема:

1️⃣ Клиент проходит аутентификацию в приложении (к примеру, с использованием логина и пароля).

2️⃣ В случае успешной аутентификации сервер отправляет клиенту access- и refresh-токены.

3️⃣ При дальнейшем обращении к серверу клиент использует access-токен. Сервер проверяет токен на валидность и предоставляет клиенту доступ к ресурсам.

4️⃣ В случае, если access-токен становится невалидным, клиент отправляет refresh-токен, в ответ на который сервер предоставляет два обновлённых токена.

5️⃣ В случае, если refresh-токен становится невалидным, клиент опять должен пройти процесс аутентификации.

JWT позволяет создавать безопасные механизмы аутентификации и авторизации без необходимости сохранения состояния сессии на сервере. Он также широко используется в распределенных системах и при создании микросервисов для передачи данных о субъекте (пользователе) между различными компонентами системы.
👍161🔥1🏆1👨‍💻1
⌨️ API (Application Programming Interface, интерфейс программирования приложения) — программный интерфейс, то есть описание способов взаимодействия одной компьютерной программы с другими. (В противоположность пользовательскому интерфейсу, используемому для взаимодействия конечного пользователя с программой.) Обычно входит в описание какого-либо интернет-протокола, программного каркаса (фреймворка) или стандарта вызовов функций операционной системы. Часто реализуется отдельной программной библиотекой или сервисом операционной системы. Используется программистами при написании всевозможных приложений.

Проще говоря, это способ взаимодействия какого-то программного кода с набором каких-то программных компонентов, с помощью которых одна компьютерная программа (например, бот или сайт) может использовать другую программу.

Если программу (модуль, библиотеку) рассматривать как чёрный ящик, то API — это набор «ручек», которые доступны пользователю данного ящика и которые он может вертеть и переключать.

Примеры API: Windows API, DirectX (DirectDraw/Direct3D), Vulkan.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍91🔥1👏1🤝1
😁16💯8🤣42🔥2👏2
⌨️ Как сравнивать элементы enum: equals() или == ?

Можно и так и так. Если посмотреть реализацию equals() в Enum, то мы там увидим сравнение через ==

public final boolean equals(Object other) {
return this==other;
}


При сравнении через ==, мы застрахуем себя от NullPointerException.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍13🔥31
⌨️ Чем абстрактный класс отличается от интерфейса? В каких случаях следует использовать абстрактный класс, а в каких интерфейс?

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

1️⃣ Абстрактный класс (Abstract
Class):

👉 Может содержать как абстрактные методы (методы без тела), так и обычные методы с реализацией.
👉 Может иметь переменные экземпляра (поля).
👉 Может содержать конструкторы.
👉 Поддерживает одиночное наследование: подкласс можно наследовать только от одного абстрактного класса.


abstract class Animal {
String name;

abstract void makeSound();

void eat() {
System.out.println(name + " is eating.");
}
}


2️⃣ Интерфейс (Interface):

👉 Содержит только абстрактные методы (в Java 8 и выше может содержать методы с реализацией, помеченные ключевым словом default).
👉 Не может иметь переменных экземпляра, кроме переменных, объявленных как static final.
👉 Не содержит конструкторов.
👉 Поддерживает множественное наследование: класс может реализовывать несколько интерфейсов.


interface Animal {
void makeSound();
void eat();
}


Когда использовать:

👉 Используйте абстрактные классы, когда у вас есть общая реализация для нескольких классов и вы хотите предоставить базовый функционал.

👉 Используйте интерфейсы, когда вам нужна поддержка множественного наследования, или когда классы, возможно, уже наследуют от других классов.

Обычно считается хорошей практикой использовать интерфейсы для определения контракта и абстрактные классы для предоставления базовой реализации. В Java 8 и более новых версиях с появлением интерфейсов с методами по умолчанию (default methods), различия стали менее явными, и выбор может зависеть от конкретной ситуации.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍162👎1🔥1🤡1🥴1🏆1👨‍💻1
Считывание файла из стандартного потока ввода

Перенаправление ввода-вывода — возможность командной оболочки ряда операционных систем перенаправлять стандартные потоки в определённое пользователем место, например, в файл. Характерна для Unix-подобных операционных систем, но в разной степени реализована и в операционных системах других семейств.

Перенаправление обычно осуществляется вставкой специального символа > или < после команды.
Обычно синтаксис выглядит так:

команда1 > файл1 — выполняет команду1, помещая стандартный вывод в файл1;

команда1 < файл1 — выполняет команду1, используя в качестве источника ввода файл1 (вместо клавиатуры).

Для перенаправления содержимого файла в поток ввода нашего приложения воспользуемся командой:

java -jar app.jar < file.txt
5❤‍🔥2👍2💘1
⌨️ Использование аннотаций. Аннотации позволяют добавлять метаданные к вашему коду, что может быть полезно для документирования, тестирования и других целей. Вот пример использования аннотации:

import java.lang.annotation.*;

// Создание аннотации
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
@interface MethodInfo {
String author() default "unknown";
String date();
int revision() default 1;
String comments();
}

public class Example {
// Использование аннотации
@MethodInfo(author = "John Doe", date = "2022-08-15", comments = "Example method")
public void performAction() {
// Реализация метода
}
}


В этом примере создается аннотация MethodInfo с параметрами author, date, revision и comments. Затем аннотация применяется к методу performAction. Таким образом, аннотации могут использоваться для предоставления дополнительной информации о вашем коде, что может быть полезно при разработке, тестировании и поддержке проекта.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥10👍31💯1
Методы и конструкторы в enum

Перечисления (enum) — это классы Java, определяющие наборы констант. Самый простой enum выглядит так:


public enum Vehicle { CAR, BUS, BICYCLE, SCOOTER }


Но на самом деле, enum в Java обладают гораздо более широким функционалом. Они поддерживают поля, методы, интерфейсы и т.д. Они также Comparable и Serializable и могут имплементировать все методы объекта.
Для наглядности давайте создадим enum Animal и присвоим каждому элементу цвет:

public enum Animal {
DOG("black"),
CAT("white"),
RAT("gray");

private final String color;
Animal(String color){
this.color = color;
}
public String getColor(){
return color;
}
}


Теперь мы можем выполнить перебор элементов массива с помощью статического метода values():

public class Main {
public static void main(String[] args) {
for (Animal a : Animal.values()) {
System.out.println(a.name() + " - " + a.getColor());
}
}
}


Мы получим следующий результат:

DOG - black
CAT - white
RAT - gray


Каждой константе можно присвоить разное поведение при выполнении определенного метода. Например, можно сделать основной метод абстрактным и переопределить его в каждой константе:

public enum Operation {
PLUS { double evaluate(double x, double y) { return x + y; } },
MINUS { double evaluate(double x, double y) { return x - y; } },
abstract double evaluate(double x, double y);
}


Всё это обеспечивает удобную работу с перечислениями в Java.
👍272🔥2🥰2👏1
JSON – невероятно удобный и полезный формат для хранения и обмена данными. Java полностью поддерживает его.

Сериализовать данные можно так:

JSONObject author = new JSONObject();
author.put("name", "J. K. Rowling");
author.put("numberOfBooks", 22);

JSONArray books = new JSONArray();
books.put("Harry Potter and the Philosopher's Stone");
books.put("Harry Potter and the Chamber of Secrets");
books.put("Harry Potter and the Prisoner of Azkaban");

author.put("books", books);
System.out.print(author);


Получится вот такая JSON-строка:

{"books":["Harry Potter and the Philosopher's Stone","Harry Potter and the Chamber of Secrets","Harry Potter and the Prisoner of Azkaban"],"name":"J. K. Rowling","numberOfBooks":22}


Десериализация на Java выглядит примерно так:

JSONObject author = new JSONObject(serializedString);
System.out.println("name: " + author.get("name"));
System.out.println("numberOfBooks: " + author.get("numberOfBooks"));

JSONArray books = (JSONArray) author.get("books");
Iterator<Object> i = books.iterator();
System.out.println("books:");
while (i.hasNext()) {
System.out.println(i.next());
}


Нужно добавить зависимость:

<dependency>
<groupId>org.json</groupId>
<artifactId>json</artifactId>
<version>20231013</version>
</dependency>
👍16🔥64
Array vs ArrayList

Выбор между Array и ArrayList зависит от специфики задачи на Java, которую требуется решить.

📌Помните о следующих особенностях этих типов:

• Array имеет фиксированный размер и память для него выделяется в момент объявления, а размер ArrayLists может динамически изменяться.

• Массивы Java работают гораздо быстрее, а в ArrayList намного проще добавлять/удалять элементы.

• При работе с Array велика вероятность получить ошибку ArrayIndexOutOfBoundsException.

• У ArrayList только одно измерение, а вот массивы Java могут быть многомерными.

import java.util.ArrayList;

public class arrayVsArrayList {

public static void main(String[] args) {

// объявление Array
int[] myArray = new int[6];

// обращение к несуществующему индексу
myArray[7]= 10; // ArrayIndexOutOfBoundsException

// объявление ArrayList
ArrayList<Integer> myArrayList = new ArrayList<>();

// простое добавление и удаление элементов
myArrayList.add(1);
myArrayList.add(2);
myArrayList.add(3);
myArrayList.add(4);
myArrayList.add(5);
myArrayList.remove(0);

// получение элементов ArrayList
for(int i = 0; i < myArrayList.size(); i++) {
System.out.println("Element: " + myArrayList.get(i));
}

// многомерный Array
int[][][] multiArray = new int [3][3][3];
}
}
👍161👎1🔥1🤗1