Java基础_字符串比较
2024-10-20 21:05:54
字符串之间的比较
- compareTo
- “==”
- equals
compareTo
示例:
compareTo(string)
compareToIgnoreCase(String)
compareTo(object string)
compareTo(string)
该示例通过使用上面的函数比较两个字符串,并返回一个int类型。若字符串等于参数字符串、则返回0,字符串小于参数字符串、则返回值小于0,字符串大于参数字符串、返回值大于0。
我的理解:
compareTo的实质就是前面的字符串与后面的字符串的对应字符相减(从第一个字符开始依次往后进行相减来比较),相等即相减等于0,则继续比较下一个字符的ASCLL码的值,出现不一样的字符,则返回两个字符之间的ASCLL码的差值,还有一种情况:两个字符的长度不一样,而可以参与比较的字符又都完全一样,则返回两个字符串的长度差值。
数字类型不能用compareTo方法,
compareToIgnoreCase(忽略大小写)
不考虑大小写,按字典顺序比较两个字符串。此方法返回一个整数,它的正负号是调用compareTo 的正负号,调用时使用了字符串的规范化版本,其大小写差异已通过对每个字符调用 Character.toLowerCase(Character.toUpperCase(character)) 得以消除。
注意,此方法不考虑语言环境,因此可能在某些特定的语言环境中产生不理想的排序。java.text包提供 Collators来完成语言环境敏感的排序。
另外:
int型可以直接比较,所以没有用到compareTo比较,如果声明的是Date、String、Integer、或者其他的,可以直接使用compareTo比较。
equals和“==”的区别
区别在于equals比较的是内容是否相等、而“==”比较的是引用的变量地址是否相等。返回的都是Boolean类型的。
package com.de.test;
public class StringA {
public static void main(String[] args){
String s1 = "hello";
String s2 = "hello";
String s3 = new String("hello");
String s4 = new String("hello");
System.out.println("s1:" + s1);
System.out.println("s2:" + s2);
System.out.println("s3:" + s3);
System.out.println("s4:" + s4);
System.out.println("----------比较内容是否相等---------------");
System.out.println(s1.equals(s2));
System.out.println(s2.equals(s3));
System.out.println(s3.equals(s4));
System.out.println("----------比较引用地址是否相等---------------");
System.out.println(s1 == s2);
System.out.println(s2 == s3);
System.out.println(s3 == s4);
}
}
/*
运行结果:
s1:hello
s2:hello
s3:hello
s4:hello
----------比较内容是否相等---------------
true
true
true
----------比较引用地址是否相等---------------
true
false
false
*/
最新文章
- adb unknown host service 这个问题的解决,转载
- [转载]const_cast
- php黑魔法之解析问题
- Mybatis知识点总结
- [转] ArcEngine 产生专题图
- POJ2524 Ubiquitous Religions(并查集)
- 最小费用最大流MCMF zkw费用流
- UVALive 7299	Boggle(深搜的姿势)
- Socket的应用案例
- webots自学笔记(五)使用物理插件ODE建立铰链
- mysql数据库实操笔记20170418
- ES6 函数的扩展(1)
- JQuery基本语法(部分)
- mysql面试题
- COMException: The data necessary to complete this operation is not yet available.
- (转)Flask框架+mySQL数据库:误删migrations文件夹后再次创建时遭遇错误(Can't locate revision identified by ‘xxx’)
- yum install oracle-validated
- Inno Setup入门(三)——指定压缩方式
- Java Swing:JPanel添加边框
- jquery获取单选button选中的值