git使用过程中遇到的问题

git查看某个文件的修改历史及具体修改内容

git log --pretty=oneline 文件名

使用git show即可显示具体的某次的改动的修改

在git中出现中文乱码的解决方案

解决方案

    • 在cygwin中,使用git add添加要提交的文件的时候,如果文件名是中文,会显示形如 274\232\350\256\256\346\200\273\347\273\223.png 的乱码。
      • 解决方案:在bash提示符下输入: git config --global core.quotepath false
      • core.quotepath设为false的话,就不会对0x80以上的字符进行quote。中文显示正常。

    • 在MsysGit中,使用git log显示提交的中文log乱码。
      解决方案:
      1. 设置git gui的界面编码 git config --global gui.encoding utf-8
      2. 设置 commit log 提交时使用 utf-8 编码,可避免服务器上乱码,同时与linux上的提交保持一致! git config --global i18n.commitencoding utf-8
      3. 使得在 $ git log 时将 utf-8 编码转换成 gbk 编码,解决Msys bash中git log 乱码。git config --global i18n.logoutputencoding gbk
      4. 使得 git log 可以正常显示中文(配合i18n.logoutputencoding = gbk),在 /etc/profile 中添加:export LESSCHARSET=utf-8

    • 在MsysGit自带的bash中,使用ls命令查看中文文件名乱码。cygwin没有这个问题。
      • 解决方案:
        1. 使用 ls --show-control-chars 命令来强制使用控制台字符编码显示文件名,即可查看中文文件名。
        2. 为了方便使用,可以编辑 /etc/git-completion.bash ,新增一行 alias ls=“ls --show-control-chars”

    • 终极的解决方案是通过修改git和TortoiseGit源码实现,有网友这么做了:让Windows下Git和TortoiseGit支持中文文件名/UTF-8 ,也可以直接访问这个开源的Google项目:utf8-git-on-windows 。

    • 如果不抗拒命令行的话,直接用Cygwin来提交Git库。因为Cygwin其实是一个在Windows平台上的模拟器,它完全模拟GNU/Linux的方式运行,所以Cygwin中的Git是采用UTF-8编码来保存中文的。

 回退到某个commit号:git reset --hard 4b6339a108c33a7904c6bf72f018ec2927bc9337

cherry-pick的commit之间有没有做过更改没有直接关系.

如果没有更改, 当然会直接merge没有conflict.

如果二者之间还有过更改, 因为cherry-pick其实是用那次commit的内容进行patch, 所以要分情况看:

  1. 所做更改没有在diff信息的context范围内, 没有冲突.
  2. 所做更改在diff信息的context范围内, 你需要解决这个冲突才能merge.

 

 

 

后期会继续补存

 

上一篇:使用自定义RRT*全局规划器建图导航


下一篇:git remote: HTTP Basic: Access denied 错误解决办法