开发者

Java Compare Strings [duplicate]

开发者 https://www.devze.com 2023-03-21 13:49 出处:网络
This question already has answers here: How do I compare strings in Java? (23 answers) Closed 6 months ago.
This question already has answers here: How do I compare strings in Java? (23 answers) Closed 6 months ago.
 /**
 * A method to compare Strings
 * @param arg1
 * @param arg2
 * @return 
 */
public boolean myQuickCompare(String arg1, String a开发者_开发技巧rg2) {
    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?


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


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       }


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


a => result b => current

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


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++)

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号