Java | Вопросы собесов – Telegram
Java | Вопросы собесов
11.4K subscribers
33 photos
3 videos
1.13K links
Download Telegram
🤔 Какие правила переопределения hashcode и equals?

Правила переопределения hashCode и equals включают: если два объекта равны по методу equals(), они должны иметь одинаковый hashCode. Если hashCode() не переопределен, объекты могут вести себя некорректно в хеш-таблицах, таких как HashMap или HashSet. Кроме того, hashCode() должен быть консистентным — при вызове несколько раз для одного и того же объекта метод должен возвращать одно и то же значение. Правильное переопределение этих методов гарантирует корректную работу объектов в коллекциях, использующих хеширование.

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍22🔥41
🤔 Какая разница между JSPWriter и сервлетным PrintWriter?

Оба этих объекта используются для вывода контента в ответе HTTP, но они имеют разные особенности и способы использования.

🚩JSPWriter

Это объект, используемый в JSP для вывода данных на клиентскую сторону. Он является частью стандартной библиотеки JSP и предоставляется контейнером JSP. Основные характеристики JSPWriter:

🟠Буферизация
JSPWriter поддерживает буферизацию, что позволяет накапливать вывод в буфере перед отправкой его клиенту. Вы можете управлять размером буфера и его очисткой.
🟠Контекст JSP
JSPWriter является частью объекта JspContext, который доступен в JSP через встроенную переменную out. JSPWriter интегрирован с другими элементами JSP, такими как теги и выражения JSP.
🟠Методы
JSPWriter наследует методы от java.io.Writer, включая write, flush, и close. Также он предоставляет методы для управления буфером, такие как clear(), clearBuffer(), и getBufferSize().

Пример использования JSPWriter в JSP:
<%@ page contentType="text/html;charset=UTF-8" %>
<html>
<head>
<noscript>Пример использования JSPWriter</noscript>
</head>
<body>
<%
out.println("Это вывод с использованием JSPWriter.");
out.write("Еще один пример вывода.");
%>
</body>
</html>


🚩PrintWriter

Это объект, используемый в сервлетах для вывода данных на клиентскую сторону. Он является частью стандартной библиотеки сервлетов и предоставляется объектом HttpServletResponse. Основные характеристики PrintWriter:
🟠Отсутствие буферизации
PrintWriter не поддерживает буферизацию в том же смысле, что и JSPWriter. Он напрямую отправляет данные клиенту. Однако сервер может использовать собственные механизмы буферизации, которые не контролируются программистом.
🟠Контекст сервлета
PrintWriter используется в сервлетах и доступен через метод getWriter() объекта HttpServletResponse. Он используется для генерации HTML, JSON, XML и других типов ответа в сервлетах.
🟠Методы
PrintWriter наследует методы от java.io.Writer и добавляет удобные методы для печати различных типов данных, такие как print, println, и printf.

Пример использования PrintWriter в сервлете:
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class ExampleServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
try {
out.println("<html>");
out.println("<head>");
out.println("<noscript>Пример использования PrintWriter</noscript>");
out.println("</head>");
out.println("<body>");
out.println("<h1>Это вывод с использованием PrintWriter.</h1>");
out.println("</body>");
out.println("</html>");
} finally {
out.close();
}
}
}


Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍6
🤔 В чём разница между SQL и NoSQL?

SQL базы данных — это реляционные базы данных, которые используют структуру таблиц и поддерживают язык запросов SQL для работы с данными. NoSQL базы данных ориентированы на документы, ключ-значения, графы или столбцы и предоставляют гибкость для хранения неструктурированных данных. SQL базы данных обеспечивают строгую согласованность данных и поддерживают транзакции ACID, в то время как NoSQL часто предлагают более высокую производительность и масштабируемость за счёт ослабления некоторых ограничений. Выбор между SQL и NoSQL зависит от требований приложения к структуре данных и производительности.

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍14🔥4
🤔 Всегда ли создается объект сессии на JSP странице, можно ли отключить его создание?

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

