2015-10-31 18:47:13 +00:00
|
|
|
|
---
|
|
|
|
|
contributors:
|
|
|
|
|
- ["Jake Prather", "http://github.com/JakeHP"]
|
|
|
|
|
- ["Jakukyo Friel", "http://weakish.github.io"]
|
|
|
|
|
- ["Madison Dickson", "http://github.com/mix3d"]
|
|
|
|
|
- ["Simon Morgan", "http://sjm.io/"]
|
|
|
|
|
- ["Zachary Ferguson", "http://github.com/zfergus2"]
|
|
|
|
|
- ["Cameron Schermerhorn", "http://github.com/cschermerhorn"]
|
|
|
|
|
- ["Rachel Stiyer", "https://github.com/rstiyer"]
|
|
|
|
|
translators:
|
2015-10-31 21:12:56 +00:00
|
|
|
|
- ["Oleksandr Tatarchuk", "https://github.com/tatarchuk"]
|
2016-02-27 16:24:20 +00:00
|
|
|
|
- ["Andre Polykanine", "https://github.com/Oire"]
|
2017-08-25 08:32:12 +00:00
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
---
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
Java є об’єктно-орієнтованою мовою програмування загального призначення з підтримкою паралельного програмування, яка базується на класах.
|
|
|
|
|
[Детальніше читайте тут, англ.](http://docs.oracle.com/javase/tutorial/java/)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
```java
|
|
|
|
|
// Однорядковий коментар починається з //
|
|
|
|
|
/*
|
|
|
|
|
Багаторядковий коментар виглядає так.
|
|
|
|
|
*/
|
|
|
|
|
/**
|
2016-02-27 16:24:20 +00:00
|
|
|
|
JavaDoc-коментар виглядає так. Використовується для опису класу та членів класу.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
*/
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Імпорт класу ArrayList з пакета java.util
|
2015-10-31 18:47:13 +00:00
|
|
|
|
import java.util.ArrayList;
|
2018-07-27 20:52:31 +00:00
|
|
|
|
// Імпорт усіх класів з пакета java.security
|
2015-10-31 18:47:13 +00:00
|
|
|
|
import java.security.*;
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Кожний .java файл містить один зовнішній публічний клас, ім’я якого співпадає
|
|
|
|
|
// з іменем файлу.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public class LearnJava {
|
|
|
|
|
|
|
|
|
|
// Для запуску програма, написана на java, повинна мати точку входу у вигляді методу main.
|
|
|
|
|
public static void main (String[] args) {
|
|
|
|
|
|
|
|
|
|
// Використання System.out.println() для виводу на друк рядків.
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Привіт, світе!");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
System.out.println(
|
2016-02-27 16:24:20 +00:00
|
|
|
|
" Ціле число: " + 10 +
|
|
|
|
|
" Число з рухомою комою подвійної точности: " + 3.14 +
|
|
|
|
|
" Булеве значення: " + true);
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Для друку без переходу на новий рядок використовується System.out.print().
|
|
|
|
|
System.out.print("Привіт, ");
|
|
|
|
|
System.out.print("світе");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
// Використання System.out.printf() для простого форматованого виводу на друк.
|
|
|
|
|
System.out.printf("pi = %.5f", Math.PI); // => pi = 3.14159
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////
|
|
|
|
|
// Змінні
|
|
|
|
|
///////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Оголошення змінних
|
|
|
|
|
*/
|
|
|
|
|
// Для оголошення змінних використовується формат <тип> <змінна>
|
|
|
|
|
int fooInt;
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Оголошення декількох змінних одного типу <тип> <ім’я1>, <ім’я2>, <ім’я3>
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int fooInt1, fooInt2, fooInt3;
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Ініціалізація змінних
|
|
|
|
|
*/
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Ініціалізація змінної з використанням формату <тип> <ім’я> = <значення>
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int fooInt = 1;
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Ініціалізація декількох змінних одного типу з одним значенням <тип> <ім’я1>, <ім’я2>, <ім’я3> = <значення>
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int fooInt1, fooInt2, fooInt3;
|
|
|
|
|
fooInt1 = fooInt2 = fooInt3 = 1;
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Типи змінних
|
|
|
|
|
*/
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Байт — 8-бітне ціле число зі знаком
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// (-128 <= byte <= 127)
|
|
|
|
|
byte fooByte = 100;
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Short — 16-бітне ціле число зі знаком
|
|
|
|
|
// (-32 768 <= short <= 32 767)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
short fooShort = 10000;
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Integer — 32-бітне ціле число зі знаком
|
|
|
|
|
// (-2 147 483 648 <= int <= 2 147 483 647)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int fooInt = 1;
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Long — 64-бітне ціле число зі знаком
|
|
|
|
|
// (-9 223 372 036 854 775 808 <= long <= 9 223 372 036 854 775 807)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
long fooLong = 100000L;
|
|
|
|
|
// L використовується для позначення того, що число має тип Long;
|
|
|
|
|
// інакше число буде трактуватись як integer.
|
|
|
|
|
|
|
|
|
|
// Примітка: Java не має беззнакових типів.
|
|
|
|
|
|
2018-07-27 20:52:31 +00:00
|
|
|
|
// Float — 32-бітне число з рухомою комою одиничної точності за стандартом IEEE 754
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// 2^-149 <= float <= (2-2^-23) * 2^127
|
|
|
|
|
float fooFloat = 234.5f;
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// f або F використовується для позначення того, що змінна має тип float;
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// інакше трактується як double.
|
|
|
|
|
|
2018-07-27 20:52:31 +00:00
|
|
|
|
// Double — 64-бітне число з рухомою комою подвійної точності за стандартом IEEE 754
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// 2^-1074 <= x <= (2-2^-52) * 2^1023
|
|
|
|
|
double fooDouble = 123.4;
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Boolean — true & false (істина чи хиба)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
boolean fooBoolean = true;
|
|
|
|
|
boolean barBoolean = false;
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Char — 16-бітний символ Unicode
|
2015-10-31 18:47:13 +00:00
|
|
|
|
char fooChar = 'A';
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// final - посилання на такі змінні не можуть бути присвоєні іншим об’єктам,
|
2015-10-31 18:47:13 +00:00
|
|
|
|
final int HOURS_I_WORK_PER_WEEK = 9001;
|
|
|
|
|
// але вони можуть мати відкладену ініціалізацію.
|
|
|
|
|
final double E;
|
|
|
|
|
E = 2.71828;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// BigInteger -Незмінні знакові цілі числа довільної точності
|
|
|
|
|
//
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// BigInteger є типом даних, який дає можливість розробнику виконувати операції
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// з цілими числами, розрядність яких більша за 64 біти. Числа зберігаються у масиві
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// байтів, операції над ними виконуються функціями, які мають клас BigInteger
|
2015-10-31 18:47:13 +00:00
|
|
|
|
//
|
|
|
|
|
// BigInteger можна ініціалізувати, використовуючи масив байтів чи рядок.
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
BigInteger fooBigInteger = new BigInteger(fooByteArray);
|
|
|
|
|
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// BigDecimal — Незмінні знакові дробові числа довільної точності
|
2015-10-31 18:47:13 +00:00
|
|
|
|
//
|
2018-07-27 20:52:31 +00:00
|
|
|
|
// BigDecimal складається з двох частин: цілого числа довільної точності
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// з немасштабованим значенням та 32-бітного масштабованого цілого числа
|
|
|
|
|
//
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// BigDecimal дозволяє розробникам контролювати десяткове округлення.
|
|
|
|
|
// Рекомендовано використовувати BigDecimal зі значеннями валют
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// і там, де необхідна точність дробових обчислень.
|
|
|
|
|
//
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// BigDecimal може бути ініціалізований типами даних int, long, double або String
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// чи немасштабованим значенням (BigInteger) і масштабованим значенням (int).
|
|
|
|
|
|
|
|
|
|
BigDecimal fooBigDecimal = new BigDecimal(fooBigInteger, fooInt);
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// Для дотримання заданої точності рекомендується використовувати
|
2018-07-27 20:52:31 +00:00
|
|
|
|
// конструктор, який приймає String
|
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
BigDecimal tenCents = new BigDecimal("0.1");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Рядки
|
|
|
|
|
String fooString = "Це мій рядок!";
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// \n є символом переходу на новий рядок
|
|
|
|
|
String barString = "Друк з нового рядка?\nНема питань!";
|
|
|
|
|
// \t — це символ табуляції
|
2015-10-31 18:47:13 +00:00
|
|
|
|
String bazString = "Хочете додати табуляцію?\tТримайте!";
|
|
|
|
|
System.out.println(fooString);
|
|
|
|
|
System.out.println(barString);
|
|
|
|
|
System.out.println(bazString);
|
|
|
|
|
|
|
|
|
|
// Масиви
|
|
|
|
|
// Розмір масиву має бути визначений перед ініціалізацією
|
|
|
|
|
// Наведений формат ілюструє ініціалізацію масивів
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// <тип даних>[] <ім’я змінної> = new <тип даних>[<розмір масиву>];
|
|
|
|
|
// <тип даних> <ім’я змінної>[] = new <тип даних>[<розмір масиву>];
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int[] intArray = new int[10];
|
|
|
|
|
String[] stringArray = new String[1];
|
|
|
|
|
boolean boolArray[] = new boolean[100];
|
|
|
|
|
|
|
|
|
|
// Інший шлях оголошення та ініціалізації масиву
|
|
|
|
|
int[] y = {9000, 1000, 1337};
|
|
|
|
|
String names[] = {"Bob", "John", "Fred", "Juan Pedro"};
|
|
|
|
|
boolean bools[] = new boolean[] {true, false, false};
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Індексація масиву — доступ за елементами
|
2015-10-31 18:47:13 +00:00
|
|
|
|
System.out.println("intArray @ 0: " + intArray[0]);
|
|
|
|
|
|
|
|
|
|
// Масиви є змінними та мають нульовий елемент.
|
|
|
|
|
intArray[1] = 1;
|
|
|
|
|
System.out.println("intArray @ 1: " + intArray[1]); // => 1
|
|
|
|
|
|
|
|
|
|
// Додатково
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// ArrayLists — Схожі на масив, але мають більший функціонал та змінний розмір.
|
|
|
|
|
// LinkedLists — Реалізація двозв’язного списку. Всі операції
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// виконуються так, як очікується від
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// двозв’язного списку.
|
|
|
|
|
// Maps — Множина об’єктів, які пов’язують ключ зі значенням. Map є
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// інтерфейсом, тому не може бути успадкований.
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Типи ключів і значень, які зберігаються в Map, мають
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// вказуватись у класі, який його реалізує.
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Ключ не може повторюватись і пов’язаний лише з одним значенням
|
|
|
|
|
// HashMaps — Цей клас використовує хеш-таблицю для реалізації інтерфейсу Map.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// Це дозволяє виконувати певні операції,
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// такі, як отримання та вставка елемента,
|
|
|
|
|
// залишаючись постійними навіть для великої кількості елементів.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
///////////////////////////////////////
|
2015-10-31 19:25:21 +00:00
|
|
|
|
// Оператори
|
2015-10-31 18:47:13 +00:00
|
|
|
|
///////////////////////////////////////
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("\n->Оператори");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 19:25:21 +00:00
|
|
|
|
int i1 = 1, i2 = 2; // Коротка форма присвоєння
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Арифметичні операції виконуються очевидним способом
|
2015-10-31 18:47:13 +00:00
|
|
|
|
System.out.println("1+2 = " + (i1 + i2)); // => 3
|
|
|
|
|
System.out.println("2-1 = " + (i2 - i1)); // => 1
|
|
|
|
|
System.out.println("2*1 = " + (i2 * i1)); // => 2
|
2015-10-31 19:25:21 +00:00
|
|
|
|
System.out.println("1/2 = " + (i1 / i2)); // => 0 (int/int повертається як int)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
System.out.println("1/2 = " + (i1 / (double)i2)); // => 0.5
|
|
|
|
|
|
2015-10-31 19:25:21 +00:00
|
|
|
|
// Ділення з остачею
|
2015-10-31 18:47:13 +00:00
|
|
|
|
System.out.println("11%3 = "+(11 % 3)); // => 2
|
|
|
|
|
|
2015-10-31 19:25:21 +00:00
|
|
|
|
// Оператори порівняння
|
2015-10-31 18:47:13 +00:00
|
|
|
|
System.out.println("3 == 2? " + (3 == 2)); // => false
|
|
|
|
|
System.out.println("3 != 2? " + (3 != 2)); // => true
|
|
|
|
|
System.out.println("3 > 2? " + (3 > 2)); // => true
|
|
|
|
|
System.out.println("3 < 2? " + (3 < 2)); // => false
|
|
|
|
|
System.out.println("2 <= 2? " + (2 <= 2)); // => true
|
|
|
|
|
System.out.println("2 >= 2? " + (2 >= 2)); // => true
|
|
|
|
|
|
2015-10-31 19:25:21 +00:00
|
|
|
|
// Логічні оператори
|
2015-10-31 18:47:13 +00:00
|
|
|
|
System.out.println("3 > 2 && 2 > 3? " + ((3 > 2) && (2 > 3))); // => false
|
|
|
|
|
System.out.println("3 > 2 || 2 > 3? " + ((3 > 2) || (2 > 3))); // => true
|
|
|
|
|
System.out.println("!(3 == 2)? " + (!(3 == 2))); // => true
|
|
|
|
|
|
2015-10-31 19:25:21 +00:00
|
|
|
|
// Бітові оператори!
|
2015-10-31 18:47:13 +00:00
|
|
|
|
/*
|
2015-10-31 19:25:21 +00:00
|
|
|
|
~ Унарне бітове доповнення
|
|
|
|
|
<< Знаковий зсув уліво
|
|
|
|
|
>> Знаковий/Арифметичний зсув управо
|
|
|
|
|
>>> Беззнаковий/Логічний зсув управо
|
|
|
|
|
& Бітове І
|
|
|
|
|
^ Бітови виключне АБО
|
|
|
|
|
| Бітове АБО
|
2015-10-31 18:47:13 +00:00
|
|
|
|
*/
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Інкремент
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int i = 0;
|
2015-10-31 19:25:21 +00:00
|
|
|
|
System.out.println("\n->Інкремент/Декремент");
|
|
|
|
|
// Оператори ++ і -- здійснюють інкремент та декремент ретроспективно.
|
|
|
|
|
// Якщо вони розташовані перед змінною, операція виконається перед поверненням;
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// якщо після неї — повернеться інкремент або декремент.
|
|
|
|
|
System.out.println(i++); // i = 1, друкує 0 (постінкремент)
|
|
|
|
|
System.out.println(++i); // i = 2, друкує 2 (преінкремент)
|
|
|
|
|
System.out.println(i--); // i = 1, друкує 2 (постдекремент)
|
|
|
|
|
System.out.println(--i); // i = 0, друкує 0 (предекремент)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
///////////////////////////////////////
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Керуючі конструкції
|
2015-10-31 18:47:13 +00:00
|
|
|
|
///////////////////////////////////////
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("\n->Керуючі конструкції");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Оператор if використовується так само, як у мові C
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int j = 10;
|
|
|
|
|
if (j == 10) {
|
2015-10-31 21:12:56 +00:00
|
|
|
|
System.out.println("Це надрукується");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
} else if (j > 10) {
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("А це — ні");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
} else {
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Це — також ні");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Цикл з передумовою While
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int fooWhile = 0;
|
|
|
|
|
while(fooWhile < 100) {
|
|
|
|
|
System.out.println(fooWhile);
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Інкремент лічильника
|
|
|
|
|
// Виконається 100 разів, fooWhile 0,1,2...99
|
2015-10-31 18:47:13 +00:00
|
|
|
|
fooWhile++;
|
|
|
|
|
}
|
|
|
|
|
System.out.println("fooWhile Value: " + fooWhile);
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Цикл з післяумовою Do While
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int fooDoWhile = 0;
|
|
|
|
|
do {
|
|
|
|
|
System.out.println(fooDoWhile);
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Інкремент лічильника
|
|
|
|
|
// Виконається 99 разів, fooDoWhile 0->99
|
2015-10-31 18:47:13 +00:00
|
|
|
|
fooDoWhile++;
|
|
|
|
|
} while(fooDoWhile < 100);
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Значення fooDoWhile: " + fooDoWhile);
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Цикл з параметром For
|
|
|
|
|
// структура циклу => for(<початковий стан>; <умова завершення>; <крок>)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
for (int fooFor = 0; fooFor < 10; fooFor++) {
|
|
|
|
|
System.out.println(fooFor);
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Виконається 10 разів, fooFor 0->9
|
2015-10-31 18:47:13 +00:00
|
|
|
|
}
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Значення fooFor: " + fooFor);
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Вихід із вкладеного циклу через мітку
|
2015-10-31 18:47:13 +00:00
|
|
|
|
outer:
|
|
|
|
|
for (int i = 0; i < 10; i++) {
|
|
|
|
|
for (int j = 0; j < 10; j++) {
|
|
|
|
|
if (i == 5 && j ==5) {
|
|
|
|
|
break outer;
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// вихід із зовнішнього циклу, а не лише внутрішнього
|
2015-10-31 18:47:13 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Цикл For Each
|
|
|
|
|
// Призначений для перебору масивів та колекцій
|
|
|
|
|
int[] fooList = {1, 2, 3, 4, 5, 6, 7, 8, 9};
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
for (int bar : fooList) {
|
|
|
|
|
System.out.println(bar);
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Повторюється 9 разів та друкує числа від 1 до 9 на нових рядках
|
2015-10-31 18:47:13 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Оператор вибору Switch Case
|
|
|
|
|
// Оператор вибору працює з типами даних byte, short, char, int.
|
2018-07-27 20:52:31 +00:00
|
|
|
|
// Також працює з переліками Enum,
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// класом String та класами-обгортками примітивних типів:
|
|
|
|
|
// Character, Byte, Short та Integer.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int month = 3;
|
|
|
|
|
String monthString;
|
|
|
|
|
switch (month) {
|
2015-10-31 21:12:56 +00:00
|
|
|
|
case 1: monthString = "Січень";
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
2015-10-31 21:12:56 +00:00
|
|
|
|
case 2: monthString = "Лютий";
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
2015-10-31 21:12:56 +00:00
|
|
|
|
case 3: monthString = "Березень";
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
2015-10-31 21:12:56 +00:00
|
|
|
|
default: monthString = "Інший місяць";
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Результат Switch Case: " + monthString);
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Починаючи з Java 7 і далі, вибір рядкових змінних здійснюється так:
|
2016-02-27 16:24:20 +00:00
|
|
|
|
String myAnswer = "можливо";
|
2015-10-31 18:47:13 +00:00
|
|
|
|
switch(myAnswer) {
|
2016-02-27 16:24:20 +00:00
|
|
|
|
case "так":
|
|
|
|
|
System.out.println("Ви відповіли «Так».");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
2016-02-27 16:24:20 +00:00
|
|
|
|
case "ні":
|
|
|
|
|
System.out.println("Ви відповіли «ні».");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
2016-02-27 16:24:20 +00:00
|
|
|
|
case "можливо":
|
|
|
|
|
System.out.println("Ви відповіли «Можливо».");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
|
|
|
|
default:
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Ви відповіли «" + myAnswer + "»");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Тернарний оператор вибору
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Можна використовувати оператор «?» (знак питання) для визначення умови.
|
|
|
|
|
// Читається так: «Якщо (умова) вірна, то <перше значення>, інакше
|
|
|
|
|
// <друге значення>»
|
2015-10-31 18:47:13 +00:00
|
|
|
|
int foo = 5;
|
|
|
|
|
String bar = (foo < 10) ? "A" : "B";
|
2015-10-31 21:12:56 +00:00
|
|
|
|
System.out.println(bar); // Надрукується А, бо умова вірна
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
////////////////////////////////////////
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Перетворення типів
|
2015-10-31 18:47:13 +00:00
|
|
|
|
////////////////////////////////////////
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Перетворення String на Integer
|
|
|
|
|
Integer.parseInt("123");//поверне числову версію рядка "123"
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Перетворення Integer на String
|
|
|
|
|
Integer.toString(123);//повертає рядкову версію 123
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Для інших перетворень є наступні класи:
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// Double
|
|
|
|
|
// Long
|
|
|
|
|
// String
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Приведення типів
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Тут можна прочитати про приведення об’єктів (англ.):
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// http://docs.oracle.com/javase/tutorial/java/IandI/subclasses.html
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Класи та функції
|
2015-10-31 18:47:13 +00:00
|
|
|
|
///////////////////////////////////////
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("\n->Класи та функції");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// (Клас Bicycle наведений нижче)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Новий об’єкт класу
|
2015-10-31 18:47:13 +00:00
|
|
|
|
Bicycle trek = new Bicycle();
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Виклик методу об’єкта
|
2015-10-31 21:12:56 +00:00
|
|
|
|
trek.speedUp(3); // Постійно використовуються методи з назвами set і get
|
2015-10-31 18:47:13 +00:00
|
|
|
|
trek.setCadence(100);
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// toString повертає рядкове представлення об’єкту.
|
|
|
|
|
System.out.println("Інформація про об’єкт trek: " + trek.toString());
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// У Java немає синтаксису для явного створення статичних колекцій.
|
|
|
|
|
// Це можна зробити так:
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
private static final Set<String> COUNTRIES = new HashSet<String>();
|
|
|
|
|
static {
|
|
|
|
|
validCodes.add("DENMARK");
|
|
|
|
|
validCodes.add("SWEDEN");
|
|
|
|
|
validCodes.add("FINLAND");
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Але є інший спосіб — ініціалізація з подвійними фігурними дужками.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
private static final Set<String> COUNTRIES = new HashSet<String>() {{
|
|
|
|
|
add("DENMARK");
|
|
|
|
|
add("SWEDEN");
|
|
|
|
|
add("FINLAND");
|
|
|
|
|
}}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Використовується анонімний внутрішній клас
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
} // Кінець методу main
|
|
|
|
|
} // Кінець класу LearnJava
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// У .java-файл можна додавати інші, не public класи зовнішнього рівня,
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// але це не є хорошою практикою. Розміщуйте класи в окремих файлах.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Синтаксис оголошення класу:
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// <public/private/protected> class <ім’я класу> {
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// // поля, конструктори, функції та ін.
|
|
|
|
|
// // у Java функції називаються методами.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
class Bicycle {
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Поля (змінні) класу Bicycle
|
|
|
|
|
public int cadence; // Public: доступно звідусіль
|
|
|
|
|
private int speed; // Private: доступно лише у межах класу
|
2016-02-27 16:24:20 +00:00
|
|
|
|
protected int gear; // Protected: доступно лише класові та його нащадкам
|
|
|
|
|
String name; // за замовчанням: доступно у даному пакеті
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
static String className; // статична змінна класу
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// статичний блок
|
|
|
|
|
// Java не має статичних конструкторів, але
|
|
|
|
|
// має статичний блок ініціалізації змінних класу
|
|
|
|
|
// Цей блок виконується при завантаженні класу.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
static {
|
|
|
|
|
className = "Bicycle";
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Конструктори є способом створення класу
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Оце — конструктор
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public Bicycle() {
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Можна викликати інший конструктор:
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// this(1, 50, 5, "Bontrager");
|
|
|
|
|
gear = 1;
|
|
|
|
|
cadence = 50;
|
|
|
|
|
speed = 5;
|
|
|
|
|
name = "Bontrager";
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Цей конструктор приймає аргументи
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public Bicycle(int startCadence, int startSpeed, int startGear,
|
|
|
|
|
String name) {
|
|
|
|
|
this.gear = startGear;
|
|
|
|
|
this.cadence = startCadence;
|
|
|
|
|
this.speed = startSpeed;
|
|
|
|
|
this.name = name;
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Синтаксис методу:
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// <public/private/protected> <тип повернутого значення> <ім’я методу>(<аргументи>)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Java-класи часто мають методи для отримання та встановлення змінних
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Синтаксис оголошення методу:
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// <модифікатор доступу> <тип повернутого значення> <ім’я методу>(<аргументи>)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public int getCadence() {
|
|
|
|
|
return cadence;
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// void-методи не повертають значень
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public void setCadence(int newValue) {
|
|
|
|
|
cadence = newValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void setGear(int newValue) {
|
|
|
|
|
gear = newValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void speedUp(int increment) {
|
|
|
|
|
speed += increment;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void slowDown(int decrement) {
|
|
|
|
|
speed -= decrement;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void setName(String newName) {
|
|
|
|
|
name = newName;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public String getName() {
|
|
|
|
|
return name;
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
//Метод показує значення змінних об’єкту.
|
|
|
|
|
@Override // Успадковано від класу Object.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public String toString() {
|
|
|
|
|
return "gear: " + gear + " cadence: " + cadence + " speed: " + speed +
|
|
|
|
|
" name: " + name;
|
|
|
|
|
}
|
2015-10-31 21:12:56 +00:00
|
|
|
|
} // кінець класу Bicycle
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// PennyFarthing є розширенням (нащадком) класу Bicycle
|
2015-10-31 18:47:13 +00:00
|
|
|
|
class PennyFarthing extends Bicycle {
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// (Penny Farthings мають велике переднє колесо.
|
|
|
|
|
// Вони не мають передач.)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
public PennyFarthing(int startCadence, int startSpeed){
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Виклик батьківського конструктора через super
|
2015-10-31 18:47:13 +00:00
|
|
|
|
super(startCadence, startSpeed, 0, "PennyFarthing");
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Перевизначений метод має бути відмічений аннотацією, яка починається зі знака @.
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Для ознайомлення з аннотаціями перейдіть за посиланням
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// http://docs.oracle.com/javase/tutorial/java/annotations/
|
2015-10-31 18:47:13 +00:00
|
|
|
|
@Override
|
|
|
|
|
public void setGear(int gear) {
|
|
|
|
|
gear = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Інтерфейси
|
|
|
|
|
// Синтаксис оголошення інтерфейсів
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// <рівень доступу> interface <ім’я інтерфейсу> extends <батьківський інтерфейс> {
|
|
|
|
|
// // Константи
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// // Оголошення методів
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// }
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
//Приклад — їжа (Food):
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public interface Edible {
|
2016-02-27 16:24:20 +00:00
|
|
|
|
public void eat(); // Будь-які класи, що реалізують цей інтерфейс,
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// повинні реалізувати цей метод.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public interface Digestible {
|
|
|
|
|
public void digest();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Можна створити клас, що реалізує обидва інтерфейси.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public class Fruit implements Edible, Digestible {
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
@Override
|
|
|
|
|
public void eat() {
|
|
|
|
|
// ...
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void digest() {
|
|
|
|
|
// ...
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// В Java можна успадковувати лише один клас, але реалізовувати багато
|
|
|
|
|
// інтерфейсів. Наприклад:
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public class ExampleClass extends ExampleClassParent implements InterfaceOne,
|
|
|
|
|
InterfaceTwo {
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void InterfaceOneMethod() {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void InterfaceTwoMethod() {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Абстрактні класи
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Синтаксис оголошення абстрактних класів:
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// <рівень доступу> abstract <ім’я класу> extends <батьківський абстрактний клас> {
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// // Константи і змінні
|
|
|
|
|
// // Оголошення методів
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// }
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Позначення класу як абстрактного означає, що оголошені у ньому методи мають
|
|
|
|
|
// бути реалізовані у дочірніх класах. Подібно до інтерфейсів, не можна створити екземпляри
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// абстракних класів, але їх можна успадковувати. Нащадок зобов’язаний реалізувати всі абстрактні
|
2018-10-18 16:20:37 +00:00
|
|
|
|
// методи. На відміну від інтерфейсів, абстрактні класи можуть мати як визначені,
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// так і абстрактні методи. Методи в інтерфейсах не мають тіла,
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// за винятком статичних методів, а змінні неявно мають модифікатор final, на відміну від
|
|
|
|
|
// абстрактного класу. Абстрактні класи МОЖУТЬ мати метод «main».
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
public abstract class Animal
|
|
|
|
|
{
|
|
|
|
|
public abstract void makeSound();
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Метод може мати тіло
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public void eat()
|
|
|
|
|
{
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Я тварина, і я їм.");
|
|
|
|
|
// Зауваження: є доступ до приватних змінних.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
age = 30;
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Ініціалізація не потрібна
|
2015-10-31 18:47:13 +00:00
|
|
|
|
protected int age;
|
|
|
|
|
|
|
|
|
|
public void printAge()
|
|
|
|
|
{
|
|
|
|
|
System.out.println(age);
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Абстрактні класи МОЖУТЬ мати метод «main».
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public static void main(String[] args)
|
|
|
|
|
{
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Я абстрактний");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class Dog extends Animal
|
|
|
|
|
{
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Слід помічати перевизначення абстрактних методів
|
2015-10-31 18:47:13 +00:00
|
|
|
|
@Override
|
|
|
|
|
public void makeSound()
|
|
|
|
|
{
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Гав!");
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// age = 30; ==> ПОМИЛКА! age є private для Animal
|
2015-10-31 18:47:13 +00:00
|
|
|
|
}
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Зауваження: Буде помилка, якщо використати аннотацію
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// @Override тут, так як у java не можна
|
|
|
|
|
// перевизначати статичні методи.
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Те, що тут відбувається, називається приховування методів.
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Більш детально: http://stackoverflow.com/questions/16313649/
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public static void main(String[] args)
|
|
|
|
|
{
|
|
|
|
|
Dog pluto = new Dog();
|
|
|
|
|
pluto.makeSound();
|
|
|
|
|
pluto.eat();
|
|
|
|
|
pluto.printAge();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Фінальні класи
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Синтаксис оголошення фінальних класів
|
|
|
|
|
// <рівень доступу> final <ім’я класу> {
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// // Константи і змінні
|
|
|
|
|
// // Оголошення методів
|
2015-10-31 18:47:13 +00:00
|
|
|
|
// }
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Фінальні класи не можуть мати нащадків, також самі вони є останніми нащадками.
|
|
|
|
|
// Фінальні класи є протилежністю абстрактних у цьому плані.
|
2015-10-31 21:12:56 +00:00
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public final class SaberToothedCat extends Animal
|
|
|
|
|
{
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Перевизначення методу
|
2015-10-31 18:47:13 +00:00
|
|
|
|
@Override
|
|
|
|
|
public void makeSound()
|
|
|
|
|
{
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Гррр!");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Фінальні методи
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public abstract class Mammal()
|
|
|
|
|
{
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Синтаксис фінальних методів:
|
|
|
|
|
// <модифікатор доступу> final <тип повернутого значення> <ім’я функції>(<аргументи>)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Фінальні методи не можуть бути перевизначені класом-нащадком,
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// вони є остаточною реалізацією методу.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public final boolean isWarmBlooded()
|
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Тип Enum (перелік)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
//
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Enum є спеціальним типом даних, який дозволяє змінним бути певною множиною
|
|
|
|
|
// визначених констант. Змінна має відповідати одному зі значень, що
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// заздалегідь визначені для неї. Оскільки це константи, імена типів полів у enum
|
|
|
|
|
// задаються у верхньому регістрі. Тип «перелік» у Java задається за допомогою
|
|
|
|
|
// ключового слова enum. Наприклад, перелік днів тижня можна задати так:
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
public enum Day {
|
|
|
|
|
SUNDAY, MONDAY, TUESDAY, WEDNESDAY,
|
2018-07-27 20:52:31 +00:00
|
|
|
|
THURSDAY, FRIDAY, SATURDAY
|
2015-10-31 18:47:13 +00:00
|
|
|
|
}
|
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Перелік Day можна використовувати так:
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
public class EnumTest {
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
// Змінна того же типу, що й перелік
|
2015-10-31 18:47:13 +00:00
|
|
|
|
Day day;
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public EnumTest(Day day) {
|
|
|
|
|
this.day = day;
|
|
|
|
|
}
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public void tellItLikeItIs() {
|
|
|
|
|
switch (day) {
|
|
|
|
|
case MONDAY:
|
2018-07-27 20:52:31 +00:00
|
|
|
|
System.out.println("Понеділки важкі.");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
case FRIDAY:
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("П’ятниці краще.");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
|
|
|
|
case SATURDAY:
|
2015-10-31 18:47:13 +00:00
|
|
|
|
case SUNDAY:
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Вихідні найліпші.");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
default:
|
2016-02-27 16:24:20 +00:00
|
|
|
|
System.out.println("Середина тижня так собі.");
|
2015-10-31 18:47:13 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-07-27 20:52:31 +00:00
|
|
|
|
|
2015-10-31 18:47:13 +00:00
|
|
|
|
public static void main(String[] args) {
|
|
|
|
|
EnumTest firstDay = new EnumTest(Day.MONDAY);
|
2016-02-27 16:24:20 +00:00
|
|
|
|
firstDay.tellItLikeItIs(); // => Понеділки важкі.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
EnumTest thirdDay = new EnumTest(Day.WEDNESDAY);
|
2016-02-27 16:24:20 +00:00
|
|
|
|
thirdDay.tellItLikeItIs(); // => Середина тижня так собі.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-07-27 20:52:31 +00:00
|
|
|
|
// Переліки набагато потужніші, ніж тут показано.
|
2015-10-31 21:12:56 +00:00
|
|
|
|
// Тіло переліків може містити методи та інші змінні.
|
|
|
|
|
// Дивіться більше тут: https://docs.oracle.com/javase/tutorial/java/javaOO/enum.html
|
2015-10-31 18:47:13 +00:00
|
|
|
|
```
|
|
|
|
|
|
2015-10-31 21:12:56 +00:00
|
|
|
|
## Додатково для читання
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
Посилання, наведені нижче, дозволяють тільки зрозуміти тему. Щоб знайти конкретні приклади, використовуйте Ґуґл.
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 19:35:19 +00:00
|
|
|
|
**Офіційні посібники Oracle**:
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
* [Посібник Java від Sun / Oracle](http://docs.oracle.com/javase/tutorial/index.html)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
* [Java — модифікатори доступу](http://docs.oracle.com/javase/tutorial/java/javaOO/accesscontrol.html)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
* [ООП-концепції](http://docs.oracle.com/javase/tutorial/java/concepts/index.html):
|
|
|
|
|
* [Наслідування](http://docs.oracle.com/javase/tutorial/java/IandI/subclasses.html)
|
|
|
|
|
* [Поліморфізм](http://docs.oracle.com/javase/tutorial/java/IandI/polymorphism.html)
|
|
|
|
|
* [Абстракція](http://docs.oracle.com/javase/tutorial/java/IandI/abstract.html)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 19:35:19 +00:00
|
|
|
|
* [Виключення](http://docs.oracle.com/javase/tutorial/essential/exceptions/index.html)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 19:35:19 +00:00
|
|
|
|
* [Інтерфейси](http://docs.oracle.com/javase/tutorial/java/IandI/createinterface.html)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 19:35:19 +00:00
|
|
|
|
* [параметризація](http://docs.oracle.com/javase/tutorial/java/generics/index.html)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
* [Стиль коду у Java](http://www.oracle.com/technetwork/java/codeconvtoc-136057.html)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2016-02-27 16:24:20 +00:00
|
|
|
|
**Online-практика та посібники**
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
* [Codingbat.com](http://codingbat.com/java)
|
|
|
|
|
|
2024-12-03 23:56:27 +00:00
|
|
|
|
* [Codewars - Java Katas](https://www.codewars.com/?language=java)
|
|
|
|
|
|
|
|
|
|
* [University of Helsinki - Object-Oriented programming with Java](http://moocfi.github.io/courses/2013/programming-part-1/)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
2015-10-31 19:35:19 +00:00
|
|
|
|
**Книжки**:
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
* [Head First Java](http://www.headfirstlabs.com/books/hfjava/)
|
|
|
|
|
|
2024-05-13 07:38:52 +00:00
|
|
|
|
* [Thinking in Java](https://www.amazon.com/Thinking-Java-4th-Bruce-Eckel/dp/0131872486/)
|
2015-10-31 18:47:13 +00:00
|
|
|
|
|
|
|
|
|
* [Objects First with Java](http://www.amazon.com/Objects-First-Java-Practical-Introduction/dp/0132492660)
|
|
|
|
|
|
|
|
|
|
* [Java The Complete Reference](http://www.amazon.com/gp/product/0071606300)
|