附上一句喜欢的格言,望共勉:好学若饥,谦卑若愚。
史上最简单的 GitHub 教程
详述 SSH 的原理及其应用
Hello World · GitHub 指南
深入理解 GitHub Flow
常用代码:
git status,查询仓库状态;
git init,初始化仓库;
git add,添加文件;
git commit,提交文件;
git log,查询提交日志;
git branch,拉分支;
git checkout,切换分支或者标签;
git merge,合并分支;
git branch -d & git branch -D,删除或者强制删除分支;
git tag,添加标签。
git restore --staged [file] : 表示从暂存区将文件的状态修改成 未add前状态。
————————————————
版权声明:本文为CSDN博主「CG国斌」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_35246620/article/details/70144578
搜索:
各个关键词空格隔开。
筛选 具体条件 java stars:>1000
内容介绍
安装 Git 及体验 Git 命令
tab键可以便捷输入
$ cd D:\coderlife
$ git status #查看git状态
$ git init demo(文件名)#初始化仓库,将普通文件夹变为git的仓库
$ git add hit.txt(已有文件名)#将已有文件加到本地仓库中去
$ git add hit/(已有文件夹)#将已有文件夹加到本地仓库中去
$ git commit -m "text commit"#**commit表示提交,-m表示提交信息,提交信息写在双引号""内**
$ git log #查看提交日志
$ git branch #查看分支
$ git branch second-branch #建立一个second-branch的分支
$ git branch -d second-branch# 删除一个分支,-d或者-D删除
$ git checkout -b b# 直接创建并切换到新分支 -b创建并切换
$ git merge b #合并分支
使用 Git 与 GitHub 进行交互
在已安装 SSH 的情况下:输入ssh-keygen -t rsa命令,表示我们指定 RSA 算法生成密钥,然后敲三次回车键,期间不需要输入密码,之后就就会生成两个文件,分别为id_rsa和id_rsa.pub,即密钥id_rsa和公钥id_rsa.pub. 对于这两个文件,其都为隐藏文件,默认生成在以下目录:
Linux 系统:~/.ssh
Mac 系统:~/.ssh
Windows 系统:C:\Documents and Settings\username\.ssh
Windows 10 ThinkPad:C:\Users\think.ssh
密钥和公钥生成之后,我们要做的事情就是把公钥id_rsa.pub的内容添加到 GitHub,这样我们本地的密钥id_rsa和 GitHub 上的公钥id_rsa.pub才可以进行匹配,授权成功后,就可以向 GitHub 提交代码啦!
第 1 步:生成 SSH key
$ ssh #查看是否安装ssh
$ ssh-keygen -t rsa # 表示我们指定 RSA 算法生成密钥
第 2 步:添加 SSH key
# 进入我们的 GitHub 主页,先点击右上角所示的倒三角▽图标,然后再点击Settins,进行设置页面
第 3 步:验证绑定是否成功
$ ssh -T git@github.com
# 输出--Hi 用户名! You've successfully authenticated, but GitHub does not provide shell access.表示成功
对于向远处仓库(GitHub)提交代码
-
第一种:本地没有 Git 仓库
第一种:本地没有 Git 仓库,这时我们可以直接将远程仓库clone到本地。通过clone命令创建的本地仓库,其本身就是一个 Git 仓库了,不用我们再进行init初始化操作啦,而且自动关联远程仓库。我们只需要在这个仓库进行修改或者添加等操作,然后commit即可。
$ git clone https://github.com/Mrwhite132613/Statistical-Learning-Method_Code.git
#如果我们本地的代码有了更新,为了保持本地与远程的代码同步,我们就需要把本地的代码推到远程的仓库
$ git push (远程仓库名字)master
$ git pull (远程仓库名字)master
重点:
$ git add THRED-master #先add到本地仓库
$ git commit -m "commit THRED-master file" # 再commit到远程仓库
$ git log #查看提交到远程仓库的记录
$ git push origin master #将本地仓库的内容push到远程仓库
#这里会进行一步GitHub的登录验证,验证结束就可以继续push。
-
第二种:本地有 Git 仓库,远程仓库和本地仓库一个名字
首先,建立一个本地仓库,今天本地仓库,打开git bash ,进行init的初始化操作,然后关联远程仓库,再用pull同步本地和远程仓库
#建立一个本地仓库
$ git init
#关联远程仓库,Pytorch-dialogue是远程仓库名字:
$ git remote add Pytorch-dialogue https://github.com/Mrwhite132613/Pytorch-dialogue.git
#同步远程仓库和本地仓库:
$ git pull Pytorch-dialogue master
-
常用-第三种:本地文件夹里的代码上传到github已有远程仓库(DLearning-)
- 注意不是将文件夹NUDT2020xt上传到远程仓库,只是文件夹里的文件(.)
#初始化本地仓库NUDT2020xt
$ git init
#关联远程仓库:
$ git remote add (远程仓库名字)https://github.com/Mrwhite132613/DLearning-.git
#同步远程仓库和本地仓库:
$ git pull (远程仓库名字) master
- 此时,文件夹NUDT2020xt需要add和commit
#将文件夹里所有文件add到本地仓库,(.)代表所有
$ git add .
# 再commit到远程仓库
$ git commit -m "first_commit"( "first_commit"此次提交的名字,git log显示)
#将本地仓库的内容push到远程仓库
$ git push (远程仓库名字)master
#这里会进行一步GitHub的登录验证,验证结束就可以继续push。
重点,易错,需要注意:
最后,再强调一遍:在我们向远程仓库提交代码的时候,一定要先进行pull操作,再进行push操作,防止本地仓库与远程仓库不同步导致冲突的问题,尤其是第二种提交代码的情况,很容易就出现问题。
上传
- 同一个远程仓库与多个本地仓库关联(包括clone下来的本地仓库),进行push和pull之前一定要确保关联在哪个本地仓库
调整关联才可以正常pull,push,commit
$ git remote add (远程仓库名字)https://github.com/Mrwhite132613/DLearning-.git