1. == 比较是否是同一对象 eg:String str1="abc",str2="abc" ;if(str1==str2) 结果为true 因为内存中str1和str2的存储地址相同
————————————————————————————————————————————————————————
java中字符串的比较:==(参考)
我们经常习惯性的写上if(str1==str2),这种写法在java中可能会带来问题
example1:
String a="abc";String b="abc"
那么a==b将返回true。因为在java中字符串的值是不可改变的,相同的字符串在内存中只会存
一份,所以a和b指向的是同一个对象;
example2:
String a=new String("abc"); String b=new String("abc");
那么a==b将返回false,此时a和b指向不同的对象
————————————————————————————————————————————————————————
2.String.equals() 返回值为boolean类型 eg:String str1="abc",str2="abc" ;str1.equals(str2) 结果为true
3.compareTo()方法 返回值为int类型,主要用于比较两字符串的大小。eg:String str1="abc",str2="abc" ;str1.compareTo(str2) 结果为0。
下面粘贴一道例题来加强记忆:
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""。
示例 1:
输入: ["flower","flow","flight"]
输出: "fl"
示例 2:
输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-common-prefix
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution {
public String longestCommonPrefix(String[] strs) {
int strArrayLen=strs.length;
if(strArrayLen==0)return "";
if(strArrayLen==1)return strs[0];
int []len=new int[strArrayLen];
for(int i=0;i<strArrayLen;i++){
len[i]=strs[i].length();
}
int minLen=10000;
for(int i=0;i<len.length;i++)if(len[i]<minLen)minLen=len[i];
for(int i=minLen;i>=0;i--){
int flag=1;
String piPei=strs[0].substring(0,i);
for(int j=1;j<strArrayLen;j++){
if(strs[j].substring(0,i).equals(piPei)==true)flag++;
}
if(flag==strArrayLen) return piPei;
}
return "";
}
}