Java Multicore Programming: Lecture #1

в 13:20, , рубрики: java, multithreading, Блог компании GolovachCourses, многопоточное программирование, параллельное программирование, метки: , ,

Добрый день.
15 мая была проведен первый вебинар (из 16) курса «Multicore programming in Java». Вебинары, видео в записи, исходный код программ и проверка заданий доступны только записавшимся на курс (запись еще открыта, свяжитесь по контактам внизу страницы). Но тут я бы хотел опубликовать материалы, упоминавшиеся на лекции: ссылки на источники, термины, картинки, задание. Возможно кто-то сочтет их полезными для себя.

Введение

“Железо”

Стоит «посмотреть картинки» в следующих источниках

Учебники

Maurice Herlihy, Nir Shavit, “The Art of Multiprocessor Programming”: «Hardware Basics» page 469-482

«Картинки»

Memory hierarchy #1
Java Multicore Programming: Lecture #1

Memory hierarchy #2
Java Multicore Programming: Lecture #1

Memory hierarchy #3
Java Multicore Programming: Lecture #1

Типичное время доступа к разным уровням памяти
Java Multicore Programming: Lecture #1

Примеры регистров конкретного процессора
Java Multicore Programming: Lecture #1

Схематичное взаимодействие контроллеров кэшей
Java Multicore Programming: Lecture #1

False sharing: код
Java Multicore Programming: Lecture #1

False sharing: эффект (отрицательная масштабируемость)
Java Multicore Programming: Lecture #1

Плохое соответствие между ядрами, кэшами и данными
Java Multicore Programming: Lecture #1

Хорошее соответствие между ядрами, кэшами и данными
Java Multicore Programming: Lecture #1

Термины

Термины
CPU, core, multicore era, memory wall, memory hierarchy, registers, L1/L2/L3 caches, cache line, false sharing, memory padding, cache pollution, cache miss, SMP, NUMA, multisocket, thread affinity

Что читать по терминам
— Mechanical Sympathy: «CPU Cache Flushing Fallacy»
— Mechanical Sympathy: «Memory Access Patterns Are Important»
— Mechanical Sympathy: «False Sharing»
— Mechanical Sympathy: «False Sharing && Java 7»
— Руслан Черемин: «False sharing»
— Руслан Черемин: «Cache coherency #3: false sharing»
— Руслан Черемин: «How caching affects hashing»

Задание к Лекции #1

Написать утилитарный класс (в варианте A или в обоих вариантах (А и В)), который возвращает следующие характеристики процессора
— размер кэш-линии
— количество и размеры кэшей (L1, L2, L3)
— количество ядер
— определяет SMP или NUMA архитектура
A) путем «постановки программных экспериментов». Рекомендуется прочитать статью «Gallery of Processor Cache Effects» (на лекции #2 разберем примеры из статьи и наметим пути решения задачи)
B) путем использования JNA для вызовов API операционной системы

public class HardwareSpy {
    public int cacheLineSize() {...}
    public int cacheL1Size() {...} // -1 если считается, что нет L1
    public int cacheL2Size() {...} // -1 если считается, что нет L2
    public int cacheL3Size() {...} // -1 если считается, что нет L3
    public int coreCount() {...}
    public int isSMP() {...}
    public int isNUMA() {...}
}

Контакты

skype: GolovachCources
email: GolovachCources@gmail.com

Автор: IvanGolovach

Источник

* - обязательные к заполнению поля


https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js