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

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

Наш канал на RUTube - https://rutube.ru/channel/37896292/
Download Telegram
Варианты ответа:
Anonymous Quiz
0%
Sum: 115
0%
Sum: 130
20%
Sum: 90
80%
Sum: 120
Что выведет код?

import java.util.concurrent.CopyOnWriteArrayList;

public class CopyOnWriteArrayListChallenge {
public static void main(String[] args) {
CopyOnWriteArrayList<Integer> list = new CopyOnWriteArrayList<>();
list.add(10);
list.add(20);
list.add(30);
list.add(40);
list.add(50);

// Iterate and modify
for (int num : list) {
if (num % 20 == 0) {
list.remove(Integer.valueOf(num));
}
}

// Add new elements
list.add(5);
list.add(25);

int sum = 0;
for (int num : list) {
sum += num;
}

System.out.println("Sum: " + sum);
}
}


#Tasks
Вот так бывает когда разраб остается один😐

https://t.me/Java_for_beginner_dev

#Mems
Основные методы CopyOnWriteArrayList и примеры использования

Добавление элементов:

add(E e): добавляет элемент в конец списка.
add(int index, E element): вставляет элемент по указанному индексу.
CopyOnWriteArrayList<String> list = new CopyOnWriteArrayList<>();
list.add("Apple");
list.add(1, "Banana");


Удаление элементов:

remove(Object o): удаляет первое вхождение указанного элемента.
remove(int index): удаляет элемент по указанному индексу.
list.remove("Banana");
list.remove(0);


Обновление элементов:

set(int index, E element): заменяет элемент по указанному индексу новым элементом.
list.set(0, "Orange");


Получение элементов:

get(int index): возвращает элемент по указанному индексу.
String fruit = list.get(0);


Проверка содержимого:

contains(Object o): проверяет, содержится ли указанный элемент в списке.
size(): возвращает количество элементов в списке.

boolean containsApple = list.contains("Apple");
int size = list.size();


Итерация по элементам:

iterator(): возвращает итератор по элементам списка.
for (String fruit : list) {
System.out.println(fruit);
}


Примеры использования
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.List;
import java.util.Iterator;

public class CopyOnWriteArrayListMethodsExample {
public static void main(String[] args) {
List<String> list = new CopyOnWriteArrayList<>();

// Добавление элементов
list.add("Apple");
list.add("Banana");
list.add("Cherry");
System.out.println("After adding elements: " + list);

// Вставка элемента
list.add(1, "Orange");
System.out.println("After insertion: " + list);

// Обновление элемента
list.set(2, "Mango");
System.out.println("After updating: " + list);

// Удаление элемента по индексу
list.remove(3);
System.out.println("After removing by index: " + list);

// Удаление элемента по значению
list.remove("Apple");
System.out.println("After removing by value: " + list);

// Проверка содержимого
boolean containsBanana = list.contains("Banana");
System.out.println("Contains Banana: " + containsBanana);

// Получение элемента
String fruit = list.get(0);
System.out.println("Element at index 0: " + fruit);

// Итерация по элементам
Iterator<String> iterator = list.iterator();
while (iterator.hasNext()) {
System.out.println("Iterating: " + iterator.next());
}

// Размер списка
int size = list.size();
System.out.println("Size of list: " + size);

// Очистка списка
list.clear();
System.out.println("After clearing: " + list);
}
}


#Java #Training #Medium #CopyOnWriteArrayList
Всем доброго субботнего утра!☀️

Как Вы собираетесь провести эти выходные?
Делитесь с нами в чате -
https://t.me/Java_Beginner_chat
Секрет раскрыт😮

https://t.me/Java_for_beginner_dev

#Mems
Сегодня воскресение бл…😡😡😡

https://t.me/Java_for_beginner_dev

#Mems
This media is not supported in your browser
VIEW IN TELEGRAM
Напоминаю!☝️

Сегодня в 16:00 по МСК, мы вновь собираемся на онлайн встречу)))

От нас лайф-кодинг, от Вас хорошее настроение и подсказки!))))😉

Ждем всех!🫡
Запись нашей сегодняшней встречи -
https://www.youtube.com/watch?v=Ryv47d3ggZw
https://rutube.ru/video/354b75fec305b2d3c678a5b58a4b70fe/

Огромная благодарность тем кто был, за участие и подсказки!
@Alexander_Gors отдельное спасибо, за лайф-кодинг!)

Сегодня, мы совместно рассмотрели на примерах порождающие паттерны проектирования:
- Фабричный метод (Factory Method)
- Абстрактная фабрика (Abstract Factory)
- Прототип (Prototype)
- Одиночка (Singleton)
- Строитель (Builder)


Смотрите, комментируйте, задавайте вопросы! Обязательно подписывайтесь на ютуб и рутюб каналы!!!

Гит репозиторий с результатом - https://github.com/Oleborn/PatternsOfCoding

