Git与Github之git使用手册( 含 error: failed to push some refs to ‘xxx)

本文详细介绍了Git的基础命令,包括初始化、克隆、创建本地存储库、分支管理、合并及推送更改。同时,讲解了如何从远程存储库克隆到本地以及将本地存储库发布到GitHub。此外,还涵盖了如何在已有分支上进行修改和协作流程。
摘要由CSDN通过智能技术生成


版本控制系统、什么是储存库 (Repository) 、 GitHub 模型如何运行、 Git 指令和示例等。

1. 版本控制系统 VCS

版本控制系统(VCS)跟踪人员和团队在项目上进行协作时的更改历史记录。更改后,随时可以恢复到项目的更早版本。

项目历史记录:

  • 进行了哪些更改?
  • 谁进行了更改?
  • 何时进行了更改?
  • 为什么需要更改?

2. Git 的基本命令

使用 Git 的特定命令来复制、创建、更改和合并代码。


git init 

初始化一个全新的 Git 存储库并开始跟踪现有目录。
它在现有目录中添加一个隐藏的子文件夹,该子文件夹包含版本控制所需的内部数据结构。

git clone 

根据远程已存在的项目创建本地副本。
克隆包括项目的所有文件、历史记录和分支。

git add 

暂存更改。 Git 跟踪对开发人员代码库的更改,但有必要暂存更改并拍摄更改的快照,以将其包含在项目的历史记录中。 此命令执行暂存,即该两步过程的第一部分。 暂存的任何更改都将成为下一个快照的一部分,并成为项目历史记录的一部分。 通过单独暂存和提交,开发人员可以完全控制其项目的历史记录,而无需更改其编码和工作方式。

git commit 

将快照保存到项目历史记录中并完成更改跟踪过程。 简言之,提交就像拍照一样。 任何使用 git add 暂存的内容都将成为使用 git commit 的快照的一部分。

git status 

将更改的状态显示为未跟踪、已修改或已暂存。

git branch

显示正在本地处理的分支。

git merge

将开发线合并在一起。 此命令通常用于合并在两个不同分支上所做的更改。 例如,当开发人员想要将功能分支中的更改合并到主分支以进行部署时,他们会合并。

git pull

用远程更新本地。
使用远程对应项的更新来更新本地开发线。 如果队友已向远程上的分支进行了提交,并且他们希望将这些更改反映到其本地环境中,则开发人员将使用此命令。

git push

使用本地对分支所做的任何提交来更新远程存储库

3. 从远程存储库克隆到本地

# 在GitHub上下载一个存储库到我们的机器
# 将 'owner/repo' 替换为要克隆的存储库的所有者和名称
git clone https://github.com/owner/repo.git

# 进入存储库目录
cd repo

# 创建一个新的分支来存储任何新的更改
git branch my-branch

# 切换到指定分支(开发线)
git checkout my-branch


# make changes, for example, edit `file1.md` and `file2.md` using the text editor (进行更改,例如,使用文本编辑器编辑 `file1.md` 和 `file2.md`  )


# stage the changed files (暂存更改的文件)
git add file1.md file2.md

# take a snapshot of the staging area (anything that's been added)
# 给所有已经暂存更改的文件添加备注
git commit -m "my snapshot"

# push changes to github (将更改推送到github)
git push --set-upstream origin my-branch

4. 创建本地存储库并发布到github

进入文件夹,右键选择 Git Bash Here
在这里插入图片描述

  1. 创建本地存储库 my-repo
    创建一个新目录,并使用特定于git的函数初始化它
git init my-repo
  1. 进入存储库目录 my-repo
cd my-repo
  1. 创建README.md文件
touch README.md
  1. 暂存README.md
git add README.md
  1. 给暂存内容添加备注
git commit -m "add README to initial commit"
  1. 提供你在github上创建的存储库的路径
git remote add origin https://github.com/YOUR-USERNAME/YOUR-REPOSITORY-NAME.git
  1. 上传更改到github, gitee
git push --set-upstream origin main

git push -u origin "master"

在这里插入图片描述
在这里插入图片描述

5. 对已有分支进行修改

git pull 命令用于从远程获取代码并合并本地的版本。

# 将远程分支与本地分支合并
git pull <远程主机名> <远程分支名>:<本地分支名>

在这里插入图片描述

# change into the `repo` directory (进入本地已有存储库)
cd repo

# update all remote tracking branches, and the currently checked out branch (将远程分支与本地分支合并)
git pull

# change into the existing branch called `feature-a` (变更到指定分支)
git checkout feature-a

# make changes, for example, edit `file1.md` using the text editor (进行修改)

# stage the changed file (暂存修改)
git add file1.md

# take a snapshot of the staging area (给目前暂存的修改添加备注)
git commit -m "edit file1"

# push changes to github (将本地暂存的修改上传到github上)
git push

6. 链接:参与项目


补充:
最常见的情况是团队中的人都共用一个origin。如果自己想额外使用一个remote,也可以通过以命令增删:

git remote add name xxx
git remote remove name
大家可以试试以下命令:

git remote # 查看有哪些remote,一般就一个,叫做origin
git remote remove origin # 删除,一般不用到
git remote add origin xxx # 新增,一般不用到。xxx 请用最开始的 git clone xxx 中的 xxx 替代

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值