Git commands

Initialize a repository

git init

Clone a repository

git clone <repository_url>

Check repository status

git status

Add files to staging area

git add <file> # Add specific file git add . # Add all files

Commit changes

git commit -m "Commit message"

View commit history

git log

Create a new branch

git branch <branch_name>

Switch branches

git checkout <branch_name> git switch <branch_name> # (Preferred in newer Git versions)

Create and switch to a new branch

git checkout -b <branch_name> git switch -c <branch_name> # (Newer Git versions)

Merge a branch into the current branch

git merge <branch_name>

Delete a branch

git branch -d <branch_name>

Check remote repositories

git remote -v

Push changes to a remote repository

git push origin <branch_name>

Pull latest changes from remote

git pull origin <branch_name>

Fetch changes from remote without merging

git fetch origin

Undo the last commit (discard changes)

git reset --hard HEAD~1

Revert a specific commit (without losing history)

git revert <commit_hash>

Stash uncommitted changes

git stash

Apply the last stash

git stash pop

Cherry-pick a commit from another branch

git cherry-pick <commit_hash>

Squash multiple commits into one

git rebase -i HEAD~n

Stream

Map<Integer, Integer> map = new HashMap<>();
// Collection.stream() + Stream.forEach()
        map.values().stream()
                .forEach(System.out::println);
map.keySet().stream()
                .forEach(System.out::println);
TreeSet<Integer> set = new TreeSet<>();
set.forEach(integer -> {
            System.out.print(integer + " ");
        });

Read from console

Scanner in = new Scanner(System.in);
String name = in.nextLine();
int number = in.nextInt();
//input from file
FileInputStream inputStream = new FileInputStream(name);
    int max = 0;
    while (inputStream.available() > 0) //пока остались непрочитанные байты
    {
        int data = inputStream.read(); //прочитать очередной байт
        if (data>max){
            max = data;
        }
    }
    System.out.println(max);
    inputStream.close();
}

Java collections

List — хранит упорядоченные елементы(могут быть одинаковые); Имеет такие реализации как LinkedList, ArrayList и Vector.

ArrayList

LinkedList

Когда использовать ArrayList и LinkedList?

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

 

Set — коллекции, которые не содержат повторяющихся элементов.

Реализации: HashSet, TreeSet, LinkedHashSet

  • TreeSet — упорядочивает элементы по их значениям;
  • HashSet — упорядочивает элементы по их хэш ключам
  • LinkedHashSet — хранит элементы в порядке их добавления


Queue — интерфейс для реализации очереди.

Основные реализации: LinkedList, PriorityQueue.

принцип FIFO – first in first out.

Map — интерфейс для реализации элементов с их ключами.

Основные реализации: HashTable, HashMap, TreeMap, LinkedHashMap

  • HashTable — синхронизирована, объявлена уставревшей.
  • HashMap — порядок елементов рассчитывается по хэш ключу;
  • TreeMap — элементы хранятся в отсортированном порядке
  • LinkedHashMap — элементы хранятся в порядке вставки

Ключи в Мар не одинаковые

Java: циклы for, while, foreach, do..while

Цикл for от 0 до 5:

for (int i = 0; i < 5; i++){
    System.out.println(i);
}

Hint! В IDE Idea ввести fori + tab

Обратный отсчет, цикл while:

int i = 10;
while (i > 0){

    System.out.println(i);
    i--;
}

Массив, значения:

int numbers [] = {7, 12, 8, 12};
for (int i=0; i<numbers.length; i++)
{

    System.out.println(numbers[i]);
}

Цикл for each (аналог примера выше):

int numbers [] = {7, 12, 8, 12};
for (int number : numbers) {
    System.out.println(number);

Hint! В IDE Idea ввести iter + enter

Цикл с do while:

int i = 10;
do {
    System.out.println(i);
    i++;
} while (i < 15);