Java | Фишки и трюки
Open in Telegram
Java: примеры кода, интересные фишки и полезные трюки Купить рекламу: https://telega.in/c/java_tips_and_tricks ✍️По всем вопросам: @Pascal4eg Менеджер по рекламе: @shmyzna
Show more6 951
Subscribers
-324 hours
-127 days
+1230 days
Posts Archive
6 950
Telegram-канал об IT-решениях для бизнеса СофтТех
Друзья, не пропустите важную информацию!
Канал СофтТех рассказывает об IT-решениях для бизнеса и тех, кто их создаёт: ПО и кибербезопасность, облачные технологии, ЦОДы и IoT.
Сами давно читаем и вам советуем подписаться.
Подписаться
#реклама
О рекламодателе
6 950
class Cache {
private static int sum = 0;
static {
initializeIfNecessary();
}
public static int getSum() {
initializeIfNecessary();
return sum;
}
private static boolean initialized = false;
private static synchronized void initializeIfNecessary() {
if (!initialized) {
for (int i = 0; i < 5; i++)
sum += i;
initialized = true;
}
}
}
class Client {
public static void main(String[] args) {
System.out.println(Cache.getSum());
}
}6 950
🔥 Это база с 1700 вопросами с собеседований на Java разработчика. Фишка в том, что просчитана вероятность с которой вопрос буден задан и есть примеры ответов. Теперь можно легко получить оффер, подготовившись к самым популярным вопросам 😏
6 950
☕️Использование библиотеки Apache POI
Apache POI (Poor Obfuscation Implementation) - это библиотека для работы с файлами Microsoft Office, такими как Excel, Word и PowerPoint. Она позволяет создавать, изменять и читать документы в форматах XLS, XLSX, DOC, DOCX, PPT и других.
Основные классы, которые используются для работы с файлами Excel в Apache POI:
1. HSSFWorkbook и XSSFWorkbook - используются для работы с файлами Excel в форматах .xls и .xlsx соответственно.
2. HSSFSheet и XSSFSheet - представляют собой листы в Excel файле.
3. HSSFRow и XSSFRow - представляют строки в Excel файле.
4. HSSFCell и XSSFCell - представляют ячейки в Excel файле.
Пример создания нового Excel файла и запись в него данных с использованием Apache POI:
import org.apache.poi.ss.usermodel.*;
public class ExcelWriter {
public static void main(String[] args) {
Workbook wb = new XSSFWorkbook();
Sheet sheet = wb.createSheet("Sheet1");
Row headerRow = sheet.createRow(0);
Cell headerCell = headerRow.createCell(0);
headerCell.setCellValue("Name");
Row dataRow = sheet.createRow(1);
Cell dataCell = dataRow.createCell(0);
dataCell.setCellValue("John Doe");
try (FileOutputStream fileOut = new FileOutputStream("workbook.xlsx")) {
wb.write(fileOut);
} catch (IOException e) {
e.printStackTrace();
}
}
}
⚙️В этом примере создается новый Excel файл с именем "workbook.xlsx" и записывается одна строка данных. После выполнения программы в папке проекта будет создан файл "workbook.xlsx" с данными "Name" и "John Doe" в первой колонке.
Apache POI также предоставляет методы для чтения и изменения существующих Excel файлов, форматирования ячеек, добавления графиков и других операций над документами Microsoft Office.6 950
— Кто мы?
— Фронтендеры!
— Чего мы хотим?
— Делать модные сайты!
— Где этому научиться?
— На канале «Будни разработчика», конечно!
— А что там?
— Крутые фишки фронтенда, истории лучших разработчиков и топовые статьи!
6 950
🌱 Spring Data REST - это проект в рамках экосистемы Spring, который позволяет автоматически создавать RESTful API на основе репозиториев Spring Data. Spring Data REST позволяет упростить создание API для работы с базами данных, предоставляя RESTful конечные точки для операций CRUD (Create, Read, Update, Delete) над данными.
Spring Data REST анализирует репозитории Spring Data и создает RESTful конечные точки для сущностей, которыми они управляют.
В Spring Data REST обеспечена поддержка различных типов запросов, включая запросы для сортировки, фильтрации, постраничного вывода и т.д.
В Spring Data REST так же встроена поддержка HATEOAS (Hypermedia as the Engine of Application State) - это архитектурный принцип, который позволяет клиентским приложениям навигировать по API, следуя гиперссылкам, предоставляемым сервером. Spring Data REST автоматически включает ссылки на связанные ресурсы в ответах API, что упрощает навигацию и использование API.
Предположим, у нас есть сущность User, которую мы хотим представить через API. Для этого нужно аннотировать репозиторий сущности User, аннотацией @RepositoryRestResource:
@RepositoryRestResource(path = "users")
public interface UserRepository extends JpaRepository<User, Long> {
}
Теперь Spring Data REST автоматически создаст RESTful конечные точки для управления сущностью User:
GET /users - Получить всех пользователей
POST /users - Создать нового пользователя
GET /users/{id} - Получить пользователя по ID
PUT /users/{id} - Обновить пользователя
DELETE /users/{id} - Удалить пользователя
Spring Data REST обеспечивает множество способов настройки и расширения поведения API. Разработчики могут настраивать URL-адреса, форматирование ответов, права доступа и многое другое, используя различные аннотации и конфигурационные параметры.6 950
Каналы любого уважающего себя разработчика:
Java Developer — поможет узнать обо всех тонкостях и секретах языка Java.
Python Developer — научит программировать на Python как настоящий разработчик.
Подписывайся и прокачивай свои навыки👇🏻
6 950
☕️Использование библиотеки Apache HttpClient
Apache HttpClient - это библиотека для выполнения HTTP запросов. Она предоставляет удобный API для создания и отправки HTTP запросов, а также обработки ответов.
Ниже приведены некоторые основные методы класса HttpClient и их краткое описание:
1. execute - метод для отправки HTTP запроса на указанный URL. Пример кода:
CloseableHttpClient httpClient = HttpClients.createDefault();
HttpGet httpGet = new HttpGet("http://example.com");
CloseableHttpResponse response = httpClient.execute(httpGet);
2. setHeader - метод для установки заголовков запроса. Пример кода:
httpGet.setHeader("Content-Type", "application/json");
3. setEntity - метод для установки тела запроса. Пример кода:
StringEntity entity = new StringEntity("{\"key\": \"value\"}");
httpPost.setEntity(entity);
4. getStatusCode - метод для получения кода ответа сервера. Пример кода:
int statusCode = response.getStatusLine().getStatusCode();
5. getEntity - метод для получения содержимого ответа. Пример кода:
String responseBody = EntityUtils.toString(response.getEntity());
Apache HttpClient позволяет выполнять различные типы запросов (GET, POST, PUT, DELETE и пр.) и работать с различными типами данных (текст, JSON, XML и пр.). Он также поддерживает работу с HTTPS, аутентификацию и установку параметров прокси.6 950
class Point {
private final int x, y;
private final String name;
Point(int x, int y) {
this.x = x;
this.y = y;
name = makeName();
}
protected String makeName() {
return "[" + x + "," + y + "]";
}
public final String toString() {
return name;
}
}
public class ColorPoint extends Point {
private final String color;
ColorPoint(int x, int y, String color) {
super(x, y);
this.color = color;
}
protected String makeName() {
return super.makeName() + ":" + color;
}
public static void main(String[] args) {
System.out.println(new ColorPoint(4, 2, "red"));
}
}6 950
☕️Использование библиотеки Apache Commons IO
Apache Commons IO - это библиотека, предоставляющая удобные утилиты для работы с вводом/выводом данных в Java. Она содержит множество методов, упрощающих манипуляции с файлами, потоками ввода/вывода, строками и директориями.
Ниже приведены некоторые из наиболее полезных методов Apache Commons IO соответствующие объяснения и примеры кода:
1. Метод FileUtils.readFileToString(File file, Charset encoding) - читает содержимое файла в строку.
File file = new File("test.txt");
String content = FileUtils.readFileToString(file, StandardCharsets.UTF_8);
System.out.println(content);
2. Метод IOUtils.copy(InputStream input, OutputStream output) - копирует данные из одного потока в другой.
InputStream input = new FileInputStream("input.txt");
OutputStream output = new FileOutputStream("output.txt");
IOUtils.copy(input, output);
input.close();
output.close();
3. Метод FileUtils.listFiles(File directory, String extensions, boolean recursive) - возвращает список файлов в указанной директории с указанными расширениями.
File directory = new File("C:/my_folder");
String[] extensions = {"txt", "xml"};
List<File> files = (List<File>) FileUtils.listFiles(directory, extensions, true);
for (File file : files) {
System.out.println(file.getName());
}
4. Метод FilenameUtils.getExtension(String filename) - возвращает расширение файла.
String filename = "example.txt";
String extension = FilenameUtils.getExtension(filename);
System.out.println(extension);
Это лишь небольшая часть методов, которые предоставляет Apache Commons IO. Использование этой библиотеки может значительно упростить работу с вводом/выводом данных в ваших Java-программах.6 950
3, 2 … Остановимся здесь.⤵️
Потому что 2 недель достаточно, чтобы познакомиться с основами Java и понять, подходит ли вам это направление.
Не обещаем, что будет легко, но интересно, полезно и недорого (всего 990 рублей!) – гарантируем.
Расклад такой: мы даем вам базу — больше 60 уроков, вебинары, лайвкодинг, а вы пишете собственную программу.
Если переживаете — не переживайте :) Рядом всегда будет наставник, готовый ответить на любой ваш вопрос.
⏰ Старт курса уже 4 апреля, присоединяйтесь!
6 950
public class Boom {
private Boom internalInstance = new Boom();
public Boom() throws Exception {
throw new Exception("Boom!");
}
public static void main(String[] args) {
try {
Boom b = new Boom();
System.out.println("Surprise");
} catch (Exception e) {
System.out.println("I caught!");
}
}
}6 950
☕️Использование библиотеки MapStruct
MapStruct – это библиотека, которая позволяет автоматически генерировать код для преобразования объектов Java одного типа в объекты другого типа. Это делает процесс маппинга объектов быстрым, удобным и безопасным.
Основные методы, которые предоставляет MapStruct:
1. @Mapper – аннотация, которая указывает, что интерфейс является маппером и должен быть компилирован в реализацию маппера.
Пример:
@Mapper
public interface CarMapper {
CarDto carToCarDto(Car car);
List<CarDto> carsToCarDtos(List<Car> cars);
}
2. @Mappings – аннотация, которая позволяет настроить маппинг полей объектов.
Пример:
@Mappings({
@Mapping(source = "make", target = "manufacturer"),
@Mapping(source = "numberOfSeats", target = "seatCount")
})
CarDto carToCarDto(Car car);
3. @Mapping – аннотация, которая позволяет настроить конкретное преобразование для поля.
Пример:
@Mapping(source = "make", target = "manufacturer")
CarDto carToCarDto(Car car);
4. @InheritInverseConfiguration – аннотация, которая указывает, что метод должен использовать обратное преобразование.
Пример:
@InheritInverseConfiguration
Car carDtoToCar(CarDto carDto);
5. @IterableMapping – аннотация, которая позволяет настроить преобразование коллекций.
Пример:
@IterableMapping(elementTargetType = CarDto.class)
List<CarDto> carsToCarDtos(List<Car> cars);
🔖Используя эти методы и аннотации, разработчики могут эффективно и легко создавать мапперы для преобразования объектов Java. MapStruct делает код более чистым, читаемым и уменьшает вероятность ошибок при преобразовании объектов.6 950
Готовы улучшить свое владение Java?
Присоединяйся к нашему каналу - https://t.me/java_secrets 📲
Свежие советы, лучшие практики, примеры кода и обсуждения, чтобы стать настоящим профессионалом в программировании на Java.
Повышай свой уровень!
6 950
☕️Использование библиотеки Hibernate
Hibernate - это фреймворк для работы с базами данных в Java, который облегчает взаимодействие с базой данных с использованием объектно-ориентированной парадигмы. Hibernate позволяет разработчикам работать с объектами Java, а не с SQL запросами напрямую.
Пример использования Hibernate для работы с базой данных:
1. Создание сессии:
SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
Session session = sessionFactory.openSession();
2. Получение объекта из базы данных:
Employee employee = session.get(Employee.class, 1); // получение сотрудника с id = 1
System.out.println(employee.getName());
3. Сохранение объекта в базу данных:
Employee newEmployee = new Employee();
newEmployee.setName("John Doe");
newEmployee.setDepartment("IT");
session.save(newEmployee);
4. Обновление объекта в базе данных:
Employee employee = session.get(Employee.class, 1);
employee.setDepartment("HR");
session.update(employee);
5. Удаление объекта из базы данных:
Employee employee = session.get(Employee.class, 1);
session.delete(employee);
Hibernate предоставляет различные методы для работы с объектами и базой данных, такие как save, update, delete, get и др. Он также поддерживает механизмы маппинга объектов на таблицы базы данных и управления транзакциями.
🔔Hibernate облегчает работу с базой данных для Java разработчиков, позволяя им сосредоточиться на объектно-ориентированном программировании, а не на SQL запросах и управлении соединениями.
Available now! Telegram Research 2025 — the year's key insights 
