learnxinyminutes-docs/uk-ua/java-ua.html.markdown

783 lines
33 KiB
Markdown
Raw Normal View History

---
language: java
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-11-01 00:12:56 +03:00
- ["Oleksandr Tatarchuk", "https://github.com/tatarchuk"]
2015-11-01 00:20:04 +03:00
filename: LearnJava.java
lang: uk-ua
---
Java є об'єктно-орієнтованою мовою програмування загального призначення з підтримкою паралельного програмування, яка базується на класах.
[Read more here.](http://docs.oracle.com/javase/tutorial/java/)
```java
// Однорядковий коментар починається з //
/*
Багаторядковий коментар виглядає так.
*/
/**
JavaDoc коментар виглядає так. Використовується для опису класу та членів класу.
*/
// Імпорт класу ArrayList з пакету java.util
import java.util.ArrayList;
// Імпорт усіх класів з пакету java.security
import java.security.*;
// Кожний .java файл містить один зовнішній публічний клас, ім'я якого співпадає
// з і менем файлу.
public class LearnJava {
// Для запуску програма, написана на java, повинна мати точку входу у вигляді методу main.
public static void main (String[] args) {
// Використання System.out.println() для виводу на друк рядків.
System.out.println("Hello World!");
System.out.println(
"Integer: " + 10 +
" Double: " + 3.14 +
" Boolean: " + true);
// Для друку з нового рядкка використовується System.out.print().
System.out.print("Hello ");
System.out.print("World");
// Використання System.out.printf() для простого форматованого виводу на друк.
System.out.printf("pi = %.5f", Math.PI); // => pi = 3.14159
///////////////////////////////////////
// Змінні
///////////////////////////////////////
/*
* Оголошення змінних
*/
// Для оголошення змінних використовується формат <тип> <змінна>
int fooInt;
// Оголошення декількох змінних одного типу <тип> <ім'я1>, <ім'я2>, <ім'я3>
int fooInt1, fooInt2, fooInt3;
/*
* Ініціалізація змінних
*/
// Ініціалізація змінної з використанням формату <тип> <ім'я> = <значення>
int fooInt = 1;
// Ініціалізація декількох змінних одного типу з одним значенням <тип> <ім'я1>, <ім'я2>, <ім'я3> = <значення>
int fooInt1, fooInt2, fooInt3;
fooInt1 = fooInt2 = fooInt3 = 1;
/*
* Типи змінних
*/
// Байт - 8-бітне ціле число зі знаком
// (-128 <= byte <= 127)
byte fooByte = 100;
// Short - 16-бітне ціле число зі знаком
// (-32,768 <= short <= 32,767)
short fooShort = 10000;
// Integer - 32-бітне ціле число зі знаком
// (-2,147,483,648 <= int <= 2,147,483,647)
int fooInt = 1;
// Long - 64-бітне ціле число зі знаком
// (-9,223,372,036,854,775,808 <= long <= 9,223,372,036,854,775,807)
long fooLong = 100000L;
// L використовується для позначення того, що число має тип Long;
// інакше число буде трактуватись як integer.
// Примітка: Java не має беззнакових типів.
// Float - 32-бітне число з плаваючою комою одиничної точності за стандартом IEEE 754
// 2^-149 <= float <= (2-2^-23) * 2^127
float fooFloat = 234.5f;
// f or F використовується для позначення того, що змінна має тип float;
// інакше трактується як double.
// Double - 64-бітне число з плаваючою комою подвійної точності за стандартом IEEE 754
// 2^-1074 <= x <= (2-2^-52) * 2^1023
double fooDouble = 123.4;
// Boolean - true & false (істина чи неправда)
boolean fooBoolean = true;
boolean barBoolean = false;
// Char - 16-бітний символ Unicode
char fooChar = 'A';
// final - посилання на такі змінні не можуть бути присвоєні іншим об'єктам,
final int HOURS_I_WORK_PER_WEEK = 9001;
// але вони можуть мати відкладену ініціалізацію.
final double E;
E = 2.71828;
// BigInteger -Незмінні знакові цілі числа довільної точності
//
// BigInteger є типом даних, який дає можливість розробнику виконувати операції з
// з цілими числами, розрядність яких більша за 64 біти. Числа зберігаються у масиві
// байтів, операції над ними виконуються функціями, які має клас BigInteger
//
// BigInteger можна ініціалізувати, використовуючи масив байтів чи рядок.
BigInteger fooBigInteger = new BigInteger(fooByteArray);
// BigDecimal - Незмінні знакові дробові числа довільної точності
//
// BigDecimal складається з двох частин: цілого числа довільної точності
// з немасштабованим значенням та 32-бітного масштабованого цілого числа
//
// BigDecimal дозволяє розробника контролювати десяткове округлення.
// Рекомндовано використовувати BigDecimal зі значеннями валют
// і там, де необхідна точність дробових обчислень.
//
// BigDecimal може бути ініціалізований типами даних int, long, double or String
// чи немасштабованим значенням (BigInteger) і масштабованим значенням (int).
BigDecimal fooBigDecimal = new BigDecimal(fooBigInteger, fooInt);
// Для дотримання заданої точності рекомендується використовувати
// конструктор, який приймає String
BigDecimal tenCents = new BigDecimal("0.1");
// Рядки
String fooString = "Це мій рядок!";
// \n символ переходу на новий рядок
String barString = "Друк з нового рялка?\nНема питань!";
// \t символ табуляції
String bazString = "Хочете додати табуляцію?\tТримайте!";
System.out.println(fooString);
System.out.println(barString);
System.out.println(bazString);
// Масиви
// Розмір масиву має бути визначений перед ініціалізацією
// Наведений формат ілюструє ініціалізацію масивів
// <тип даних>[] <ім'я змінної> = new <тип даних>[<розмір масиву>];
// <тип даних> <ім'я змінної>[] = new <тип даних>[<розмір масиву>];
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};
// Індексація масиву - доступ за елементами
System.out.println("intArray @ 0: " + intArray[0]);
// Масиви є змінними та мають нульовий елемент.
intArray[1] = 1;
System.out.println("intArray @ 1: " + intArray[1]); // => 1
// Додатково
// ArrayLists - Схожі на масив, але мають більший функціонал та змінний розмір.
// LinkedLists - Реалізація двозв'язного списку. Всі операції
// виконуються так, як очікується від
// двозв'язного списку.
// Maps - Множина об'єктів, які пов'язують ключ зі значенням. Map є
// інтерфейсом, тому не може бути успадкований.
// Типи ключів і значень, які зберігаються в Map мають
// вказуватись у класі, який його реалізує.
// Ключ не може повторюватись і пов'язаний лише з одним значенням
// HashMaps - Цей клас використовує хеш-таблицю для реалізації інтерфейсу Map.
// Це дозволяє виконувати певні операції,
// такі як отримання та вставка елемента,
// за сталий час для будь-якої кількості значень.
///////////////////////////////////////
// Оператори
///////////////////////////////////////
System.out.println("\n->Operators");
int i1 = 1, i2 = 2; // Коротка форма присвоєння
// Арифметичні операції виконуються
System.out.println("1+2 = " + (i1 + i2)); // => 3
System.out.println("2-1 = " + (i2 - i1)); // => 1
System.out.println("2*1 = " + (i2 * i1)); // => 2
System.out.println("1/2 = " + (i1 / i2)); // => 0 (int/int повертається як int)
System.out.println("1/2 = " + (i1 / (double)i2)); // => 0.5
// Ділення з остачею
System.out.println("11%3 = "+(11 % 3)); // => 2
// Оператори порівняння
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
// Логічні оператори
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
// Бітові оператори!
/*
~ Унарне бітове доповнення
<< Знаковий зсув уліво
>> Знаковий/Арифметичний зсув управо
>>> Беззнаковий/Логічний зсув управо
& Бітове І
^ Бітови виключне АБО
| Бітове АБО
*/
// Інкремнт
int i = 0;
System.out.println("\n->Інкремент/Декремент");
// Оператори ++ і -- здійснюють інкремент та декремент ретроспективно.
// Якщо вони розташовані перед змінною, операція виконається перед поверненням;
// після - повернеться інкремент або декремент.
System.out.println(i++); // i = 1, prints 0 (post-increment)
System.out.println(++i); // i = 2, prints 2 (pre-increment)
System.out.println(i--); // i = 1, prints 2 (post-decrement)
System.out.println(--i); // i = 0, prints 0 (pre-decrement)
///////////////////////////////////////
2015-11-01 00:12:56 +03:00
// Управляючі конструкції
///////////////////////////////////////
System.out.println("\n->Control Structures");
2015-11-01 00:12:56 +03:00
// Оператор if використовується так само, як у мові С
int j = 10;
if (j == 10) {
2015-11-01 00:12:56 +03:00
System.out.println("Це надрукується");
} else if (j > 10) {
2015-11-01 00:12:56 +03:00
System.out.println("А це - ні");
} else {
2015-11-01 00:12:56 +03:00
System.out.println("Це - також ні");
}
2015-11-01 00:12:56 +03:00
// Цикл з передумовою While
int fooWhile = 0;
while(fooWhile < 100) {
System.out.println(fooWhile);
2015-11-01 00:12:56 +03:00
// Інкремент лічильника
// Виконається 100 разів, fooWhile 0,1,2...99
fooWhile++;
}
System.out.println("fooWhile Value: " + fooWhile);
2015-11-01 00:12:56 +03:00
// Цикл з післяумовою Do While
int fooDoWhile = 0;
do {
System.out.println(fooDoWhile);
2015-11-01 00:12:56 +03:00
// Інкремент лічильника
// Виконається 99 разів, fooDoWhile 0->99
fooDoWhile++;
} while(fooDoWhile < 100);
System.out.println("fooDoWhile Value: " + fooDoWhile);
2015-11-01 00:12:56 +03:00
// Цикл з параметром For
// структура циклу => for(<початковий стан>; <умова завершення>; <крок>)
for (int fooFor = 0; fooFor < 10; fooFor++) {
System.out.println(fooFor);
2015-11-01 00:12:56 +03:00
// Виконається 10 разів, fooFor 0->9
}
System.out.println("fooFor Value: " + fooFor);
2015-11-01 00:12:56 +03:00
// Вихід з вкладеного циклу через Label
outer:
for (int i = 0; i < 10; i++) {
for (int j = 0; j < 10; j++) {
if (i == 5 && j ==5) {
break outer;
2015-11-01 00:12:56 +03:00
// вихід із зовнішнього циклу, а не лише внутрішнього
}
}
}
2015-11-01 00:12:56 +03:00
// Цикл For Each
// Призначений для перебору масивів та колекцій
int[] fooList = {1, 2, 3, 4, 5, 6, 7, 8, 9};
for (int bar : fooList) {
System.out.println(bar);
//Iterates 9 times and prints 1-9 on new lines
}
2015-11-01 00:12:56 +03:00
// Оператор вибору Switch Case
// Оператор вибору працює з типами даних byte, short, char, int.
// Також працює з переліками Enum,
// класом String та класами-обгортками примітивних типів:
// Character, Byte, Short та Integer.
int month = 3;
String monthString;
switch (month) {
2015-11-01 00:12:56 +03:00
case 1: monthString = "Січень";
break;
2015-11-01 00:12:56 +03:00
case 2: monthString = "Лютий";
break;
2015-11-01 00:12:56 +03:00
case 3: monthString = "Березень";
break;
2015-11-01 00:12:56 +03:00
default: monthString = "Інший місяць";
break;
}
2015-11-01 00:12:56 +03:00
System.out.println("Switch Case результат: " + monthString);
2015-11-01 00:12:56 +03:00
// Починаючи з Java 7 і далі, вибір рядкових змінних здійснюється так:
String myAnswer = "maybe";
switch(myAnswer) {
case "yes":
System.out.println("You answered yes.");
break;
case "no":
System.out.println("You answered no.");
break;
case "maybe":
System.out.println("You answered maybe.");
break;
default:
System.out.println("You answered " + myAnswer);
break;
}
2015-11-01 00:12:56 +03:00
// Тернарний оператор вибору
// Можна використовувати '?' оператор для визначення умови.
// Читається так "Якщо (умова) вірна, то <перше значення>, інакше
// <друге значення"
int foo = 5;
String bar = (foo < 10) ? "A" : "B";
2015-11-01 00:12:56 +03:00
System.out.println(bar); // Надрукується А, бо умова вірна
////////////////////////////////////////
2015-11-01 00:12:56 +03:00
// Перетворення типів
////////////////////////////////////////
2015-11-01 00:12:56 +03:00
// Перетворення String на Integer
Integer.parseInt("123");//поверне числову версію рядка "123"
2015-11-01 00:12:56 +03:00
// Перетворення Integer на String
Integer.toString(123);//повертає рядкову версію 123
2015-11-01 00:12:56 +03:00
// Для інших перетворень є наступні класи:
// Double
// Long
// String
2015-11-01 00:12:56 +03:00
// Приведення типів
// Тут можна прочитати про приведення об'єктів:
// http://docs.oracle.com/javase/tutorial/java/IandI/subclasses.html
///////////////////////////////////////
2015-11-01 00:12:56 +03:00
// Класи та функції
///////////////////////////////////////
System.out.println("\n->Classes & Functions");
2015-11-01 00:12:56 +03:00
// (Клас Bicycle наведений нижче)
2015-11-01 00:12:56 +03:00
// Новий об'єкт класу
Bicycle trek = new Bicycle();
2015-11-01 00:12:56 +03:00
// Виклик методу об'єкта
trek.speedUp(3); // Постійно використовуються методи з назвами set і get
trek.setCadence(100);
2015-11-01 00:12:56 +03:00
// toString повертає рядкове представленя об'єкту.
System.out.println("trek info: " + trek.toString());
2015-11-01 00:12:56 +03:00
// У Java немає синтаксису для явного створення статичних колекцій.
// Це можна зробити так:
private static final Set<String> COUNTRIES = new HashSet<String>();
static {
validCodes.add("DENMARK");
validCodes.add("SWEDEN");
validCodes.add("FINLAND");
}
2015-11-01 00:12:56 +03:00
// Але є інший спосіб - Double Brace Initialization.
private static final Set<String> COUNTRIES = new HashSet<String>() {{
add("DENMARK");
add("SWEDEN");
add("FINLAND");
}}
2015-11-01 00:12:56 +03:00
// Використовується анонімний внутрішній клас
2015-11-01 00:12:56 +03:00
} // Кінець методу main
} // Кінець класу LearnJava
2015-11-01 00:12:56 +03:00
// Можна додавати інші, не public класи зовнішнього рівня у .java файл,
// але це не є хорошою практикою. Розміщуйте класи в окремих файлах.
2015-11-01 00:12:56 +03:00
// Синтаксис оголошення класу:
// <public/private/protected> class <class name> {
2015-11-01 00:12:56 +03:00
// // поля, конструктори, функції та ін.
// // у Java функції називаються методами.
// }
class Bicycle {
2015-11-01 00:12:56 +03:00
// Поля (змінні) класу Bicycle
public int cadence; // Public: доступно звідусіль
private int speed; // Private: доступно лише у межах класу
protected int gear; // Protected: доступно лише класу та нащадкам
String name; // default: доступно у даному пакеті
2015-11-01 00:12:56 +03:00
static String className; // статична змінна класу
2015-11-01 00:12:56 +03:00
// статичний блок
// Java не має статичних конструкторів, але
// має статичний блок ініціалізації змінних класу
// Цей блок виконується при завантаженні класу.
static {
className = "Bicycle";
}
2015-11-01 00:12:56 +03:00
// Конструктори є способом створення класу
// Це - конструктор
public Bicycle() {
2015-11-01 00:12:56 +03:00
// Можна викликати інший конструктор:
// this(1, 50, 5, "Bontrager");
gear = 1;
cadence = 50;
speed = 5;
name = "Bontrager";
}
2015-11-01 00:12:56 +03:00
// Цей конструктор приймає аргументи
public Bicycle(int startCadence, int startSpeed, int startGear,
String name) {
this.gear = startGear;
this.cadence = startCadence;
this.speed = startSpeed;
this.name = name;
}
2015-11-01 00:12:56 +03:00
// Синтаксис методу:
// <public/private/protected> <тип повернутого значення> <ім'я методу>(<аргументи>)
2015-11-01 00:12:56 +03:00
// Java класи часто мають методи для отримання та встановлення змінних
2015-11-01 00:12:56 +03:00
// Синтаксис оголошення методу:
// <модифікатор доступу> <тип повернутого значення> <ім'я методу>(<аргументи>)
public int getCadence() {
return cadence;
}
2015-11-01 00:12:56 +03:00
// void методи не повертають значень
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;
}
2015-11-01 00:12:56 +03:00
//Метод показує значення змінних об'єкту.
@Override // Inherited from the Object class.
public String toString() {
return "gear: " + gear + " cadence: " + cadence + " speed: " + speed +
" name: " + name;
}
2015-11-01 00:12:56 +03:00
} // кінець класу Bicycle
2015-11-01 00:12:56 +03:00
// PennyFarthing є розширенням (нащадком) класу Bicycle
class PennyFarthing extends Bicycle {
2015-11-01 00:12:56 +03:00
// (Penny Farthings мають велике переднє колесо.
// Вони не мають передач.)
public PennyFarthing(int startCadence, int startSpeed){
2015-11-01 00:12:56 +03:00
// Виклик батьківського конструктора через super
super(startCadence, startSpeed, 0, "PennyFarthing");
}
2015-11-01 00:12:56 +03:00
// Перевизначений метод має відти відмічений аннотацією @annotation.
// Для ознайомлення з аннотаціями перейдіть за посиланням
// out: http://docs.oracle.com/javase/tutorial/java/annotations/
@Override
public void setGear(int gear) {
gear = 0;
}
}
2015-11-01 00:12:56 +03:00
// Інтерфейси
// Синтаксис оголошення інтерфейсів
// <рівень доступу> interface <ім'я інтерфейсу> extends <супер-інтерфейс> {
// // Констатнти
// // Оголошення методів
// }
2015-11-01 00:12:56 +03:00
//Приклад - Food:
public interface Edible {
2015-11-01 00:12:56 +03:00
public void eat(); // Будь-які класи, що реалізують цей інтерфейс
// повинні реалізувати цей метод.
}
public interface Digestible {
public void digest();
}
2015-11-01 00:12:56 +03:00
// Можна створити клас, що реалізує обидва інтерфейси.
public class Fruit implements Edible, Digestible {
@Override
public void eat() {
// ...
}
@Override
public void digest() {
// ...
}
}
2015-11-01 00:12:56 +03:00
// В Java можна успадковувати лише один клас, але реалізовувати багато
// інтерфейсів. Наприклад:
public class ExampleClass extends ExampleClassParent implements InterfaceOne,
InterfaceTwo {
@Override
public void InterfaceOneMethod() {
}
@Override
public void InterfaceTwoMethod() {
}
}
2015-11-01 00:12:56 +03:00
// Абстрактні класи
2015-11-01 00:12:56 +03:00
// Синтаксис оголошення абстрактних класів:
// <ріаень доступу> abstract <ім1я класу> extends <супер-абстрактний клас> {
// // Константи і змінні
// // Оголошення методів
// }
2015-11-01 00:12:56 +03:00
// Позначення класу як абстрактного означає, що оголошені у ньому методи мають
// бути реалізовані у дочірніх класах. Подібно до інтерфейсів, не можна створити екземпляри
// абстракних класів, але їх можна успадковувати. Нащадок зобов'язаний реалізувати всі абстрактні
// методи. на відміну від інтерфейсів, абстрактні класи можуть мати як визначені,
// так і абстрактні методи. Методи в інтерфейсах не мають тіла,
// за вийнятком статичних методів, а змінні неявно мають модифікатор final, на відміну від
// абстрактного класу. Абстрактні класи МОЖУТЬ мати метод "main".
public abstract class Animal
{
public abstract void makeSound();
2015-11-01 00:12:56 +03:00
// Метод може мати тіло
public void eat()
{
System.out.println("I am an animal and I am Eating.");
2015-11-01 00:12:56 +03:00
// Зауваження: є доступ до privat змінних.
age = 30;
}
2015-11-01 00:12:56 +03:00
// Ініціалізація не потрібна
protected int age;
public void printAge()
{
System.out.println(age);
}
2015-11-01 00:12:56 +03:00
// Абстрактні класи МОЖУТЬ мати метод "main".
public static void main(String[] args)
{
System.out.println("I am abstract");
}
}
class Dog extends Animal
{
2015-11-01 00:12:56 +03:00
// Слід помічати перевизначення абстрактних методів
@Override
public void makeSound()
{
System.out.println("Bark");
2015-11-01 00:12:56 +03:00
// age = 30; ==> ПОМИЛКА! age є private для Animal
}
2015-11-01 00:12:56 +03:00
// NOTE: Буде помилка, якщо використати аннотацію
// @Override тут, так як у java не можна
// перевизначати статичні методи.
// Те, що тут відбувається, називається METHOD HIDING.
// Більш детально: http://stackoverflow.com/questions/16313649/
public static void main(String[] args)
{
Dog pluto = new Dog();
pluto.makeSound();
pluto.eat();
pluto.printAge();
}
}
2015-11-01 00:12:56 +03:00
// Final класи
2015-11-01 00:12:56 +03:00
// Синтаксис оголошення Final класів
// <рівень доступу> final <ім'я класу> {
// // Константи і змінні
// // Оголошення методів
// }
2015-11-01 00:12:56 +03:00
// Final не можуть мати нащадків, також самі вони є останніми нащадками.
// Final класи є протилежністю абстрактних у цьому плані.
public final class SaberToothedCat extends Animal
{
2015-11-01 00:12:56 +03:00
// Перевизначення методу
@Override
public void makeSound()
{
System.out.println("Roar");
}
}
2015-11-01 00:12:56 +03:00
// Final методи
public abstract class Mammal()
{
2015-11-01 00:12:56 +03:00
// Синтаксис Final методів:
// <модифікаор доступу> final <тип повернутого значення> <ім'я функції>(<аргументи>)
2015-11-01 00:12:56 +03:00
// Final методи не можуть бути перевизначені класом-нащадком,
// вони є остаточною реалізацією методу.
public final boolean isWarmBlooded()
{
return true;
}
}
2015-11-01 00:12:56 +03:00
// Тип Enum (перелік)
//
2015-11-01 00:12:56 +03:00
// Enum є спеціальним типом даних, який дозволяє змінним бути певною множиною
// визначених констант. Змінна має відповідати одному зі значень, що
// заздалегідь визначені для неї. Так як це константи, імена типів полів у enum
// задаються у верхньому регістрі. У Java задається тип переліку за допомогою
// ключового слова. Наприклад, перелік днів тижня можна задати так:
public enum Day {
SUNDAY, MONDAY, TUESDAY, WEDNESDAY,
THURSDAY, FRIDAY, SATURDAY
}
2015-11-01 00:12:56 +03:00
// Можна використовувати перелік Day так:
public class EnumTest {
// Variable Enum
Day day;
public EnumTest(Day day) {
this.day = day;
}
public void tellItLikeItIs() {
switch (day) {
case MONDAY:
System.out.println("Mondays are bad.");
break;
case FRIDAY:
System.out.println("Fridays are better.");
break;
case SATURDAY:
case SUNDAY:
System.out.println("Weekends are best.");
break;
default:
System.out.println("Midweek days are so-so.");
break;
}
}
public static void main(String[] args) {
EnumTest firstDay = new EnumTest(Day.MONDAY);
firstDay.tellItLikeItIs(); // => Mondays are bad.
EnumTest thirdDay = new EnumTest(Day.WEDNESDAY);
thirdDay.tellItLikeItIs(); // => Midweek days are so-so.
}
}
2015-11-01 00:12:56 +03:00
// Переліки набагато потужніші, ніж тут показано.
// Тіло переліків може містити методи та інші змінні.
// Дивіться більше тут: https://docs.oracle.com/javase/tutorial/java/javaOO/enum.html
```
2015-11-01 00:12:56 +03:00
## Додатково для читання
The links provided here below are just to get an understanding of the topic, feel free to Google and find specific examples.
2015-10-31 22:35:19 +03:00
**Офіційні посібники Oracle**:
* [Java Tutorial Trail from Sun / Oracle](http://docs.oracle.com/javase/tutorial/index.html)
2015-10-31 22:35:19 +03:00
* [Java модифікатори доступу](http://docs.oracle.com/javase/tutorial/java/javaOO/accesscontrol.html)
2015-10-31 22:35:19 +03:00
* [ООП концепції](http://docs.oracle.com/javase/tutorial/java/concepts/index.html):
* [Inheritance](http://docs.oracle.com/javase/tutorial/java/IandI/subclasses.html)
* [Polymorphism](http://docs.oracle.com/javase/tutorial/java/IandI/polymorphism.html)
* [Abstraction](http://docs.oracle.com/javase/tutorial/java/IandI/abstract.html)
2015-10-31 22:35:19 +03:00
* [Виключення](http://docs.oracle.com/javase/tutorial/essential/exceptions/index.html)
2015-10-31 22:35:19 +03:00
* [Інтерфейси](http://docs.oracle.com/javase/tutorial/java/IandI/createinterface.html)
2015-10-31 22:35:19 +03:00
* [параметризація](http://docs.oracle.com/javase/tutorial/java/generics/index.html)
* [Java Code Conventions](http://www.oracle.com/technetwork/java/codeconvtoc-136057.html)
2015-10-31 22:35:19 +03:00
**Online практика та посібники**
* [Learneroo.com - Learn Java](http://www.learneroo.com)
* [Codingbat.com](http://codingbat.com/java)
2015-10-31 22:35:19 +03:00
**Книжки**:
* [Head First Java](http://www.headfirstlabs.com/books/hfjava/)
* [Thinking in Java](http://www.mindview.net/Books/TIJ/)
* [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)