🚩Отключение создания сессии

Вы можете отключить автоматическое создание сессии на JSP-странице с помощью атрибута session директивы page. Для этого нужно установить session="false". Директива <%@ page session="false" %> отключает автоматическое создание объекта сессии для данной страницы.
<%@ page session="false" %>
<html>
<head>
<noscript>Страница без сессии</noscript>
</head>
<body>
<h1>Эта страница не создает объект сессии</h1>
</body>
</html>


🚩Что происходит, когда сессия отключена

🟠Нет автоматического создания сессии
Объект сессии не будет создан автоматически сервером.
🟠Недоступность встроенной переменной `session`
Встроенная переменная session не будет доступна на странице. Попытка обращения к ней приведет к ошибке компиляции JSP.

🚩Когда полезно отключать сессии

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

Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2
🤔 Что такое нормализация баз данных?

Нормализация — это процесс организации данных в базе данных для минимизации дублирования и предотвращения аномалий при изменении данных. Она включает разбиение таблиц на меньшие связанные таблицы и определение отношений между ними. Основные формы нормализации включают первую (1NF), вторую (2NF) и третью нормальные формы (3NF), каждая из которых имеет свои правила для уменьшения избыточности. Нормализация улучшает целостность данных и делает базы данных более эффективными.

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍21🔥7
🤔 Опиши общие практические принципы работы с JSP?

Работа с JSP (JavaServer Pages) включает в себя множество принципов и практик, которые помогают разработчикам создавать поддерживаемые, эффективные и безопасные веб-приложения.

🚩Разделение логики и представления

🟠Принцип MVC (Model-View-Controller)
Использование шаблона проектирования MVC помогает отделить логику приложения (модель) от его представления (вид) и управления (контроллер). В JSP это достигается следующими способами:
Модель: Логика обработки данных, обычно реализованная в JavaBeans, POJO или сервисах.
Вид: JSP-страницы, которые используются для отображения данных пользователю.
Контроллер: Серверные компоненты, такие как сервлеты, которые обрабатывают запросы, взаимодействуют с моделью и передают данные на вид.
// Сервлет-контроллер
@WebServlet("/greeting")
public class GreetingServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String name = request.getParameter("name");
if (name == null || name.isEmpty()) {
name = "Guest";
}
request.setAttribute("greeting", "Hello, " + name + "!");
request.getRequestDispatcher("/greeting.jsp").forward(request, response);
}
}

<!-- greeting.jsp -->
<%@ page contentType="text/html;charset=UTF-8" %>
<html>
<head>
<noscript>Greeting</noscript>
</head>
<body>
<h1><%= request.getAttribute("greeting") %></h1>
</body>
</html>


🟠Использование JSTL и EL
JSTL (JavaServer Pages Standard Tag Library)
JSTL предоставляет стандартный набор тегов для выполнения общих задач, таких как условные операторы, циклы, работа с коллекциями, форматирование и интернационализация.
EL (Expression Language)
EL используется для упрощения доступа к данным в JSP, таких как атрибуты запроса, сессии и контекста приложения.
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<html>
<head>
<noscript>Greeting</noscript>
</head>
<body>
<c:if test="${not empty greeting}">
<h1>${greeting}</h1>
</c:if>
</body>
</html>


🟠Минимизация использования скриплетов
Использование скриплетов <% %> (вставки Java-кода в JSP) не рекомендуется, так как это затрудняет поддержку и чтение кода. Вместо этого используйте JSTL и EL для выполнения большинства задач.

🟠Управление сессиями
Сессии используются для сохранения состояния пользователя между запросами. Однако, они потребляют ресурсы сервера, поэтому используйте их разумно.
Отключение сессий при ненадобности: Если страница не требует использования сессий, отключите их. Минимизация данных сессии: Храните в сессии только необходимые данные.
<%@ page session="false" %>


