CodeGym /Java курс /Модул 1 /Сравняване на низове по съдържание

Сравняване на низове по съдържание

Модул 1
Ниво , Урок
На разположение

1. Сравняване на низове

Всичко това е добре. Но можете да видите, че низовете s1и s2всъщност са еднакви, което означава, че съдържат един и същ текст. Когато сравнявате низове, How казвате на програмата да гледа не addressите на Stringобектите, а тяхното съдържание?

За да ни помогне с това, класът на Java Stringима equalsметода. Извикването изглежда така:

string1.equals(string2)
Сравняване на два низа

Този метод връща, trueако низовете са еднакви и falseако не са еднакви.

Пример:

Код Забележка
String s1 = "Hello";
String s2 = "HELLO";
String s3 = s1.toUpperCase();

System.out.println(s1.equals(s2));
System.out.println(s1.equals(s3));
System.out.println(s2.equals(s3));
// Hello
// HELLO
// HELLO

false // They are different
false // They are different
true // They are the same, even though the addresses are different

Още примери:

Код Обяснение
"Hello".equals("HELLO")
false
String s = "Hello";
"Hello".equals(s);
true
String s = "Hel";
"Hello".equals(s + "lo");
true
String s = "H";
(s + "ello").equals(s + "ello");
true


2. Сравнение на низове без meaning за малки и главни букви

В последния пример видяхте, че сравнението дава . Наистина низовете не са равни. Но..."Hello".equals("HELLO")false

Ясно е, че низовете не са равни. Въпреки това съдържанието им има едни и същи букви и се различава само по регистъра на буквите. Има ли няHowъв начин да ги сравним и да пренебрегнем регистъра на буквите? Тоест, така че дава ?"Hello".equals("HELLO")true

И отговорът на този въпрос е да. В Java типът Stringима друг специален метод: equalsIgnoreCase. Извикването изглежда така:

string1.equalsIgnoreCase(string2)

Името на метода се превежда приблизително като сравняване, но пренебрегване на главни и малки букви . Буквите в името на метода включват две вертикални линии: първата е малка L, а втората е главна i. Не позволявайте това да ви обърква.

Пример:

Код Забележка
String s1 = "Hello";
String s2 = "HELLO";
String s3 = s1.toUpperCase();

System.out.println(s1.equalsIgnoreCase(s2));
System.out.println(s1.equalsIgnoreCase(s3));
System.out.println(s2.equalsIgnoreCase(s3));  
// Hello
// HELLO
// HELLO

true
true
true


3. Пример за сравнение на низове

Нека дадем само един прост пример: да предположим, че трябва да въведете два реда от клавиатурата и да определите дали са еднакви. Ето How ще изглежда codeът:

Scanner console = new Scanner(System.in);
String a = console.nextLine();
String b = console.nextLine();
String result = a.equals(b) ? "Same" : "Different";
System.out.println(result);

4. Интересен нюанс на сравнение на низове

Има един важен нюанс, който трябва да знаете.

Ако компилаторът на Java намери множество идентични низове във вашия code (по-специално във вашия code), тогава той ще създаде само един обект за тях, за да спести памет.

String text = "This is a very important message";
String message = "This is a very important message";

И ето Howво ще съдържа паметта като резултат:

сравнение на низове

И ако сравните text == messageтук, тогава ще получите true. Така че не се изненадвайте от това.

Ако по няHowва причина наистина се нуждаете референциите да са различни, тогава можете да напишете това:

String text = "This is a very important message";
String message = new String ("This is a very important message");

Или това:

String text = "This is a very important message";
String message = new String (text);

И в двата случая променливите textи messageсочат към различни обекти, които съдържат един и същи текст.


Коментари
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION