Абсолютно запрещено употребление ругательств, мат. Запрещены упоминания политических тем, а также оскорбления человека и животных по любым признакам.
Название файла, содержащего заметку, пишется на английском языке. В имени должна быть информация о том, что это за заметка и про какую тему будет идти речь.
Если в названии более одного слова, то вместо пробела слова связываются символом нижнего подчеркивания _
.
Например:
abstract_class.md
Заметки логически группируются по директориям. Принцип группирования тот же, что и в группировке классов по пакетам.
Сначала выбираете область, к которой относится ваша статья, например, web
или jcore
.
Возвращаясь к нашему примеру с abstract_class.md
: так как эта заметка относится к абстрактным классам в Java, то логично положить ее будет в jcore
. Однако, можно более точно описать область, к которой она относится - это ООП в Java. Значит, логично будет поместить ее в jcore/oop
.
Памятка:
Директория | Описание |
---|---|
algorithms | Алгоритмы, структуры данных |
build | Все, что касается сборки и ci/cd |
course | Курсы (HSE, MIPT, Zero to Hero) |
db | Секция баз данных |
frameworks | Фреймворки |
images | Хранилище картинок и ресурсов для статей |
interview | Задачи с собеседований |
jcore | Основные темы Java |
logging | Логгирование |
patterns | Паттерны: архитектурные, программирования (GoF), проекта |
testing | Секция про тестирование |
web | Веб и все, что с ним связано |
other | Все, что не вошло в другие разделы |
kafka | Статьи про кафку |
zookeeper | Статьи про zookeeper |
serialization | Статьи про сериализацию/десериализацию |
Обращайте внимание на подпапки в директориях: это поможет детальнее подойти к выбору места для заметки.
Шаблон для оформления находится здесь: Pull Request Template
Ниже даны пояснения по разделам.
Каждая заметка должна иметь заголовок, оформленный в виде h1
.
Заголовок должен коротко передавать суть заметки и содержать не более 3-4 слов.
Крайне нежелательно в заголовок выносить какие-то цифры, менять регистр как вздумается и использование табуляции.
После h1
заголовка статьи следует блок Введение
, чья задача - это ввести читателя в рассматриваемую тему или проблему. Либо добавить деталей о том, что за материал будет дальше изложен.
До введения следует расположить блок ToC
: Table of Contents. Это блок оглавления и навигации.
После заголовка начинается основная часть статьи, каждый логический блок выделяется через h2
-заголовок.
Каждый блок может также дробиться, выделяя новые блоки через h3
и так далее.
Каждый блок отделется переносом строки до и после.
Значимые и ключевые слова выделяются с помощью ``.
Если в статье используется какой-то класс из JDK
, либо из библиотеки, то имя класса используется полное, с указанием имени пакета и библиотеки.
Желательно избегать сокращений, либо в начале явно читателю показать, что вы сокращаете некоторое имя и далее будет использоваться сокращенная форма.
Примером может служить java.lang.NullPointerException
, где вы можете указать, что здесь и далее будет использовано сокращение NPE
.
Если рассматриваемый материал пересекается или ссылается на отдельную заметку будет не лишним дать на неё ссылку.
Необходимо делать скидку на то, что уровень читателя может разниться. Поэтому избегайте переосложнений и сленга.
Старайтесь давать примеры кода и оформлять их в виде:
```java // some code ```.
В качестве заключения пишется краткий обзор рассмотренного материала, с выделением наиболее занчимых мест.
После заключения обязательно необходимо указать блок полезных ссылок, которые помогут либо в дальнейшем, более глубоком изучении материала, либо были использованы для основы статьи.
В самом конце можно выделить блок для вынесения благодарностей для тех, кто помог в создании статьи: делал ревью, консультировал, предлагал материалы и т.д.
Изображения хранятся в директории images
репозитория. Под каждую статью выделяется своя директория. Структура должна повторять то, как расположена статья.
Например, если ваша статья - это jcore/oop/abstract_class.md
, то изображения для нее должны располагаться в директории images/jcore/oop/abstract_class
.
Изображения, используемые в заметках и статьях, хранятся в формате png
или jpg
.
Я использую draw.io в качестве редактора.
В качесте ориентира того, как я вижу правильно оформленную статью, можно использовать статью по http 1.1
Это заметки, описывюащие вопросы и задачи с интервью.
Раздел interview состоит из: algorithms (задачи на алгоритмы), code_review (задачи с код ревью), design_interview (задачи с интервью), live_coding (кодинг прямо на собеседовании), questions (вопросы с собеседований).
Вопросы и задачи в каждом разделе делятся по сложности.
В каждом разделе есть intro.md файл с описанием раздела и списком задач, там же описывается принцип разделения по сложности.
Шаблон:
# Заголовок
## Условие
### Примеры
## Решение
Пример: move_zeroes.md
Не забудьте добавить заметку в intro.md раздела, в случае с примером выше - это intro.md.