git知识总结

要知道

本地回退后,反悔了,可以恢复。前提是已经提交了,提交了就丢不了。 

git reflog  +  git reset --hard commitId


以前git push不让推,就是没有对应关系。第一次推要setxxx参数。 


 

 前奏


 


设置用户名和邮箱,设置错了,可以重新输入,重新设置

git config --global user.name “gzy”

git config --global user.email "xxxx163.com"

查看用户名和邮箱。邮箱可以是不存在的邮箱

git config --global user.name

git config --global user.email

给指令设置别名 。自己无法用鼠标创建.开头的文件,可以用指令。必须设置在用户根目录下 ~/表示根路径下

1.创建.bashrc文件

touch ~/.bashrc

2.在.bashrc文件中输入如下内容

#用于输出git提交日志

alias git-log ='git log --pretty=oneline --all --graph --abbrev-commit'

#用于输出当前目录所有文件及其基本信息

alias ll='ls -al'

3.打开gitBash , 执行.                告诉shell从~/.bashrc文件中读取并执行其中的命令

source ~/.bashrc

 

解决gitBash乱码问题

1.打开gitBash执行

git config --global core.quotepath false

2.git安装目录下文件中修改文件,添加两行代码    git_home是git安装目录

 

export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"

 

初始化仓库

git init

查看内容  配置完别名的

ll

 状态

我们的文件所在区域就是工作区 

缓存区就是提交本地仓库之前的缓存区

工作区进入暂存区用add,暂存区进入仓库用commit。


git流程中的状态

untracked未跟踪:新创建的文件,还没有与git产生联系。 

unstaged未暂存:修改已经有的文件,但是没有进入暂存区

staged已暂存:已经在暂存区。暂存区就是提交本地仓库之前的缓存区。

to be committed即将被提交:已经进入暂存区,还没被提交

命令 

基础指令

touch file01.txt  创建文件

git status   查看状态

git add .  添加所有到暂存区 

git commit -m "add file01"  提交        在本地提交了肯定丢不了

git log  查看日志   

vi file01.txt(文件名)  键盘insert变为可编辑状态,esc退出,:wq退出保存

git reset --hard commitId    回退版本

git reflog  查看操作记录      可以查看历史,即使回退完,也可以返回  。查看已删除的记录
git-log  查看提交记录    这个是别名指令

当git add  不想将所有的文件都添加到缓存区时。

 touch .gitignore   创建忽略文件    .固定名称

vi .gitignore  insert  :wq

输入 *.a  就是git add . 不会添加.a结尾的文件。

git clone 克隆

远端分支,也是一个分支。 

git fetch origin master   抓取远端master到本地

git pull    拉取远端

推送远程

git remote add origin git@gitee.com:ayu--66/git_test.git   关联远程仓库   origin是远端分支名可以自定义,一般都默认是origin

git remote  查看是否有远程仓库

git push origin master   将master推到远程仓库,每次都这么写也可以      因为名称一致,所以省略了 :master

git push  推送远端       不让推,是因为不知道绑定关系,本地与远端。

git branch -vv   查看本地与远端的对应关系

git push --set-upstream origin master:master    设置对应关系     第一次推的时候要加setxxx

git push 有了对应关系就可以使用了。

 

 

 分支

git branch  查看分支                   head指向谁,谁就是当前分支

git branch dev01(分支名)  创建分支

git checkout dev01(分支名) 切换分支 

git checkout -b dev02   切换并创建    没有这个分支就创建出来在切换。

git merge 分支名称(要合并的分支)   合并分支    合并到master,现在就要在master。

git branch -d b1  删除分支,需要做各种检查

git branch -D b1 强制删除  (删除的分支有内容没有完全合并到master上,-d就无法删除)

常用命令 

git init

git clone 地址

git add .

git commit -m 'xxx' 

git remote add origin 地址    与远程建立连接

git push origin master    不统一配置,每次都要这么写

git push --set-upstream origin master   统一建立关联

git push   建立关联后,就可以直接用了

git pull = git fetch + git merge  先抓取到本地,再合并也行。

git checkout 分支名

git checkout -b 分支名

git-log 别名日志 配置的

git merge

git status

git reset --hard commitId

 

本地解决冲突:

dev修改 file01文件                            内容:abcdev

master修改file01文件                        内容:abcmaster

切换到master,执行 git merge dev

 

冲突,合并失败。

此时,打开冲突文件file01。这个文件就变样了。

 git无法合并,交给提交人来解决冲突。

 

找到冲突文件,解决后,重新提交。 

 


远端解决冲突

远端与你本地不一致,远端被别人推送了,并且正好是你修改的那一行代码。

之所以产生冲突就是因为 git merge操作,合并操作,不知取你的还是他的。

git pull = git fetch + git merge。

这时候一样的操作,找到冲突的文件,进行修改(解决冲突) add commit 重新推送。

图1:B是本地的master进行了修改。A是远端,修改了master。

图2:B要推代码之前,先拉取(抓取+合并),此步骤会解决冲突。

图3:远端完成同步


两个人都有需求,改的是同一个文件。后推送的人会推送失败,产生冲突。这时候只需拉取,找到冲突文件,add,commit,push,就可以了。A只需再pull就可以和远端一样了。

 

解决冲突的本质操作

找到冲突文件,本地进行修改,然后add ,commit ,再推送

每次推送前,要进行pull操作。 不拉取有可能会覆盖别人代码(但是git会有提示不让推送)

ssh仓库

ssh-keygen -t rsa    生成秘钥   一路回车

cat ~/.ssh/id_rsa.pub   查看秘钥  复制    粘贴到这里。

 

ssh -T git@gitee.com  验证秘钥是否配置成功

如果是秘钥,就用ssh

 

 修改Terminal

铁律 

用idea切换分支之前,一定要提交代码,只要代码提交了,代码就丢不了。 

  • 12
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
java面试题git是关于版本控制和代码管理工具git在java开发中的应用和相关知识的问题。下面我将用300字回答这个问题。 1. git是什么?git是一个分布式版本控制系统,可以高效地管理和追踪代码的改动。它与集中式版本控制系统相比具有更高的性能和灵活性。 2. git的基本工作原理是什么?git使用了一种称为“快照”的方式来记录代码的更改。每次提交代码时,git会创建一个新的快照,并将其与上一次提交进行比较,以记录代码的改动。这样可以高效地保存和追踪代码的修改历史。 3. git的常用命令有哪些?git的常用命令包括:git init(初始化git仓库),git add(将文件添加到暂存区),git commit(提交代码),git push(将提交的代码推送到远程仓库),git pull(从远程仓库拉取最新代码),git branch(创建、查看或删除分支),git merge(合并分支),git rebase(变基操作)等。 4. 如何解决代码冲突?在团队协作开发中,多人对同一个文件进行修改会产生代码冲突。解决代码冲突可以使用git的合并(merge)或变基(rebase)命令来进行操作。首先,需要查看代码冲突的文件,然后手动解决冲突并保存修改。最后,再次提交修改以解决代码冲突。 5. 如何撤销git提交?如果需要撤销最近一次的git提交,可以使用git的reset命令。git reset HEAD^可以撤销最近的一次提交,并将修改保留在工作区。如果希望彻底删除最近一次提交的更改,可以用git reset --hard HEAD^命令。 总结git是一种强大的版本控制和代码管理工具,广泛应用于Java开发中。掌握git的基本命令和工作原理,对于团队协作开发和代码管理是非常重要的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值