经常使用git diff 但是其是如何实现的呢?
本博客简单实现不考虑行的比较。可以比较两个字符串
// 相当于把每一行换比较换成字符比较,道理一样
s1='xxxxxxxxxx'
s2='yyyyyyyyyy'
首先我们把文件转化为两个列表,列表的每个元素是文件的某一行:
A = [1行、2行、3行、4行、…]
B = [1行、2行、3行、4行、…]
然后我们计算A和B最长的相似元素的长度lcs(递归就是力量)
lcs = (A, B) ->
result = 0
if A.length is 0 or B.length is 0
result
else if A[0] is B[0]
result = 1 + lcs(A[1..], B[1..])
else
result = Math.max(lcs(A, B[1..]), lcs(A[1..], B))
(真实环境下,文件足够大的话,会因为递归太多而爆栈……)
拿到了lcs,然后根据计算lcs时找到的能对上的头,就可以得出两个文件最大的相同部分,用C表示,那么,A、B就被切分成了:
A-、C、A+
B-、C、B+
然后,我们再用同样的方法比较A-、B-,以及A+、B+,一直这样递归下去,一段段地比较,最后把所有的结果拼起来。
最后使用Java实现
public class LCSTest {
public static class Node {
int st;
String subTpl;
int length;
int op;
public Node(