百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Git常用操作(持续更新)

wptr33 2025-01-16 21:12 23 浏览

从分支剔除测试不完的提交

相信大家都有遇到过一个版本功能特别多,测试不完的情况,这种情况我们可以尝试使用 git cherry-pick 来解决该问题。

(一)查看提交历史

在使用git cherry-pick之前,首先需要清楚地了解各个分支的提交情况。这就需要借助git log命令。例如,我们想要查看feature-branch的提交历史,可以在命令行中输入:

git log feature-branch

这将会列出feature-branch上的所有提交记录,包括提交的作者、日期、提交信息以及最重要的 —— 提交 ID。这些提交 ID 就像是每个提交的唯一标识符,是我们后续使用git cherry-pick的关键依据。

(二)切换到目标分支

确定了要摘取的提交所在的源分支以及目标分支后,我们需要先切换到目标分支。假设我们要将某个提交从feature-branch摘取到new-feature-branch分支,那么就执行:

git checkout new-feature-branch

(三)执行git cherry-pick命令

  1. 摘取单个提交
    如果我们想要摘取feature-branch上的一个特定提交,其提交 ID 为abc123,则在new-feature-branch分支下执行:
git cherry-pick abc123

此时,Git 会尝试将abc123提交中的所有更改应用到new-feature-branch分支。如果一切顺利,没有任何冲突,那么这个提交就会成功地被摘取到new-feature-branch分支,并且会生成一个新的提交记录,其提交信息与源提交相同。

  1. 摘取多个连续提交
    有时候,我们可能需要摘取多个连续的提交。比如,从feature-branch上的提交def456到ghi789(按照提交顺序)的所有提交。可以使用以下命令:
git cherry-pick def456^..ghi789

这里的def456^表示从def456的父提交开始,一直到ghi789的所有提交都会被应用到当前分支。需要注意的是,如果在这个过程中出现了冲突,Git 会暂停git cherry-pick的过程,并提示冲突的文件。

  1. 摘取多个不连续提交
    若要摘取多个不连续的提交,例如jkl101、mno202和pqr303,则需要分别对每个提交执行git cherry-pick命令:
git cherry-pick jkl101
git cherry-pick mno202
git cherry-pick pqr303

(四)处理冲突

当git cherry-pick过程中出现冲突时,Git 会在冲突的文件中标记出冲突的部分。例如,可能会看到类似这样的标记:

<<<<<<< HEAD
// 当前分支的代码
=======
// 要摘取的提交中的代码
>>>>>>> abc123

我们需要手动编辑这些文件,解决冲突,选择保留合适的代码部分。解决完冲突后,使用git add命令将冲突解决后的文件添加到暂存区,例如:

git add conflicted_file1 conflicted_file2

然后再使用git cherry-pick --continue命令继续git cherry-pick的过程:

git cherry-pick --continue

如果在处理冲突过程中,我们想要放弃这次git cherry-pick操作,可以使用git cherry-pick --abort命令,它会将当前分支恢复到git cherry-pick操作开始之前的状态。

(五)注意事项

然而,git cherry-pick也并非毫无风险。由于它是选择性地摘取提交,可能会导致目标分支的提交历史变得不够清晰和线性。如果过度使用或者使用不当,可能会给后续的代码维护和版本回退带来一定的困难。因此,在使用git cherry-pick时,需要谨慎考虑,并尽量在提交信息中详细说明摘取的来源和目的,以便其他团队成员能够更好地理解代码的变动。

另外,当从一个长期分支摘取提交到一个短期分支时,需要特别注意提交之间的依赖关系。如果摘取的提交依赖于源分支上的其他提交,而这些提交并没有被一同摘取,可能会导致代码在目标分支上无法正常运行。

统计代码量

(一)统计某个时间段内的代码行数

git log --since=2024-09-01 --until=2024-- --pretty=tformat: --numstat | awk '{ add += $1; subs += $2; loc += $1 - $2 } END { printf "added lines: %s, removed lines: %s, total lines: %s\\n", add, subs, loc }'

(二)统计某个人某个时间段内的代码行数

git log --author=username --since=2024-09-01 --until=2024-09-30 --format='%aN' | sort -u | while read name; do echo -en "$name\\t"; git log --author="$name" --pretty=tformat: --numstat | grep "\\(.html\\|.java\\|.xml\\|.properties\\)$" |awk '{ add += $1; subs += $2; loc += $1 - $2 } END { printf "added lines: %s, removed lines: %s, total lines: %s\\n", add, subs, loc }' -; done

(三)统计每个用户的所有提交代码行数(包括增、删、修改等)

git log --format='%aN' | sort -u | while read name; do echo -en "$name\\t"; git log --author="$name" --pretty=tformat: --numstat | awk '{ add += $1; subs += $2; loc += $1 - $2 } END { printf "added lines: %s, removed lines: %s, total lines: %s\\n", add, subs, loc }' -; done

