JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据.这个String类提供了数值不可改变的字符串.而这个StringBuffer类提供的字符串进行修改.当你知道字符数据要改变的时候你就可以使用 StringBuffer.典型地,你可以使用 StringBuffers来动态构造字符数据.
Java String的使用方法:
1. 首先String不属于8种基本数据类型,String是一个对象.
因为对象的默认值是null,所以String的默认值也是null;但它又是一种特殊的对象,有其它对象没有的一些特性.
2. new String()和new String("")都是申明一个新的空字符串,是空串不是null;
3. String str="kvill";
String str=new String ("kvill");的区别:
在这里,我们不谈堆,也不谈栈,只先简单引入常量池这个简单的概念.
常量池(constant pool)指的是在编译期被确定,并被保存在已编译的.class文件中的一些数据.它包括了关于类、方法、接口等中的常量,也包括字符串常量.
看例1:
String s0="kvill";
String s1="kvill";
String s2="kv" + "ill";
System.out.println( s0==s1 );
System.out.println( s0==s2 );
结果为:
true
true
首先,我们要知道Java会确保一个字符串常量只有一个拷贝.
因为例子中的s0和s1中的"kvill"都是字符串常量,它们在编译期就被确定了,所以s0==s1为true;而"kv"和"ill"也都是字符串常量,当一个字符串由多个字符串常量连接而成时,它自己肯定也是字符串常量,所以s2也同样在编译期就被解析为一个字符串常量,所以s2也是常量池中"kvill"的一个引用.
所以我们得出s0==s1==s2;
用new String() 创建的字符串不是常量,不能在编译期就确定,所以new String() 创建的字符串不放入常量池中,它们有自己的地址空间.
看例2:
String s0="kvill";
String s1=new String("kvill");
String s2="kv" + new String("ill");
System.out.println( s0==s1 );
System.out.println( s0==s2 );
System.out.println( s1==s2 );
结果为:
false
false
false
例2中s0还是常量池中"kvill"的应用,s1因为无法在编译期确定,所以是运行时创建的新对象"kvill"的引用,s2因为有后半部分new String("ill")所以也无法在编译期确定,所以也是一个新创建对象"kvill"的应用;明白了这些也就知道为何得出此结果了.
4. String.intern():
再补充介绍一点:存在于.class文件中的常量池,在运行期被JVM装载,并且可以扩充.String的intern()方法就是扩充常量池的一个方法;当一个String实例str调用intern()方法时,Java查找常量池中是否有相同Unicode的字符串常量,如果有,则返回其的引用,如果没有,则在常量池中增加一个Unicode等于str的字符串并返回它的引用;看例3就清楚了
例3:
String s0= "kvill";
String s1=new String("kvill");
String s2=new String("kvill");
System.out.println( s0==s1 );
System.out.println( "**********" );
s1.intern();
s2=s2.intern(); //把常量池中"kvill"的引用赋给s2
System.out.println( s0==s1);
System.out.println( s0==s1.intern() );
System.out.println( s0==s2 );
结果为:
false
**********
false //虽然执行了s1.intern(),但它的返回值没有赋给s1
true //说明s1.intern()返回的是常量池中"kvill"的引用
true
最后我再破除一个错误的理解:
有人说,"使用String.intern()方法则可以将一个String类的保存到一个全局String表中,如果具有相同值的Unicode字符串已经在这个表中,那么该方法返回表中已有字符串的地址,如果在表中没有相同值的字符串,则将自己的地址注册到表中"如果我把他说的这个全局的String 表理解为常量池的话,他的最后一句话,"如果在表中没有相同值的字符串,则将自己的地址注册到表中"是错的:
看例4:
String s1=new String("kvill");
String s2=s1.intern();
System.out.println( s1==s1.intern() );
System.out.println( s1+" "+s2 );
System.out.println( s2==s1.intern() );
结果:
false
kvill kvill
true
在这个类中我们没有声名一个"kvill"常量,所以常量池中一开始是没有"kvill"的,当我们调用s1.intern()后就在常量池中新添加了一个"kvill"常量,原来的不在常量池中的"kvill"仍然存在,也就不是"将自己的地址注册到常量池中"了.
s1==s1.intern()为false说明原来的"kvill"仍然存在;
s2现在为常量池中"kvill"的地址,所以有s2==s1.intern()为true.
5. 关于equals()和==:
这个对于String简单来说就是比较两字符串的Unicode序列是否相当,如果相等返回true;而==是比较两字符串的地址是否相同,也就是是否是同一个字符串的引用.
6. 关于String是不可变的
这一说又要说很多,大家只要知道String的实例一旦生成就不会再改变了,比如说:String str="kv"+"ill"+" "+"ans";
就是有4个字符串常量,首先"kv"和"ill"生成了"kvill"存在内存中,然后"kvill"又和" " 生成 "kvill "存在内存中,最后又和生成了"kvill ans";并把这个字符串的地址赋给了str,就是因为String的"不可变"产生了很多临时变量,这也就是为什么建议用StringBuffer的原因了,因为StringBuffer是可改变的
Java StringBuffer的使用方法:
1.java.lang.StringBuffer代表可变的字符序列;
2.StringBuffer和String类似,但StringBuffer可以对其字符串进行改变;
3.StringBuffer类的常见构造方法:
StringBuffer()
创建一个不包含字符序列的"空"的StringBuffer对象;
StringBuffer(String str)
创建一个StringBuffer对象,包含与String对象str相同的字符序列.
4.常用方法:
public StringBuffer append()
可以为该StringBuffer对象添加字符序列,返回添加后的该StringBuffer对象引用;
public StringBuffer insert()
可以为该StringBuffer对象在指定位置插入字符序列,返回修改后的该
[b] public StringBuffer delete(int start,int end)
可以删除从start开始到end-1为止的一段字符序列,返回修改后的该
public StringBuffer reverse()
用于将字符序列逆序,返回修改后的该StringBuffer对象引用.
实例:
程序代码
public class TestStringBuffer
{
public static void main(String args[]) {
String s = "dengkehai" ;
char[] a = {'a','b','c'} ;
StringBuffer sb1 = new StringBuffer(s) ;
sb1.append('/').append("DKH").append('/').append("J2SE") ;
System.out.println(sb1) ;
StringBuffer sb2 = new StringBuffer("Number:") ;
for(int i=0 ;i<10 ;i++)
sb2.append(i) ;
System.out.println(sb2) ;
sb2.delete(10,sb2.length()).insert(0,a) ;
System.out.println(sb2) ;
System.out.println(sb2.reverse()) ;
}
我想知道equals是否既比对象又比值比如:
String s1="hello";
String s2="hello";
String s3=new String("hello");
s1.eauals("hello");
s1.equals(s2);//?
== 只是比较两个数据的地址,也就是这两个是不是同一个东西 ...
你一个String 和另一个String == ,绝对不会相等.
因为它们是两个...
因为例如 int, boolean 等基本类型的值比较就要用 ==
还有有没有人想过如果不是String 类型的对象那equals比较的是什么呢??例如: List 、Iterator 、Hashtable ......
==比较是否为同一引用(类型),因此s1==""恒为true
String s1="hello";
String s2="hello";
String s3=new String("hello");
s1.eauals("hello");//true?
s1.equals(s2);//true?
s1==s2//false?
s3=="hello"//false?
还想问一下基本数据类型怎么判断是否相等,==是否可以在基数类中使用:如
int i=1; if (i==1){}
如果不能,是否将i包装成INTEGER类再使用equals
==用于判断int型,char型等.int i=1; if (i==1){}这样使用是正确的.
2,当用包裹类时,例如 Integer i = new Integer(1);
Integer j = new Integer(1);
i==j是比较的两个对象是否是同一引用,也就是说是否是指的同一对象,显然结果false;
如果用equals比较是比较两者的值是否相同,结果为true;
3,对象的比较除去StringBuffer类,结果都同于第二点(String 也与第二点相同);
4,StringBuffer类两种调用方法都返回false;
5,说一点,楼上的说法是不对的;
Java String的使用方法:
1. 首先String不属于8种基本数据类型,String是一个对象.
因为对象的默认值是null,所以String的默认值也是null;但它又是一种特殊的对象,有其它对象没有的一些特性.
2. new String()和new String("")都是申明一个新的空字符串,是空串不是null;
3. String str="kvill";
String str=new String ("kvill");的区别:
在这里,我们不谈堆,也不谈栈,只先简单引入常量池这个简单的概念.
常量池(constant pool)指的是在编译期被确定,并被保存在已编译的.class文件中的一些数据.它包括了关于类、方法、接口等中的常量,也包括字符串常量.
看例1:
String s0="kvill";
String s1="kvill";
String s2="kv" + "ill";
System.out.println( s0==s1 );
System.out.println( s0==s2 );
结果为:
true
true
首先,我们要知道Java会确保一个字符串常量只有一个拷贝.
因为例子中的s0和s1中的"kvill"都是字符串常量,它们在编译期就被确定了,所以s0==s1为true;而"kv"和"ill"也都是字符串常量,当一个字符串由多个字符串常量连接而成时,它自己肯定也是字符串常量,所以s2也同样在编译期就被解析为一个字符串常量,所以s2也是常量池中"kvill"的一个引用.
所以我们得出s0==s1==s2;
用new String() 创建的字符串不是常量,不能在编译期就确定,所以new String() 创建的字符串不放入常量池中,它们有自己的地址空间.
看例2:
String s0="kvill";
String s1=new String("kvill");
String s2="kv" + new String("ill");
System.out.println( s0==s1 );
System.out.println( s0==s2 );
System.out.println( s1==s2 );
结果为:
false
false
false
例2中s0还是常量池中"kvill"的应用,s1因为无法在编译期确定,所以是运行时创建的新对象"kvill"的引用,s2因为有后半部分new String("ill")所以也无法在编译期确定,所以也是一个新创建对象"kvill"的应用;明白了这些也就知道为何得出此结果了.
4. String.intern():
再补充介绍一点:存在于.class文件中的常量池,在运行期被JVM装载,并且可以扩充.String的intern()方法就是扩充常量池的一个方法;当一个String实例str调用intern()方法时,Java查找常量池中是否有相同Unicode的字符串常量,如果有,则返回其的引用,如果没有,则在常量池中增加一个Unicode等于str的字符串并返回它的引用;看例3就清楚了
例3:
String s0= "kvill";
String s1=new String("kvill");
String s2=new String("kvill");
System.out.println( s0==s1 );
System.out.println( "**********" );
s1.intern();
s2=s2.intern(); //把常量池中"kvill"的引用赋给s2
System.out.println( s0==s1);
System.out.println( s0==s1.intern() );
System.out.println( s0==s2 );
结果为:
false
**********
false //虽然执行了s1.intern(),但它的返回值没有赋给s1
true //说明s1.intern()返回的是常量池中"kvill"的引用
true
最后我再破除一个错误的理解:
有人说,"使用String.intern()方法则可以将一个String类的保存到一个全局String表中,如果具有相同值的Unicode字符串已经在这个表中,那么该方法返回表中已有字符串的地址,如果在表中没有相同值的字符串,则将自己的地址注册到表中"如果我把他说的这个全局的String 表理解为常量池的话,他的最后一句话,"如果在表中没有相同值的字符串,则将自己的地址注册到表中"是错的:
看例4:
String s1=new String("kvill");
String s2=s1.intern();
System.out.println( s1==s1.intern() );
System.out.println( s1+" "+s2 );
System.out.println( s2==s1.intern() );
结果:
false
kvill kvill
true
在这个类中我们没有声名一个"kvill"常量,所以常量池中一开始是没有"kvill"的,当我们调用s1.intern()后就在常量池中新添加了一个"kvill"常量,原来的不在常量池中的"kvill"仍然存在,也就不是"将自己的地址注册到常量池中"了.
s1==s1.intern()为false说明原来的"kvill"仍然存在;
s2现在为常量池中"kvill"的地址,所以有s2==s1.intern()为true.
5. 关于equals()和==:
这个对于String简单来说就是比较两字符串的Unicode序列是否相当,如果相等返回true;而==是比较两字符串的地址是否相同,也就是是否是同一个字符串的引用.
6. 关于String是不可变的
这一说又要说很多,大家只要知道String的实例一旦生成就不会再改变了,比如说:String str="kv"+"ill"+" "+"ans";
就是有4个字符串常量,首先"kv"和"ill"生成了"kvill"存在内存中,然后"kvill"又和" " 生成 "kvill "存在内存中,最后又和生成了"kvill ans";并把这个字符串的地址赋给了str,就是因为String的"不可变"产生了很多临时变量,这也就是为什么建议用StringBuffer的原因了,因为StringBuffer是可改变的
Java StringBuffer的使用方法:
1.java.lang.StringBuffer代表可变的字符序列;
2.StringBuffer和String类似,但StringBuffer可以对其字符串进行改变;
3.StringBuffer类的常见构造方法:
StringBuffer()
创建一个不包含字符序列的"空"的StringBuffer对象;
StringBuffer(String str)
创建一个StringBuffer对象,包含与String对象str相同的字符序列.
4.常用方法:
public StringBuffer append()
可以为该StringBuffer对象添加字符序列,返回添加后的该StringBuffer对象引用;
public StringBuffer insert()
可以为该StringBuffer对象在指定位置插入字符序列,返回修改后的该
[b] public StringBuffer delete(int start,int end)
可以删除从start开始到end-1为止的一段字符序列,返回修改后的该
public StringBuffer reverse()
用于将字符序列逆序,返回修改后的该StringBuffer对象引用.
实例:
程序代码
public class TestStringBuffer
{
public static void main(String args[]) {
String s = "dengkehai" ;
char[] a = {'a','b','c'} ;
StringBuffer sb1 = new StringBuffer(s) ;
sb1.append('/').append("DKH").append('/').append("J2SE") ;
System.out.println(sb1) ;
StringBuffer sb2 = new StringBuffer("Number:") ;
for(int i=0 ;i<10 ;i++)
sb2.append(i) ;
System.out.println(sb2) ;
sb2.delete(10,sb2.length()).insert(0,a) ;
System.out.println(sb2) ;
System.out.println(sb2.reverse()) ;
}
}
compareTo方法是比较两个字符串的词典顺序
也就是在字典中的顺序,比如“abcd”在“acdb”前面
另外你应该先把字符串转变成int,然后再比较
可以用下面的方法比较两个整数
public int max(int m,int n)
{
if(m>n)
return m;
else if(n>m)
return n;
else return 0;//相等的时候返回0
}
可以用int a=Integer.parseint("20");
来把字符串20转换为整数20并赋予a
--__---------------------------------------------------------------------------------------------------------
java中字符串比较1equals是用来比较字符串是否相等的,==不能用做字符串的比较.如果要比较大小应该用compareto(String),它是依次比较字符串的每个字符的大小
回复:java中字符串比较2
lsj_smile(我笑)我想知道equals是否既比对象又比值比如:
String s1="hello";
String s2="hello";
String s3=new String("hello");
s1.eauals("hello");
s1.equals(s2);//?
回复:java中字符串比较5
对象的比较必须用equals== 只是比较两个数据的地址,也就是这两个是不是同一个东西 ...
你一个String 和另一个String == ,绝对不会相等.
因为它们是两个...
回复:java中字符串比较6
equals 是值比较,== 是reference 如果不计较的说可以认为是片面正确,因为例如 int, boolean 等基本类型的值比较就要用 ==
还有有没有人想过如果不是String 类型的对象那equals比较的是什么呢??例如: List 、Iterator 、Hashtable ......
回复:java中字符串比较7
用equals即比较对象又比较值,事实上,如果两个对象无法进行equals比较,编译根本无法通过.有的情况,比如Double和Float型,比较结果始终是false==比较是否为同一引用(类型),因此s1==""恒为true
回复:java中字符串比较8
请判断是否正确:String s1="hello";
String s2="hello";
String s3=new String("hello");
s1.eauals("hello");//true?
s1.equals(s2);//true?
s1==s2//false?
s3=="hello"//false?
还想问一下基本数据类型怎么判断是否相等,==是否可以在基数类中使用:如
int i=1; if (i==1){}
如果不能,是否将i包装成INTEGER类再使用equals
回复:java中字符串比较9
当s1,s2为String型,s1==s2这样写是错误的.判断他们是否相等必须用equals==用于判断int型,char型等.int i=1; if (i==1){}这样使用是正确的.
回复:java中字符串比较10
1,简单数据类型不可单纯的来做为一个对象,比较值大小时必须用“==”;2,当用包裹类时,例如 Integer i = new Integer(1);
Integer j = new Integer(1);
i==j是比较的两个对象是否是同一引用,也就是说是否是指的同一对象,显然结果false;
如果用equals比较是比较两者的值是否相同,结果为true;
3,对象的比较除去StringBuffer类,结果都同于第二点(String 也与第二点相同);
4,StringBuffer类两种调用方法都返回false;
5,说一点,楼上的说法是不对的;
_____----------------------------------------------------------------------------------------------------
java中字符串比较为什么不能用“==”
如果说==是比较地址指针的 他照样踢了你呵呵
java是号称无指针的哦,
应该说== 是比较两对象是否在同一个存储单元里的,才比较符合java的说法哦
而equals是比较两对象的内容是否一样啊
所以也不能说==不能比较,只是比较特殊。
java是号称无指针的哦,
应该说== 是比较两对象是否在同一个存储单元里的,才比较符合java的说法哦
而equals是比较两对象的内容是否一样啊
所以也不能说==不能比较,只是比较特殊。
看下例:
String str1 =new String("a");
String str2 =new String("a");
这时str1==str2为比较两个引用地址是否相等,返回false
而str1.equals(str2)是比较两个对象的内容,返回值为true.
String str2 =new String("a");
这时str1==str2为比较两个引用地址是否相等,返回false
而str1.equals(str2)是比较两个对象的内容,返回值为true.
----------------------------------------------------------------------------------
关于字符串(String)
[p>
字符串是用一对双引号括起来的字符序列,在JAVA语言中,字符串数据实际上由String类所实现的。
Java字符串类分为两类:一类是在程序中不会被改变长度的不变字符串;二类是在程序中会被改变长度的可变字符串。Java环境为了存储和维护这两类字符串提供了
String和
StringBuffer两个类。
一、创建字符串
例: String str= new( "This is a String" );
或者 String str= "This is a String" ;
二、得到字符串对象的有关信息
1.通过调用length()方法得到String的长度.
例:
String str= "This is a String" ;
int len =str.length();
2.StringBuffer类的capacity()方法与String类的length()的方法类似,但是她测试是分配给StringBuffer的内存空间的大小,而不是当前被使用了的内存空间。
3.如果想确定字符串中指定字符或子字符串在给定字符串的位置,可以用indexOf()和lastIndexOf()方法。
String str= "This is a String" ;
Int index1 =str.indexOf( "i" ); //index=2
Int index2=str.indexOf('i',index+1); //index2=5
Int index3=str.lastIndexOf("I"); //index3=15
Int index4=str.indexOf("String"); //index4=10
三、String 对象的比较和操作
1.String 对象的比较
String类的equals()方法用来确定两个字符串是否相等。
String str="This is a String";
Boolean result=str.equals("This is another String ");
//result=false
2.String对象的访问
A、方法charAt()用以得到指定位置的字符。
String str="This is a String";
char chr=str.charAt(3); //chr="i"
B、方法getChars()用以得到字符串的一部分字符串
public void getChars(int srcBegin,int srcEnd,char[]dst,int dstBegin)
String str="This is a String";
Char chr =new char[10];
Str.getChars(5,12,chr,0); //chr="is a St"
C、subString()是提取字符串的另一种方法,它可以指定从何处开始提取字符串以及何处结束。
3.操作字符串
A、replace()方法可以将字符串中的一个字符替换为另一个字符。
String str="This is a String";
String str1=str.replace('T','t'); //str1="this is a String"
B、concat()方法可以把两个字符串合并为一个字符串。
String str="This is a String";
String str1=str.concat("Test"); //str1="This is a String Test"
C、toUpperCase()和toLowerCase()方法分别实现字符串大小写的转换。
String str="THIS IS A STRING";
String str1=str.toLowerCase(); //str1="this is a string";
D、trim()方法可以将字符串中开头和结尾处的空格去掉.
String str="This is a String ";
String str1=str.trim(); // str1="This is a String"
E、String 类提供静态方法valueOf(),它可以将任何类型的数据对象转换为一个字符串。如
System.out.println(String,ValueOf(math,PI));
四、修改可变字符串
StringBuffer类为可变字符串的修改提供了3种方法,在字符串中间插入和改变某个位置所在的字符。
1.在字符串后面追加:用append()方法将各种对象加入到字符串中。
2.在字符串中间插入:用insert()方法。例
StringBuffer str=new StringBuffer("This is a String");
Str.insert(9,"test");
System.out.println(str.toString());
这段代码输出为:This is a test String
3.改变某个位置所在的字符,用setCharAt()方法。
一、创建字符串
例: String str= new( "This is a String" );
或者 String str= "This is a String" ;
二、得到字符串对象的有关信息
1.通过调用length()方法得到String的长度.
例:
String str= "This is a String" ;
int len =str.length();
2.StringBuffer类的capacity()方法与String类的length()的方法类似,但是她测试是分配给StringBuffer的内存空间的大小,而不是当前被使用了的内存空间。
3.如果想确定字符串中指定字符或子字符串在给定字符串的位置,可以用indexOf()和lastIndexOf()方法。
String str= "This is a String" ;
Int index1 =str.indexOf( "i" ); //index=2
Int index2=str.indexOf('i',index+1); //index2=5
Int index3=str.lastIndexOf("I"); //index3=15
Int index4=str.indexOf("String"); //index4=10
三、String 对象的比较和操作
1.String 对象的比较
String类的equals()方法用来确定两个字符串是否相等。
String str="This is a String";
Boolean result=str.equals("This is another String ");
//result=false
2.String对象的访问
A、方法charAt()用以得到指定位置的字符。
String str="This is a String";
char chr=str.charAt(3); //chr="i"
B、方法getChars()用以得到字符串的一部分字符串
public void getChars(int srcBegin,int srcEnd,char[]dst,int dstBegin)
String str="This is a String";
Char chr =new char[10];
Str.getChars(5,12,chr,0); //chr="is a St"
C、subString()是提取字符串的另一种方法,它可以指定从何处开始提取字符串以及何处结束。
3.操作字符串
A、replace()方法可以将字符串中的一个字符替换为另一个字符。
String str="This is a String";
String str1=str.replace('T','t'); //str1="this is a String"
B、concat()方法可以把两个字符串合并为一个字符串。
String str="This is a String";
String str1=str.concat("Test"); //str1="This is a String Test"
C、toUpperCase()和toLowerCase()方法分别实现字符串大小写的转换。
String str="THIS IS A STRING";
String str1=str.toLowerCase(); //str1="this is a string";
D、trim()方法可以将字符串中开头和结尾处的空格去掉.
String str="This is a String ";
String str1=str.trim(); // str1="This is a String"
E、String 类提供静态方法valueOf(),它可以将任何类型的数据对象转换为一个字符串。如
System.out.println(String,ValueOf(math,PI));
四、修改可变字符串
StringBuffer类为可变字符串的修改提供了3种方法,在字符串中间插入和改变某个位置所在的字符。
1.在字符串后面追加:用append()方法将各种对象加入到字符串中。
2.在字符串中间插入:用insert()方法。例
StringBuffer str=new StringBuffer("This is a String");
Str.insert(9,"test");
System.out.println(str.toString());
这段代码输出为:This is a test String
3.改变某个位置所在的字符,用setCharAt()方法。