HTML Diff
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>