Всем светлого и пенного 🍻😉
Встреча_в_Телемосте_04_08_24_20_16_33_—_запись.webm
224.1 MB
Для тех кто не смог победить блокировку Youtube и не желает заходить в Rutube выкладываю видео тут!

Смотрите на здоровье) 🫡

#online_meeting
Vector, отличия от ArrayList

Vector — это класс из пакета java.util, который реализует интерфейсы List, RandomAccess, Cloneable и Serializable. Этот класс предоставляет возможность создания динамически изменяемых массивов, которые могут автоматически увеличивать свой размер.


В отличие от ArrayList, класс Vector является синхронизированным, что делает его безопасным для использования в многопоточной среде без необходимости в дополнительной синхронизации.

История и использование

Vector был введен в первых версиях Java и являлся основным динамическим массивом до появления ArrayList в Java 2 (JDK 1.2). С тех пор, ArrayList стал более предпочтительным выбором для однопоточных приложений благодаря своей более высокой производительности.

Отличия от ArrayList

Синхронизация:
Vector: Все методы класса синхронизированы, что делает его потокобезопасным. Это приводит к некоторому снижению производительности при выполнении операций.
ArrayList: Не синхронизирован. Если требуется потокобезопасность, нужно вручную синхронизировать методы или использовать внешние блокировки.

Увеличение емкости:
Vector: По умолчанию удваивает свой размер при переполнении, что может привести к резкому увеличению памяти.
ArrayList: Увеличивает свою емкость на 50% при необходимости, что делает его более гибким в плане использования памяти.


Методы добавления и удаления элементов:
Оба класса имеют схожие методы для добавления, удаления и доступа к элементам. Однако из-за синхронизации, методы Vector несколько медленнее.


Пример использования Vector
import java.util.Vector;

public class VectorExample {
public static void main(String[] args) {
// Создание вектора с начальной емкостью 10
Vector<String> vector = new Vector<>(10);

// Добавление элементов
vector.add("Element 1");
vector.add("Element 2");
vector.add("Element 3");

// Чтение элементов
System.out.println("Element at index 1: " + vector.get(1));

// Удаление элемента
vector.remove(2);

// Итерация по элементам
for (String element : vector) {
System.out.println("Element: " + element);
}
}
}


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

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


Ссылки на полезные статьи (спасибо авторам за проделанную работу) :
https://www.baeldung.com/java-vector-guide
https://proglang.su/java/vector-class

#Java #Training #Medium #Vector
Что выведет код?

import java.util.Vector;

public class VectorChallenge {
public static void main(String[] args) {
Vector<Integer> vector = new Vector<>();
vector.add(15);
vector.add(30);
vector.add(45);
vector.add(60);
vector.add(75);

// Iterate and modify
for (int i = 0; i < vector.size(); i++) {
if (vector.get(i) % 30 == 0) {
vector.set(i, vector.get(i) / 2);
}
}

// Add new elements
vector.add(10);
vector.add(20);

int sum = 0;
for (int num : vector) {
sum += num;
}

System.out.println("Sum: " + sum);
}
}


#Tasks
Варианты ответа:
Anonymous Quiz
0%
Sum: 220
0%
Sum: 165
91%
Sum: 210
9%
Sum: 185
И лезут, и лезут со своими исправлениями 😂😂😂

https://t.me/Java_for_beginner_dev

#Mems
Внутреннее устройство и основные методы Vector

Как и ArrayList, Vector основан на массиве, который динамически изменяет свой размер. Основные особенности внутреннего устройства Vector включают:

Массив для хранения данных:
Внутренне Vector использует массив Object[] elementData для хранения элементов.
Поле size хранит количество элементов в векторе.

Синхронизация:
Все методы класса синхронизированы, что обеспечивает потокобезопасность.

Управление емкостью:
При создании Vector можно задать начальную емкость и коэффициент увеличения (capacityIncrement). Если коэффициент не задан, то при переполнении емкость вектора удваивается.

Основные методы Vector

Конструкторы:
Vector(): Создает пустой вектор с начальной емкостью 10.
Vector(int initialCapacity): Создает пустой вектор с указанной начальной емкостью.
Vector(int initialCapacity, int capacityIncrement): Создает пустой вектор с указанной начальной емкостью и коэффициентом увеличения.
Vector(Collection<? extends E> c): Создает вектор, содержащий элементы указанной коллекции.


Методы добавления элементов:

boolean add(E e): Добавляет элемент в конец вектора.
Vector<String> vector = new Vector<>();
vector.add("Element 1");


void add(int index, E element): Вставляет элемент в указанную позицию, сдвигая элементы вправо.
vector.add(1, "Element 2");


Методы доступа к элементам:

E get(int index): Возвращает элемент, находящийся в указанной позиции.
String element = vector.get(0);


int size(): Возвращает количество элементов в векторе.
int size = vector.size();


Методы удаления элементов:

boolean remove(Object o): Удаляет первое вхождение указанного элемента.
vector.remove("Element 1");


E remove(int index): Удаляет элемент в указанной позиции и возвращает его.
vector.remove(0);


Итерация по элементам:

Enumeration<E> elements(): Возвращает объект Enumeration для перебора элементов вектора.
Enumeration<String> enumeration = vector.elements();
while (enumeration.hasMoreElements()) {
System.out.println("Element: " + enumeration.nextElement());
}


Iterator<E> iterator(): Возвращает объект Iterator для перебора элементов вектора.

Iterator<String> iterator = vector.iterator();
while (iterator.hasNext()) {
System.out.println("Element: " + iterator.next());
}


Преимущества и недостатки Vector

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

Потокобезопасность: Синхронизация методов делает Vector безопасным для использования в многопоточной среде.
Динамическое изменение размера: Вектор автоматически увеличивает свою емкость при добавлении новых элементов.


Недостатки:
Низкая производительность: Из-за синхронизации методов производительность Vector может быть ниже, чем у ArrayList.
Высокие накладные расходы: При частых операциях добавления или удаления элементов синхронизация и увеличение емкости могут создавать дополнительные накладные расходы.


#Java #Training #Medium #Vector
Stack, особенности и примеры использования

Stack — это класс из пакета java.util, который реализует структуру данных "стек" (stack). Стек работает по принципу LIFO (Last In, First Out), что означает, что последний добавленный элемент будет первым, который удаляется. Эта структура данных полезна в случаях, когда требуется обратный порядок обработки данных, например, в алгоритмах обхода графов или в реализации операций отмены (undo).

import java.util.Stack;

public class StackExample {
public static void main(String[] args) {
Stack<String> stack = new Stack<>();

// Добавление элементов в стек
stack.push("Element 1");
stack.push("Element 2");
stack.push("Element 3");

// Чтение верхнего элемента стека без его удаления
System.out.println("Top element: " + stack.peek());

// Удаление верхнего элемента стека
System.out.println("Popped element: " + stack.pop());

// Чтение элементов после удаления
System.out.println("Top element after pop: " + stack.peek());
}
}


Особенности Stack

Синхронизация: Stack является синхронизированным классом, что делает его безопасным для использования в многопоточной среде. Однако, как и Vector, это может привести к снижению производительности в однопоточных приложениях.
Наследование от Vector: Stack наследует все методы от класса Vector и добавляет свои методы, специфичные для работы с LIFO структурой.
Устаревший класс: В современных приложениях предпочтительнее использовать Deque интерфейс и его реализации (ArrayDeque или LinkedList), которые предлагают более гибкие и эффективные способы работы с данными, чем Stack.

Примеры использования
Обратный порядок строки:
public static String reverseString(String input) {
Stack<Character> stack = new Stack<>();
for (char c : input.toCharArray()) {
stack.push(c);
}
StringBuilder reversed = new StringBuilder();
while (!stack.isEmpty()) {
reversed.append(stack.pop());
}
return reversed.toString();
}


Проверка корректности скобок:
public static boolean isValid(String s) {
Stack<Character> stack = new Stack<>();
for (char c : s.toCharArray()) {
if (c == '(' || c == '{' || c == '[') {
stack.push(c);
} else {
if (stack.isEmpty()) return false;
char top = stack.pop();
if ((c == ')' && top != '(') || (c == '}' && top != '{') || (c == ']' && top != '[')) {
return false;
}
}
}
return stack.isEmpty();
}


Перевод инфиксного выражения в постфиксное:
public static String infixToPostfix(String expression) {
Stack<Character> stack = new Stack<>();
StringBuilder result = new StringBuilder();
for (char c : expression.toCharArray()) {
if (Character.isLetterOrDigit(c)) {
result.append(c);
} else if (c == '(') {
stack.push(c);
} else if (c == ')') {
while (!stack.isEmpty() && stack.peek() != '(') {
result.append(stack.pop());
}
stack.pop();
} else {
while (!stack.isEmpty() && precedence(c) <= precedence(stack.peek())) {
result.append(stack.pop());
}
stack.push(c);
}
}
while (!stack.isEmpty()) {
result.append(stack.pop());
}
return result.toString();
}

public static int precedence(char ch) {
switch (ch) {
case '+':
case '-':
return 1;
case '*':
case '/':
return 2;
case '^':
return 3;
}
return -1;
}

Ссылки на полезные статьи (спасибо авторам за проделанную работу) :
https://www.baeldung.com/java-stack

#Java #Training #Medium #Stack
Что выведет код?

import java.util.Stack;

public class StackChallenge {
public static void main(String[] args) {
Stack<Integer> stack = new Stack<>();
stack.push(10);
stack.push(20);
stack.push(30);
stack.push(40);
stack.push(50);

int sum = 0;

while (!stack.isEmpty()) {
int value = stack.pop();
if (value % 20 == 0) {
stack.push(value / 2);
} else {
sum += value;
}
}

System.out.println("Sum: " + sum);
}
}


#Tasks
Варианты ответа:
Anonymous Quiz
19%
Sum: 80
31%
Sum: 90
13%
Sum: 100
38%
Sum: 110