0 added
0 removed
Original
2026-01-01
Modified
2026-02-26
1
<p>Индекс в Git - это специальная промежуточная область, в которой хранятся изменения файлов на пути от рабочей директории до репозитория. При выполнении коммита в него попадают только те изменения, которые были добавлены в индекс. В этом уроке вы узнаете, зачем нужен индекс и как он работает.</p>
1
<p>Индекс в Git - это специальная промежуточная область, в которой хранятся изменения файлов на пути от рабочей директории до репозитория. При выполнении коммита в него попадают только те изменения, которые были добавлены в индекс. В этом уроке вы узнаете, зачем нужен индекс и как он работает.</p>
2
<p>Понятие индекса в Git появилось неслучайно. Даже когда разработчик работает над одной задачей, по пути он натыкается на разные проблемы в коде:</p>
2
<p>Понятие индекса в Git появилось неслучайно. Даже когда разработчик работает над одной задачей, по пути он натыкается на разные проблемы в коде:</p>
3
<ul><li>Ошибки</li>
3
<ul><li>Ошибки</li>
4
<li>Код с плохим оформлением</li>
4
<li>Код с плохим оформлением</li>
5
<li>Фрагменты, которые нужно будет исправить под новые требования</li>
5
<li>Фрагменты, которые нужно будет исправить под новые требования</li>
6
</ul><p>В большинстве ситуаций совершенно нормально исправлять эти недочеты, что все и делают. В итоге в рабочей директории появляется множество разных исправлений. Частично они относятся к выполняемой задаче, а частично - содержат множественные исправления, напрямую не связанные с основными изменениями. В чем здесь проблема?</p>
6
</ul><p>В большинстве ситуаций совершенно нормально исправлять эти недочеты, что все и делают. В итоге в рабочей директории появляется множество разных исправлений. Частично они относятся к выполняемой задаче, а частично - содержат множественные исправления, напрямую не связанные с основными изменениями. В чем здесь проблема?</p>
7
<p>Представим, что мы сделали ровно один коммит, в который включили и основную задачу, и дополнительные исправления. В таком случае, мы получаем несколько неприятных побочных эффектов.</p>
7
<p>Представим, что мы сделали ровно один коммит, в который включили и основную задачу, и дополнительные исправления. В таком случае, мы получаем несколько неприятных побочных эффектов.</p>
8
<p>Во-первых, становится сложнее смотреть историю. Коммит начинает содержать совершенно несвязанные изменения, которые отвлекают во время проверки чужого кода:</p>
8
<p>Во-первых, становится сложнее смотреть историю. Коммит начинает содержать совершенно несвязанные изменения, которые отвлекают во время проверки чужого кода:</p>
9
<p>Во-вторых, откат коммита по любым причинам приведет к тому, что откатятся правки, которые все равно нужно будет делать.</p>
9
<p>Во-вторых, откат коммита по любым причинам приведет к тому, что откатятся правки, которые все равно нужно будет делать.</p>
10
<p>Именно здесь помогает<strong>индекс</strong>. Если он есть, мы можем не переживать, как сформируется коммит.</p>
10
<p>Именно здесь помогает<strong>индекс</strong>. Если он есть, мы можем не переживать, как сформируется коммит.</p>
11
<p>Стандартный способ работы с индексом - это добавление или изменение файлов и последующий коммит:</p>
11
<p>Стандартный способ работы с индексом - это добавление или изменение файлов и последующий коммит:</p>
12
<p>Если речь идет про один-два файла, которые нужно закоммитить прямо сейчас, то можно сделать проще. Этот подход работает только с уже отслеживаемыми файлами:</p>
12
<p>Если речь идет про один-два файла, которые нужно закоммитить прямо сейчас, то можно сделать проще. Этот подход работает только с уже отслеживаемыми файлами:</p>
13
<p>Иногда бывает наоборот - мы исправили много файлов и хотим добавить их в коммит сразу все. Тогда поможет точка:</p>
13
<p>Иногда бывает наоборот - мы исправили много файлов и хотим добавить их в коммит сразу все. Тогда поможет точка:</p>
14
<p>Команда выше очень опасна. С ее помощью крайне легко закоммитить много лишнего, особенно если перед коммитом не посмотреть git diff --staged.</p>
14
<p>Команда выше очень опасна. С ее помощью крайне легко закоммитить много лишнего, особенно если перед коммитом не посмотреть git diff --staged.</p>
15
<p>Ну и совсем страшная, но полезная команда - это коммит с одновременным добавлением всего в индекс:</p>
15
<p>Ну и совсем страшная, но полезная команда - это коммит с одновременным добавлением всего в индекс:</p>
16
<p>С другой стороны, нередко разные изменения делаются в одних и тех же файлах. То есть изменения в этих файлах по-хорошему должны находиться в разных коммитах.</p>
16
<p>С другой стороны, нередко разные изменения делаются в одних и тех же файлах. То есть изменения в этих файлах по-хорошему должны находиться в разных коммитах.</p>
17
<p>И даже такое можно сделать с помощью Git. Для этого подходит команда git add -i, которая показывает измененные куски файлов и спрашивает, что с ними сделать:</p>
17
<p>И даже такое можно сделать с помощью Git. Для этого подходит команда git add -i, которая показывает измененные куски файлов и спрашивает, что с ними сделать:</p>
18
<p>С помощью этой команды можно очень точно выбрать то, что должно попасть в коммит, а что нет. Ее использование обычно показывает хороший уровень владения Git.</p>
18
<p>С помощью этой команды можно очень точно выбрать то, что должно попасть в коммит, а что нет. Ее использование обычно показывает хороший уровень владения Git.</p>