Форум программистов, компьютерный форум, киберфорум
Git
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.83/120: Рейтинг темы: голосов - 120, средняя оценка - 4.83
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818

Чем отличается git merge От git pull

05.07.2016, 13:13. Показов 23212. Ответов 20
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
в обоих случаях я забираю изменения в свою ветку. в чем различие?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.07.2016, 13:13
Ответы с готовыми решениями:

Разница межу git fetch+merge и pull
Есть удаленный реп. Правильно ли я понимаю, что если я выполню на локальной машине: git fetch git merge origin/branch_name или...

Ошибки выполняя git pull
вСЕМ привет! Получил от другого разработчика проект в виде .zip-файла и внеся изменения перевел его на наш bitbucket и загружаю его...

Git merge errors
Совершенно не получается скачать последние изменения, сделанные другим человеком на моем репозитории. С гитом совершенно не дружу....

20
Эксперт .NET
 Аватар для Rius
13084 / 7644 / 1670
Регистрация: 25.05.2015
Сообщений: 23,273
Записей в блоге: 14
05.07.2016, 15:11
Pull скачивает с сервера и делает merge.
0
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
05.07.2016, 16:44  [ТС]
Rius, а просто ,merge?
0
Эксперт .NET
 Аватар для Rius
13084 / 7644 / 1670
Регистрация: 25.05.2015
Сообщений: 23,273
Записей в блоге: 14
05.07.2016, 16:45
А merge делает merge.
pull в варианте по умолчанию это почти аналог fetch с последующим merge.

https://git-scm.com/docs/git-merge
https://git-scm.com/docs/git-pull
0
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
05.07.2016, 17:20  [ТС]
Rius, но в любом случае я получаю все изменения в свою ветку с другой ветки?
0
Эксперт .NET
 Аватар для Rius
13084 / 7644 / 1670
Регистрация: 25.05.2015
Сообщений: 23,273
Записей в блоге: 14
05.07.2016, 17:27
Разными путями, с разными последствиями, с разным видом получаемого дерева версий.
Команды не эквивалентны.

Добавлено через 3 минуты
Надо использовать те команды, которые подходят по месту. А не "они же одинаковы". Потому что дерево может быть аккуратным вьюном, а может быть грибницей.
0
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
05.07.2016, 17:31  [ТС]
Rius,

не понятно. мерж делает мерж, а пул скачивает и делает мерж
0
Эксперт .NET
 Аватар для Rius
13084 / 7644 / 1670
Регистрация: 25.05.2015
Сообщений: 23,273
Записей в блоге: 14
05.07.2016, 17:33
Да.
Что именно непонятно? Подробнее.
0
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
06.07.2016, 13:58  [ТС]
Rius,

получается pull это улучшенный вариант мержа?
0
Эксперт .NET
 Аватар для Rius
13084 / 7644 / 1670
Регистрация: 25.05.2015
Сообщений: 23,273
Записей в блоге: 14
06.07.2016, 14:01
Нет. Это лишь команда для подтягивания коммитов из удалённого репозитория в текущую ветку (по умолчанию).
Особенно удобен
Bash
1
git pull --rebase
, позволяющий обойтись без ненужных слияний.
0
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
06.07.2016, 15:06  [ТС]
Rius,

допустим кто-то сделал изменения в своей ветке, назовем ее vetka1

у меня есть своя ветка, называется vetka2

этот кто-то сделал коммит в vetka1, мне нужно забрать изменения из vetka1 в vetka2

если я делаю git pull vetka1, то я скачиваю эти изменения себе в vetka2

если я делаю git merge vetka1, то я так же забираю изменения в vetka2
0
Эксперт .NET
 Аватар для Rius
13084 / 7644 / 1670
Регистрация: 25.05.2015
Сообщений: 23,273
Записей в блоге: 14
06.07.2016, 15:16
Типа того. Только через pull забирать изменения из другой ветки не стоит, можно историю кривой сделать.
0
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
06.07.2016, 16:59  [ТС]
Rius, тогда вообще разницы не вижу, скачаю я эти изменения или соединю две ветки результат то тот же
0
Эксперт .NET
 Аватар для Rius
