Java Compare Strings

℡╲_俬逩灬. 提交于 2019-12-08 05:14:01

问题


 /**
 * A method to compare Strings
 * @param arg1
 * @param arg2
 * @return 
 */
public boolean myQuickCompare(String arg1, String arg2) {
    boolean a = arg1.length() == arg2.length();
    if (a) {
        for (int b = 0; b > arg1.length(); b++) {
            if (arg1.charAt(b) != arg2.charAt(b)) {
                a = false;
            }
        }
    }
    return a;
}

I understand that the for loop is the wrong way around, b will never be greater than the length of the string. How would you correct this problem?

What sensible variable names would you give for a and b?


回答1:


Use arg1.equals(arg2). No need for custom functions. Don't try to outsmart the developers of Java. Most of the time, they win.




回答2:


I understand that the for loop is the wrong way around, b will never be greater than the >length of the string. How would you correct this problem?

use equals() of String directly

What sensible variable names would you give for a and b?

a may be result

b may be index


Here is the implementation of equals() from open jdk 7

 public boolean equals(Object anObject) {
 1014           if (this == anObject) {
 1015               return true;
 1016           }
 1017           if (anObject instanceof String) {
 1018               String anotherString = (String)anObject;
 1019               int n = count;
 1020               if (n == anotherString.count) {
 1021                   char v1[] = value;
 1022                   char v2[] = anotherString.value;
 1023                   int i = offset;
 1024                   int j = anotherString.offset;
 1025                   while (n-- != 0) {
 1026                       if (v1[i++] != v2[j++])
 1027                           return false;
 1028                   }
 1029                   return true;
 1030               }
 1031           }
 1032           return false;
 1033       }



回答3:


I always use StringUtils.compare ( Apache Commons ). This handles the null case for either String argument as well.




回答4:


a => result b => current

It would be helpful to check if either of arguments is null.




回答5:


A couple of things:

  1. When you compare strings for equality, use the .equals method. == is used to compare object references and see if they refer to the same instance. .equals actually compares the characters inside the String object.
  2. Even if you do things your way (which is incorrect), the for loop should look like this

    for (int b = 0; b < arg1.length(); b++)



来源:https://stackoverflow.com/questions/6730907/java-compare-strings

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!