🟠Обработка ошибок и исключений
Реализуйте глобальную обработку ошибок в дескрипторе развертывания web.xml и на уровне страниц.
<!-- web.xml -->
<error-page>
<error-code>404</error-code>
<location>/error404.jsp</location>
</error-page>
<error-page>
<exception-type>java.lang.Throwable</exception-type>
<location>/error.jsp</location>
</error-page>


🟠Безопасность
Защита от XSS (Cross-Site Scripting): Экранируйте выводимые данные.
Защита от CSRF (Cross-Site Request Forgery): Используйте токены для подтверждения действий.
<c:out value="${param.name}" />


🟠Оптимизация производительности
Кеширование: Кешируйте часто используемые данные для снижения нагрузки на сервер и базу данных.
Минимизация размера ответа: Сжимайте HTML, CSS и JavaScript.

Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍63🤔1🤯1
🤔 Что такое ExecutorService?

ExecutorService — это интерфейс в Java, который предоставляет механизм для управления потоками и выполнения задач в многопоточном окружении. Он позволяет запускать, останавливать и управлять пулом потоков, предоставляя гибкость в распределении задач между потоками. ExecutorService поддерживает выполнение задач с возвратом результата (Callable) и без (Runnable), а также периодическое выполнение задач. Он упрощает работу с потоками, предоставляя методы для эффективного управления многозадачностью.

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍12🔥21
🤔 Для чего нужна JVM?

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

🚩Функции

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

🟠Управление памятью
Управляет памятью через кучу (heap), где объекты динамически создаются и удаляются. Это освобождает разработчиков от необходимости вручную управлять памятью, снижая вероятность ошибок, связанных с неправильным использованием памяти, таких как утечки памяти.

🟠Сборка мусора (Garbage Collection)
Автоматически управляет освобождением памяти, используя сборщик мусора. Сборщик мусора периодически освобождает память, занятую объектами, которые больше не используются программой, что помогает предотвратить утечки памяти и улучшить производительность.

🟠Безопасность
Обеспечивает безопасное выполнение кода через систему управления доступом, которая проверяет разрешения при выполнении определенных операций (например, доступ к файловой системе). Это помогает предотвратить выполнение вредоносного кода.

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

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

🚩Как работает

1⃣Компиляция исходного кода в байт-код
Исходный код Java (.java файлы) компилируется компилятором Java (javac) в байт-код (.class файлы), который является машинно-независимым промежуточным кодом.

2⃣Загрузка байт-кода
Класс-загрузчики (Class Loaders) JVM загружают байт-код в память. Существует несколько типов загрузчиков классов, такие как Bootstrap Class Loader, Extension Class Loader и Application Class Loader.

3⃣Проверка байт-кода
Выполняет проверку байт-кода для обеспечения его корректности и безопасности. Проверка включает проверку формата, доступности, ссылок и других аспектов, чтобы предотвратить выполнение некорректного или вредоносного кода.

4⃣Интерпретация или компиляция JIT
Может интерпретировать байт-код или использовать Just-In-Time (JIT) компиляцию для преобразования байт-кода в машинный код во время выполнения. JIT-компиляция улучшает производительность, так как позволяет часто исполняемым частям кода выполняться быстрее.

5⃣Выполнение кода
После загрузки, проверки и компиляции байт-кода JVM выполняет его, управляя памятью, потоками и исключениями, обеспечивая при этом безопасность выполнения.

Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍171
🤔 Какие примитивные типы данных есть в Java?

В Java существует восемь примитивных типов данных: byte, short, int, long, float, double, boolean и char. Эти типы хранят непосредственно значения и отличаются по размеру и диапазону возможных значений. Примитивные типы данных используются для простых операций и экономят память по сравнению с объектными типами. Примитивные значения не могут быть null, но для них существуют соответствующие обёрточные классы (например, Integer, Boolean).

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍33🔥1
🤔 Что такое Classloader?

Это компонент JVM, который отвечает за динамическую загрузку классов в память во время выполнения программы. В Java каждый класс должен быть загружен в память перед его использованием, и именно Classloader занимается этой задачей.

🚩Функции

🟠Загрузка классов
Classloader находит и загружает файлы классов (обычно с расширением .class) в память.
🟠Проверка классов
После загрузки Classloader проверяет байт-код класса для обеспечения его корректности и безопасности.
🟠Связывание классов
Classloader связывает загруженные классы, включая проверку ссылок и разрешение символов.
🟠Инициализация классов
Classloader инициализирует загруженные классы, вызывая их статические инициализаторы и инициализаторы переменных.

🚩Иерархия

🟠Bootstrap ClassLoader
Это базовый загрузчик классов, встроенный в JVM. Он загружает основные классы Java из файла rt.jar, такие как классы из java.lang, java.util и других. Он реализован на нативном языке и является частью ядра JVM.

🟠Extension ClassLoader (Platform ClassLoader)
Загружает классы из стандартных расширений Java, находящихся в директории jre/lib/ext или другой директории, определенной системным параметром java.ext.dirs. Он сам загружается с помощью Bootstrap ClassLoader.

🟠Application ClassLoader (System ClassLoader)
Загружает классы приложения из директории classpath. Обычно это директория, указанная в переменной окружения CLASSPATH или параметре командной строки -cp. Это стандартный загрузчик классов, используемый для загрузки классов приложений и библиотек.
public class Main {
public static void main(String[] args) {
ClassLoader classLoader = Main.class.getClassLoader();
System.out.println("ClassLoader: " + classLoader);

try {
Class<?> aClass = classLoader.loadClass("Example");
System.out.println("Class loaded: " + aClass.getName());
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}

🟠Мы получаем Classloader, который загрузил класс Main.
🟠Мы используем этот Classloader для загрузки класса Example динамически.
🟠Если класс Example не найден, выбрасывается исключение ClassNotFoundException.

🚩Кастомные

Можно создавать собственные Classloader, расширяя класс java.lang.ClassLoader, например, для и классов из нестандартных источников (например, из базы данных, сети или зашифрованных архивов).
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.nio.file.Files;
import java.nio.file.Paths;

public class CustomClassLoader extends ClassLoader {

@Override
public Class<?> findClass(String name) throws ClassNotFoundException {
try {
byte[] bytes = loadClassData(name);
return defineClass(name, bytes, 0, bytes.length);
} catch (IOException e) {
throw new ClassNotFoundException(name, e);
}
}

private byte[] loadClassData(String name) throws IOException {
String path = name.replace('.', '/') + ".class";
InputStream inputStream = Files.newInputStream(Paths.get(path));
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
int data;
while ((data = inputStream.read()) != -1) {
byteArrayOutputStream.write(data);
}
return byteArrayOutputStream.toByteArray();
}
}

🟠Мы расширяем ClassLoader и переопределяем метод findClass.
🟠Метод loadClassData загружает данные класса из файла.
🟠Метод defineClass создает класс из байтового массива.

Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍171
🤔 Какие знаешь паттерны проектирования?

Паттерны проектирования в Java и других языках программирования классифицируются на три основные категории:
1. Порождающие: Singleton, Factory Method, Abstract Factory, Builder, Prototype.
2. Структурные: Adapter, Bridge, Composite, Decorator, Facade, Flyweight, Proxy.
3. Поведенческие: Observer, Strategy, Command, State, Visitor, Mediator, Iterator, Chain of Responsibility, Interpreter, Memento.?

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥23👍4
🤔 Области данных времени выполнения?

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

🚩Области выполнения

🟠Heap (Куча)
Это область памяти, где размещаются все объекты и массивы, созданные динамически во время выполнения программы. Эта область управляется сборщиком мусора (Garbage Collector), который освобождает память, занятую объектами, которые больше не используются. Когда вы создаете объект с помощью ключевого слова new, память для этого объекта выделяется в куче. Пример: Person person = new Person();

🟠Method Area (Методная область)
Содержит структуру классов, включая данные о классах (метаданные), методах, полях, константах и статических переменных. Это аналогично метаспространству в современных реализациях JVM. Загрузка информации о классе, методах и константах происходит в методной области. Пример: Информация о классе Person, его методах и полях будет храниться в методной области.

🟠Java Stack (Стек Java)
Стек Java содержит фреймы методов, где каждый фрейм представляет собой вызов метода. В каждом фрейме хранятся локальные переменные, параметры метода, данные для возврата и временные значения. Каждый поток имеет свой собственный стек. Локальные переменные и параметры метода хранятся в стеке. Пример: При вызове метода calculate() его локальные переменные и параметры будут размещены в фрейме стека.
public class Example {
public static void main(String[] args) {
int x = 10;
int y = 20;
int result = add(x, y);
}

public static int add(int a, int b) {
return a + b;
}
}

При вызове метода main создается фрейм для этого метода в стеке, где x, y и result хранятся как локальные переменные. При вызове метода add создается новый фрейм в стеке для этого метода с параметрами a и b.

🟠PC Register (Регистры программного счётчика)
Каждый поток имеет свой собственный программный счетчик (PC Register), который хранит адрес текущей исполняемой инструкции. Для каждого потока этот регистр указывает на следующую инструкцию, которая должна быть выполнена. Программный счетчик используется для управления потоком исполнения инструкций в программе. Пример: Если метод вызывает другой метод, программный счетчик обновляется, чтобы указывать на новую точку выполнения.

🟠Native Method Stack (Стек нативных методов)
Этот стек используется для выполнения нативных (не на Java) методов, написанных на других языках, таких как C или C++. Каждый поток также имеет свой собственный стек нативных методов. Всякий раз, когда Java программа вызывает нативный метод, используется этот стек. Пример: Вызов метода из библиотеки, написанной на C, для выполнения специфической для платформы задачи.

🚩Взаимодействие

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

Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍20🤯41
🤔 Чем singleton отличается от prototype?

В контексте паттернов проектирования:
- Singleton гарантирует, что класс имеет только один экземпляр в приложении и предоставляет глобальную точку доступа к этому экземпляру.

- Prototype позволяет создавать объекты, клонируя существующий объект, что позволяет избежать затрат на создание объектов стандартным способом (через new), особенно если это сложный процесс создания.?

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥14👍9🤔21
🤔 Что такое Frames?

Это класс в библиотеке Swing, который используется для создания основного окна приложения. Это одно из основных контейнеров, в котором можно размещать другие компоненты, такие как кнопки, текстовые поля, панели и т.д.

🚩Почему это нужно?

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

🚩Как это используется?

1⃣Создание экземпляра JFrame.
2⃣Настройка основных параметров окна (заголовок, размер, действие при закрытии и т.д.).
3⃣Добавление компонентов на окно.
4⃣Отображение окна.
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;

public class MyFrameExample {
public static void main(String[] args) {
// Создание нового окна (фрейма)
JFrame frame = new JFrame("My First Frame");

// Установка действия при закрытии окна
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

// Создание панели для размещения компонентов
JPanel panel = new JPanel();

// Создание метки и кнопки
JLabel label = new JLabel("Hello, World!");
JButton button = new JButton("Click Me");

// Добавление метки и кнопки на панель
panel.add(label);
panel.add(button);

// Добавление панели в окно
frame.add(panel);

// Установка размеров окна
frame.setSize(400, 300);

// Отображение окна
frame.setVisible(true);
}
}

1⃣Мы создаем новый экземпляр JFrame с заголовком "My First Frame".
2⃣Устанавливаем действие при закрытии окна, чтобы приложение завершало работу при закрытии окна.
3⃣Создаем панель JPanel, на которую будем размещать компоненты.
4⃣Создаем метку JLabel и кнопку JButton.
5⃣Добавляем метку и кнопку на панель.
6⃣Добавляем панель в окно.
7⃣Устанавливаем размеры окна.
8⃣Делаем окно видимым.

Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8🤯3
🤔 Зачем вообще нужен класс object?

Класс `Object` в Java является корневым классом в иерархии классов. Каждый класс в Java неявно наследуется от класса `Object`, что делает доступными базовые методы, такие как `equals()`, `hashCode()`, `toString()`, `clone()`, `wait()`, и `notify()`, для всех объектов. Это обеспечивает универсальность и возможность полиморфного использования всех объектов.?

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍26
🤔 Что такое Execution Engine?

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

🚩Почему это нужно?

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

🚩Как это используется?

1⃣Class Loader (Загрузчик классов)
Загружает классы и интерфейсы в JVM по мере необходимости.

2⃣Interpreter (Интерпретатор)
Читает байт-код и выполняет его инструкции одну за другой. Это простой и прямолинейный способ исполнения, но может быть медленным.

3⃣Just-In-Time Compiler (JIT-компилятор)
JIT-компиляция используется для повышения производительности. Вместо того чтобы интерпретировать байт-код каждый раз, JIT компилирует часто выполняемые части байт-кода в машинный код, который может выполняться напрямую процессором.

4⃣Garbage Collector (Сборщик мусора)
Управляет памятью, автоматически освобождая ее от объектов, которые больше не используются программой, что предотвращает утечки памяти.

🚩Пример процесса выполнения

1⃣Загрузка классов
Когда JVM запускает программу, сначала загружается основной класс и любые другие классы, необходимые для выполнения программы.
2⃣Интерпретация
Интерпретатор начинает выполнение кода, интерпретируя байт-код в машинный код.
3⃣JIT-компиляция
Если интерпретатор обнаруживает, что определенные части кода выполняются часто, он передает их JIT-компилятору, который компилирует этот байт-код в машинный код для более быстрого выполнения.
4⃣Сборка мусора
В течение выполнения программы сборщик мусора освобождает память от объектов, которые больше не используются.

Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍13
🤔 Какие участки памяти в JVM знаешь?

В Java Virtual Machine (JVM) используются следующие участки памяти:
- **Heap**: область памяти, где создаются объекты и хранятся их данные.
- **Stack**: хранит локальные переменные и информацию о вызовах методов.
- **Method Area**: хранит структуру класса, включая константы, методы, поля и код.
- **Program Counter Register**: указывает на текущую инструкцию JVM, которая выполняется.
- **Native Method Stack**: для нативных методов, не написанных на Java.?

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥36👍92
🤔 Расскажи о разнице execute, executeQuary и executeApdate?

Являются частью интерфейса Statement в JDBC (Java Database Connectivity). Они используются для выполнения SQL-запросов к базе данных, но применяются в разных ситуациях в зависимости от типа запроса.

🚩execute()

Метод используется для выполнения любых SQL-запросов. Он возвращает булевое значение, указывающее, вернул ли запрос объект ResultSet (набор результатов). Используется для выполнения сложных запросов или тех, которые могут возвращать как результаты (например, SELECT), так и не возвращать результаты (например, INSERT, UPDATE, DELETE, DDL - команды).
Statement stmt = connection.createStatement();
boolean hasResultSet = stmt.execute("SELECT * FROM employees");
if (hasResultSet) {
ResultSet rs = stmt.getResultSet();
// Обработка ResultSet
} else {
int updateCount = stmt.getUpdateCount();
// Обработка количества обновлений
}


🚩executeQuery()

Метод executeQuery() используется исключительно для выполнения SQL-запросов типа SELECT. Он всегда возвращает объект ResultSet. Используется, когда нужно получить данные из базы данных, то есть при выполнении запросов SELECT.
Statement stmt = connection.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM employees");
while (rs.next()) {
// Обработка данных из ResultSet
}


🚩executeUpdate()

Метод executeUpdate() используется для выполнения SQL-запросов, которые изменяют состояние базы данных. Это может быть INSERT, UPDATE, DELETE или DDL команды (например, создание или удаление таблицы). Он возвращает количество строк, затронутых запросом. Используется для выполнения запросов, которые изменяют данные или структуру базы данных.
Statement stmt = connection.createStatement();
int rowsAffected = stmt.executeUpdate("UPDATE employees SET salary = 1000 WHERE id = 1");
System.out.println("Rows affected: " + rowsAffected);


🚩Различия

🟠Тип возвращаемого значения
execute(): возвращает boolean, указывающий, вернул ли запрос ResultSet.
executeQuery(): возвращает ResultSet.
executeUpdate(): возвращает int, указывающий количество затронутых строк.

🟠Тип запроса
execute(): может выполнять любые SQL-запросы.
executeQuery(): только SELECT запросы.
executeUpdate(): INSERT, UPDATE, DELETE и DDL запросы.

Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍13😁1
🤔 Что такое процесс и поток, чем они отличаются?

- **Процесс** — это экземпляр запущенной программы, который имеет свою собственную изолированную область памяти.
- **Поток** — это единица выполнения внутри процесса. Потоки в одном процессе могут делиться ресурсами и памятью. Отличие в том, что потоки (особенно в одном процессе) менее затратны для создания и управления по сравнению с процессами.?

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍14🔥7🤯1
🤔 Зачем нам нужен ResultSet?

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

🚩Почему это нужно?

🟠Получения данных из базы данных
Когда вы выполняете запрос SELECT, база данных возвращает данные в виде таблицы. ResultSet позволяет получить эти данные и работать с ними в вашем Java-коде.
🟠Обработки данных
С помощью методов ResultSet можно извлекать данные строка за строкой и обрабатывать их по мере необходимости.
🟠Управления данными
ResultSet предоставляет методы для навигации по данным, доступа к столбцам по имени или индексу, обновления данных и даже перемещения курсора по результатам.

🚩Как это используется?

1⃣Создание запроса и выполнение его
Statement stmt = connection.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM employees


2⃣Извлечение и обработка данных
while (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
double salary = rs.getDouble("salary");
System.out.println("ID: " + id + ", Name: " + name + ", Salary: " + salary);
}


🚩Методы

🟠next()
Перемещает курсор к следующей строке.
rs.next();  


🟠getInt(), getString(), getDouble() и другие get-методы
Извлекают данные из текущей строки.
int id = rs.getInt("id");
String name = rs.getString("name");


🟠wasNull()
Проверяет, было ли последнее прочитанное значение SQL NULL.
int age = rs.getInt("age");
if (rs.wasNull()) {
// Обработка NULL значения
}


🟠close()
Закрывает ResultSet и освобождает связанные с ним ресурсы.
rs.close();  


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

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class ResultSetExample {
public static void main(String[] args) {
try {
// Подключение к базе данных
Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydatabase", "user", "password");

// Создание Statement и выполнение запроса
Statement stmt = connection.createStatement();
ResultSet rs = stmt.executeQuery("SELECT id, name, salary FROM employees");

// Обработка результатов
while (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
double salary = rs.getDouble("salary");
System.out.println("ID: " + id + ", Name: " + name + ", Salary: " + salary);
}

// Закрытие ResultSet и Statement
rs.close();
stmt.close();
connection.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}


Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍15
🤔 В чем разница между final vs. finally vs. finalize?

- **final**: ключевое слово, которое можно использовать для объявления переменных, методов и классов, при этом переменные не могут быть изменены, методы не могут быть переопределены, а классы не могут быть унаследованы.
- **finally**: блок в Java, который следует за блоками try и catch, выполняется в любом случае, независимо от того, было ли исключение.
- **finalize()**: метод, вызываемый сборщиком мусора перед тем, как объект будет уничтожен, что дает последний шанс очистить ресурсы.?

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍28🔥52