(四)仓库提交者排名前 5

git log --pretty='%aN' | sort | uniq -c | sort -k1 -n -r | head -n 5

(五)统计某个用户的所有提交代码行数

git log --author="username" --pretty=tformat: --numstat | awk '{ add += $1; subs += $2; loc += $1 - $2 } END { printf "added lines: %s, removed lines: %s, total lines: %s\\n", add, subs, loc }'

(六)统计代码提交的人数

git log --pretty='%aN' | sort -u | wc -l

(七)统计总提交次数

git log --oneline | wc -l

(八)统计所有Java代码总行数提交修改的信息

find . "(" -name "*.java" ")" -print | xargs wc -l

(九)统计所有其他文件总行数提交修改的信息

find . "(" -name "*.m" -or -name "*.mm" -or -name "*.cpp" -or -name "*.h" -or -name "*.rss" ")" -print | xargs wc -l

(十)统计所有文件提交记录明细

 git ls-files | xargs wc -l

相关推荐

redis的八种使用场景

前言:redis是我们工作开发中,经常要打交道的,下面对redis的使用场景做总结介绍也是对redis举报的功能做梳理。缓存Redis最常见的用途是作为缓存,用于加速应用程序的响应速度。...

基于Redis的3种分布式ID生成策略

在分布式系统设计中,全局唯一ID是一个基础而关键的组件。随着业务规模扩大和系统架构向微服务演进,传统的单机自增ID已无法满足需求。高并发、高可用的分布式ID生成方案成为构建可靠分布式系统的必要条件。R...

基于OpenWrt系统路由器的模式切换与网页设计

摘要:目前商用WiFi路由器已应用到多个领域,商家通过给用户提供一个稳定免费WiFi热点达到吸引客户、提升服务的目标。传统路由器自带的Luci界面提供了工厂模式的Web界面,用户可通过该界面配置路...

这篇文章教你看明白 nginx-ingress 控制器

主机nginx一般nginx做主机反向代理(网关)有以下配置...

如何用redis实现注册中心

一句话总结使用Redis实现注册中心:服务注册...

爱可可老师24小时热门分享(2020.5.10)

No1.看自己以前写的代码是种什么体验?No2.DooM-chip!国外网友SylvainLefebvre自制的无CPU、无操作码、无指令计数器...No3.我认为CS学位可以更好,如...

Apportable:拯救程序员,IOS一秒变安卓

摘要:还在为了跨平台使用cocos2d-x吗,拯救objc程序员的奇葩来了,ApportableSDK:FreeAndroidsupportforcocos2d-iPhone。App...

JAVA实现超买超卖方案汇总,那个最适合你,一篇文章彻底讲透

以下是几种Java实现超买超卖问题的核心解决方案及代码示例,针对高并发场景下的库存扣减问题:方案一:Redis原子操作+Lua脚本(推荐)//使用Redis+Lua保证原子性publicbo...

3月26日更新 快速施法自动施法可独立设置

2016年3月26日DOTA2有一个79.6MB的更新主要是针对自动施法和快速施法的调整本来内容不多不少朋友都有自动施法和快速施法的困扰英文更新日志一些视觉BUG修复就不翻译了主要翻译自动施...

Redis 是如何提供服务的

在刚刚接触Redis的时候,最想要知道的是一个’setnameJhon’命令到达Redis服务器的时候,它是如何返回’OK’的?里面命令处理的流程如何,具体细节怎么样?你一定有问过自己...

lua _G、_VERSION使用

到这里我们已经把lua基础库中的函数介绍完了,除了函数外基础库中还有两个常量,一个是_G,另一个是_VERSION。_G是基础库本身,指向自己,这个变量很有意思,可以无限引用自己,最后得到的还是自己,...

China&#39;s top diplomat to chair third China-Pacific Island countries foreign ministers&#39; meeting

BEIJING,May21(Xinhua)--ChineseForeignMinisterWangYi,alsoamemberofthePoliticalBureau...

移动工作交流工具Lua推出Insights数据分析产品

Lua是一个适用于各种职业人士的移动交流平台,它在今天推出了一项叫做Insights的全新功能。Insights是一个数据平台,客户可以在上面实时看到员工之间的交流情况,并分析这些情况对公司发展的影响...

Redis 7新武器:用Redis Stack实现向量搜索的极限压测

当传统关系型数据库还在为向量相似度搜索的性能挣扎时,Redis7的RedisStack...

Nginx/OpenResty详解,Nginx Lua编程,重定向与内部子请求

重定向与内部子请求Nginx的rewrite指令不仅可以在Nginx内部的server、location之间进行跳转,还可以进行外部链接的重定向。通过ngx_lua模块的Lua函数除了能实现Nginx...