繁体   English   中英

java中比较的长列表

[英]Long list of if comparisons in java

我需要比较两个对象。 如果存在差异,我需要记录对应于特定差异并返回true。

例如:

private boolean compTwoObjects(Object objA, Object ObjB) {
   if(objA.getType() != objB.getType()) {
      logTheDifference("getType is differing");
      return true;
   }
                   .
                   .
                   .
   // Now this could invoke other composite methods
   if(checkFont(objA.getFont(), objB.getFont()) {
      logTheDifference("Font is differing");
      return true;
   }
}


private boolean checkFont(Font fontObjA, Font fontObjB) {
   if(fontObjA.getBold() != fontObjB.getBold()) {
      logTheDifference("font bold formatting differs");
      return true;
   }
                   .
                   .
                   .
   if(fontObjA.getAllCaps() != fontObjB.getAllCaps()) {
      logTheDifference("font all caps formatting differs");
      return true;
   }
                   .
                   .
                   .
   if(checkBorderDiff(fontObjA.getBorder(), fontObjB.getBorder())) {
      logTheDifference("border diff");
      return true;
   }
}

private boolean checkBorderDiff(Border borderObjA, Border borderObjB) {
    if (borderObjA.getColor() != null || borderObjB.getColor() != null) {
       if (!borderObjA.getColor().equals(borderObjB.getColor())) {
            logIt("border color differing");
            return true;
        }
    }

    if (borderObjA.getDistanceFromText() != borderObjB.getDistanceFromText()) {
        logIt("distance of the border from text or from the page edge in points differing");
        return true;
    }

    if (borderObjA.isVisible() != borderObjB.isVisible()) {
        logIt("border visibility differing");
        return true;
    }

    if (borderObjA.getLineStyle() != borderObjB.getLineStyle()) {
        logIt("line style differing for border");
        return true;
    }

    if (borderObjA.getLineWidth() != borderObjB.getLineWidth()) {
        logIt("border width in points differing");
        return true;
    }

    if (borderObjA.getShadow() != borderObjB.getShadow()) {
        logIt("border shadow differing");
        return true;
    }
}

//And it is going like this.

我的问题是我想避免方法中的多个if语句。 另外我想记录对应于特定差异的消息。

我已经在stackoverflow上阅读了几个类似的问题,通过命令模式或HashMap解决。 但他们没有包括比较。

我想重构我的代码以摆脱if的系列。

有一个比较系统,由泛型支持。 每个比较器也会知道下一个是什么。 例如:

interface IComparer<T> {
    boolean areDifferent (T first, T second);
}

class FontComparer implements IComparer<Font> {
    @Override
    public boolean areDifferent(Font first, Font second) {
        // Compare fonts start
        // ..
        // Compare fonts end
        return new BorderComparer().areDifferent(first.getBorder(), second.getBorder());
    }
}


class BorderComparer implements IComparer<Border> {

    @Override
    public boolean areDifferent(Border first, Border second) {
        //Do border comparison alone
        return false;
    }
}

你现在可以设置一个比较器链,并在比较失败时纾困。 否则,比较将转到链中的下一个比较器。

客户端代码最终将如下所示:

    Object one = new Object();
    Object two = new Object();
    new ObjectComparer().areDifferent(one, two);

你考虑过枚举吗?

private enum FontCmp {

    Bold {
                @Override
                boolean cmp(Font a, Font b) {
                    return a.getBold() != b.getBold();
                }
            },
    AllCaps {
                @Override
                boolean cmp(Font a, Font b) {
                    return a.getAllCaps() != b.getAllCaps();
                }
            },
    Border {
                @Override
                boolean cmp(Font a, Font b) {
                    return BorderCmp.compare(a.getBorder(), b.getBorder());
                }
            };

    // Each enum has one of these.
    abstract boolean cmp(Font a, Font b);

    // Compare them all and log any failures.
    static boolean compare(Font a, Font b) {
        for (FontCmp c : FontCmp.values()) {
            if (c.cmp(a, b)) {
                logIt("FontCmp-" + c + " failed");
                return false;
            }
        }
        return true;
    }
}

你也可以使用这里描述的反射。 还要看看这里描述的内省

从根本上说,您正在尝试进行一系列比较,因此除了进行一系列比较之外别无选择。

你可以做的是定义一个接口/枚举/抽象类,它是一个FieldChecker。 FieldChecker会在每个FieldChecker中以不同的方式实现抽象方法:

 String performCheck(Font a, Font b) {
     if (DO CHECK HERE) {
         return "failure message";
     }
     return null;
 }

然后你的检查功能变成:

for (FieldChecker fc: fieldCheckers) {
    String res = fc.performCheck(a,b);
    if (res != null) {
       return res;
    }
}
return "All ok";

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM