git diff -w忽略空白差异。
你不能忽略多行注释,因为 git 是一个版本控制工具,而不是依赖于语言的解释器。它不知道你的代码是C++。它不会解析文件的语义,因此它无法解释什么是注释,什么不是。特别是,它依赖 diff(或配置的 difftool)来比较文本文件,并且需要逐行比较。
我同意@andrew-c 的观点,你真正要求的是比较两段没有注释的代码。更具体地说,您要求比较所有多行注释已变成空行的代码行。您将空白行保留在那里,以便在普通副本上引用正确的行号。
因此,您可以手动转换两个代码状态以清除多行注释...或者您可能会考虑构建自己的差异包装器来为您进行剥离。但后者可能不值得付出努力。