13084 / 7644 / 1670
Регистрация: 25.05.2015
Сообщений: 23,273
Записей в блоге: 14
06.07.2016, 20:01
Скачать можно обновления текущей ветки, из удалённого репозитория, в текущую же ветку.
Объединить можно только что-то с чем-то (3 ветки сразу, например), но не само с собой.
Не видите разницы? Это не имеет значения. Надо просто пользоваться теми командами, что подходят к конкретному случаю.
0
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
07.07.2016, 10:29  [ТС]
Rius, т.е. git pull нельзя сделать из ветки vetka1 Находять при этом в vetka 2?

p.s.как же можно понять какой случай лучше использовать, если я не могу понять разницы в командах?)
0
Эксперт .NET
 Аватар для Rius
13084 / 7644 / 1670
Регистрация: 25.05.2015
Сообщений: 23,273
Записей в блоге: 14
07.07.2016, 10:32
Лучший ответ Сообщение было отмечено Mashka_mulashka как решение

Решение

Цитата Сообщение от Mashka_mulashka Посмотреть сообщение
т.е. git pull нельзя сделать из ветки vetka1 Находять при этом в vetka 2?
Можно, но обычно лучше не стоит.

Если надо загрузить изменения удалённой текущей ветки в локальную текущую ветку, пользуйтесь git pull --rebase.
Если надо слить одну локальную ветку с другой, то git merge.
1
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
07.07.2016, 10:33  [ТС]
Rius, т.е. git merge работает только с локальными ветками?
0
Эксперт .NET
 Аватар для Rius
13084 / 7644 / 1670
Регистрация: 25.05.2015
Сообщений: 23,273
Записей в блоге: 14
07.07.2016, 10:35
Да.
Чтобы с удалёнными, их надо сначала загрузить, через git fetch например.
0
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
07.07.2016, 10:39  [ТС]
Rius, а чем отличается git pull -rebase От git pull?
0
Эксперт .NET
 Аватар для Rius
13084 / 7644 / 1670
Регистрация: 25.05.2015
Сообщений: 23,273
Записей в блоге: 14
07.07.2016, 10:52
Предположим, у Вас есть удалённая ветка и локальная её копия.
Вы закоммитили в локальную ветку что-то.
Кто-то другой закоммитил и запушил в репозиторий в эту же ветку.
Название: C1.PNG
Просмотров: 125

Размер: 2.6 Кб
Вам надо скачать себе изменения, но там ветки пошли разными путями.
Если сделать git pull, у Вас случится merge, что создаёт один лишний коммит и искривляет историю.
Если git pull --rebase, то скачаются изменения, найдётся общий коммит удалённой и локальной ветки, удалённые изменения применятся к нему, а Ваши - после удалённого. История останется прямой.
Название: C2.PNG
Просмотров: 124

Размер: 2.5 Кб
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.07.2016, 10:52
Помогаю со студенческими работами здесь

Механизм работы git merge
Мне стало интересно как изнутри работает механизм git merge. То есть допустим если я создал две ветки и сделал два комита на одной ветке...

Как сделать git pull, не затерев при этом в директории папки и файлы
Привет. Мне необходим сделать git pull origin master в текущую директорию, но у меня в ней лежат папка node_modules и файл info.txt,...

Команда $git init создает .git не в той папке
Привет. Не нашел на форуме раздела, где мог бы задать вопрос по работе git, пишу поэтому сюда. После команды $git init в git-bash папка...

Not a git repository or any of the parent directories git
Всем привет. Случилось нечто досадное. Я закончил работу в локальной ветке и перешел в мастер, чтобы слить изменения и запушить их. ...

git - gitk и git-gui
На сайте raboj.su написаноЭто имеется в виду, что надо перейти в какую именно папку?


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru