java字符串的方法
A. java中字符串有哪些方法
API找
http://tool.oschina.net/apidocs/apidoc?api=jdk-zh
java.lang.String
B. java 中String的equals()方法
java.lang.String.equals() 方法比较字符串与指定的对象。其结果是true当且仅当参数不为null,并且是一个String对象,这个对象表示相同的字符序列
声明
以下是声明java.lang.String.equals()方法
public boolean equals(Object anObject)
参数
anObject -- 这是这个String对比较的对象
返回值
此方法返回true如果给定对象代表一个字符串,这个字符串,否则返回false
异常
NA
实例
下面的例子显示使用的java.lang.String.equals()方法
package com.pieryon;
import java.lang.*;
public class StringDemo {
public static void main(String[] args) {
String str1 = "sachin tenlkar";
String str2 = "amrood admin";
String str3 = "amrood admin";
// checking for equality
boolean retval1 = str2.equals(str1);
boolean retval2 = str2.equals(str3);
// prints the return value
System.out.println("str2 is equal to str1 = " + retval1);
System.out.println("str2 is equal to str3 = " + retval2);
}
}
编译和运行上面的程序,这将产生以下结果:
str2 is equal to str1 = false
str2 is equal to str3 = true
C. java中string类的方法有哪些
方法摘要
char charAt(int index)
返回指定索引处的 char 值。
int codePointAt(int index)
返回指定索引处的字符(Unicode 代码点)。
int codePointBefore(int index)
返回指定索引之前的字符(Unicode 代码点)。
int codePointCount(int beginIndex, int endIndex)
返回此 String 的指定文本范围中的 Unicode 代码点数。
int compareTo(String anotherString)
按字典顺序比较两个字符串。
int compareToIgnoreCase(String str)
不考虑大小写,按字典顺序比较两个字符串。
String concat(String str)
将指定字符串联到此字符串的结尾。
boolean contains(CharSequence s)
当且仅当此字符串包含 char 值的指定序列时,才返回 true。
boolean contentEquals(CharSequence cs)
当且仅当此 String 表示与指定序列相同的 char 值时,才返回 true。
boolean contentEquals(StringBuffer sb)
当且仅当此 String 表示与指定的 StringBuffer 相同的字符序列时,才返回 true。
static String ValueOf(char[] data)
返回指定数组中表示该字符序列的字符串。
static String ValueOf(char[] data, int offset, int count)
返回指定数组中表示该字符序列的字符串。
boolean endsWith(String suffix)
测试此字符串是否以指定的后缀结束。
boolean equals(Object anObject)
比较此字符串与指定的对象。
boolean equalsIgnoreCase(String anotherString)
将此 String 与另一个 String 进行比较,不考虑大小写。
static String format(Locale l, String format, Object... args)
使用指定的语言环境、格式字符串和参数返回一个格式化字符串。
static String format(String format, Object... args)
使用指定的格式字符串和参数返回一个格式化字符串。
byte[] getBytes()
使用平台默认的字符集将此 String 解码为字节序列,并将结果存储到一个新的字节数组中。
void getBytes(int srcBegin, int srcEnd, byte[] dst, int dstBegin)
已过时。 该方法无法将字符正确转换为字节。从 JDK 1.1 起,完成该转换的首选方法是通过 getBytes() 构造方法,该方法使用平台的默认字符集。
byte[] getBytes(String charsetName)
使用指定的字符集将此 String 解码为字节序列,并将结果存储到一个新的字节数组中。
void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)
将字符从此字符串复制到目标字符数组。
int hashCode()
返回此字符串的哈希码。
int indexOf(int ch)
返回指定字符在此字符串中第一次出现处的索引。
int indexOf(int ch, int fromIndex)
从指定的索引开始搜索,返回在此字符串中第一次出现指定字符处的索引。
int indexOf(String str)
返回第一次出现的指定子字符串在此字符串中的索引。
int indexOf(String str, int fromIndex)
从指定的索引处开始,返回第一次出现的指定子字符串在此字符串中的索引。
String intern()
返回字符串对象的规范化表示形式。
int lastIndexOf(int ch)
返回最后一次出现的指定字符在此字符串中的索引。
int lastIndexOf(int ch, int fromIndex)
从指定的索引处开始进行后向搜索,返回最后一次出现的指定字符在此字符串中的索引。
int lastIndexOf(String str)
返回在此字符串中最右边出现的指定子字符串的索引。
int lastIndexOf(String str, int fromIndex)
从指定的索引处开始向后搜索,返回在此字符串中最后一次出现的指定子字符串的索引。
int length()
返回此字符串的长度。
boolean matches(String regex)
通知此字符串是否匹配给定的正则表达式。
int offsetByCodePoints(int index, int codePointOffset)
返回此 String 中从给定的 index 处偏移 codePointOffset 个代码点的索引。
boolean regionMatches(boolean ignoreCase, int toffset, String other, int ooffset, int len)
测试两个字符串区域是否相等。
boolean regionMatches(int toffset, String other, int ooffset, int len)
测试两个字符串区域是否相等。
String replace(char oldChar, char newChar)
返回一个新的字符串,它是通过用 newChar 替换此字符串中出现的所有 oldChar 而生成的。
String replace(CharSequence target, CharSequence replacement)
使用指定的字面值替换序列替换此字符串匹配字面值目标序列的每个子字符串。
String replaceAll(String regex, String replacement)
使用给定的 replacement 字符串替换此字符串匹配给定的正则表达式的每个子字符串。
String replaceFirst(String regex, String replacement)
使用给定的 replacement 字符串替换此字符串匹配给定的正则表达式的第一个子字符串。
String[] split(String regex)
根据给定的正则表达式的匹配来拆分此字符串。
String[] split(String regex, int limit)
根据匹配给定的正则表达式来拆分此字符串。
boolean startsWith(String prefix)
测试此字符串是否以指定的前缀开始。
boolean startsWith(String prefix, int toffset)
测试此字符串是否以指定前缀开始,该前缀以指定索引开始。
CharSequence subSequence(int beginIndex, int endIndex)
返回一个新的字符序列,它是此序列的一个子序列。
String substring(int beginIndex)
返回一个新的字符串,它是此字符串的一个子字符串。
String substring(int beginIndex, int endIndex)
返回一个新字符串,它是此字符串的一个子字符串。
char[] toCharArray()
将此字符串转换为一个新的字符数组。
String toLowerCase()
使用默认语言环境的规则将此 String 中的所有字符都转换为小写。
String toLowerCase(Locale locale)
使用给定 Locale 的规则将此 String 中的所有字符都转换为小写。
String toString()
返回此对象本身(它已经是一个字符串!)。
String toUpperCase()
使用默认语言环境的规则将此 String 中的所有字符都转换为大写。
String toUpperCase(Locale locale)
使用给定的 Locale 规则将此 String 中的所有字符都转换为大写。
String trim()
返回字符串的副本,忽略前导空白和尾部空白。
static String valueOf(boolean b)
返回 boolean 参数的字符串表示形式。
static String valueOf(char c)
返回 char 参数的字符串表示形式。
static String valueOf(char[] data)
返回 char 数组参数的字符串表示形式。
static String valueOf(char[] data, int offset, int count)
返回 char 数组参数的特定子数组的字符串表示形式。
static String valueOf(double d)
返回 double 参数的字符串表示形式。
static String valueOf(float f)
返回 float 参数的字符串表示形式。
static String valueOf(int i)
返回 int 参数的字符串表示形式。
static String valueOf(long l)
返回 long 参数的字符串表示形式。
static String valueOf(Object obj)
返回 Object 参数的字符串表示形式。
从类 java.lang.Object 继承的方法
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
D. java中怎么执行字符串中的代码
转:
在javascript中eval()可以实现字符串转代码,java中需要使用动态编译。
把获得的字符串写入一个临时文件中,然后编译它,在调用其中的函数。
我们把要转换的字符串构造一个完整的类:如果方法是有返回值的.则:
public object eval(string str){
//生成java文件
string s = "class temp{";
s += "object rt(){"
s += "myclass mc = new myclass();"
s += " return mc."+str+"();";
s += "}"
s +="}";
file f = new file("temp.java");
printwriter pw = new printwriter(new filewriter(f));
pw.println(s);
pw.close();
//动态编译
com.sun.tools.javac.main javac = new com.sun.tools.javac.main();
string[] cpargs = new string[] {"-d", "所在目录","temp.java"};
int status = javac.compile(cpargs);
if(status!=0){
system.out.println("没有成功编译源文件!");
return null;
}
//调用temp的rt方法返回结果:
myclassloader mc = new myclassloader();
class clasz = mc.loadclass("test.class",true);
method rt = clasz.getmethod("rt", new class[]{ string[].class });
return rt.invoke(null, new object[] { new string[0] });
//如果方法没有返回就直接调用
}
我们可以先写好多个重载的eval,有返回值和没有返回值的.以及可以传递参数的.
这样我们就可以用字符串转换为java的语句来执行.
E. java中字符、字符串的常用方法
转换大小写、"aaaa".toUpperCase(),"aaaa".toLowerCase();
去除前后的空格、"aaaa".trim();
判断是否用那个字符串开始(结束)、"aaaa".startWith("a"),"aaaa".endWith("a");
获取长度、"aaaa".length();
备注专:方法太多了,属建议可以通过自己实际操作的形式熟悉下。
F. java中的string方法
从一个byte数组里,从第offset位置开始取,取length长度,按照规定的Charset字符编码集来获取byte里的数回据简单示例:public
static
void
main(String[]
args)
{
byte[]
a
=
{'a','b','c','d','e','f','g','h','i'};
String
aa
=
new
String(a,5,3,Charset.defaultCharset());
String
bb
=
new
String(a,5,3,Charset.forName("US-ASCII"));
System.out.println(aa);
System.out.println(bb);
}当然,答如果byte数组内存放的用中文字符或者其他字符,测试起来更有意义~
G. java中的字符串比较方法
java中的字符串比较方法:
1)string1.equals(string2)
2) str1==str2 。
java中字符串的比较是==比较引用,equals 比较值的做法。但是不同的声明方法字符串的比较结果也是不同的。
例如: String str1=new String("a");
String str2=new String("a");
str1==str2 输出false
str1.equals(str2) 输出true
而如果这样声明
String str1="a";
String str2="a";
str1==str2 输出true
str1.equals(str2) 输出true
这是因为 equals 方法本来也是比较引用的字符串类在实现的时候重写了该方法。
第一种声明方法等于是声明了两个对象,用’==‘比较是时候比较的是引用输出的是false 由于他们的值相同用equals的时候就比较的是值了,输出true。
第二种情况不是因为比较有与第一种有差异,而是因为声明有差异,第二种声明方法在声明的时候有堆或堆栈 共用的现象,也就是说 在声明的时候如果如果声明为类属性他会检查在堆栈中有没有与现在声明的是相同结构的字符串。如果有就直接将地址指向已有内存地址。声明在方法内部的局部变量原理一样只不过他是堆栈共享。
H. java字符串
12.4.4 String 和 StringBuffer 类
这里总结一下同时适用于 String 和 StringBuffer 的方法,以便对它们相互间
的沟通方式有一个印象。这些表格并未把每个单独的方法都包括进去,而是包含
了与本次讨论有重要关系的方法。那些已被覆盖的方法用单独一行总结。
首先总结 String 类的各种方法:
方法 自变量,覆盖 用途
构建器 已被覆盖:默认,String,StringBuffer,char 数组,byte 数组 创建
String 对象
length() 无 String 中的字符数量
charAt() int Index 位于 String 内某个位置的 char
getChars(),getBytes 开始复制的起点和终点,要向其中复制内容的数组,对
目标数组的一个索引 将 char 或 byte 复制到外部数组内部
toCharArray() 无 产生一个 char[],其中包含了 String 内部的字符
equals(),equalsIgnoreCase() 用于对比的一个 String 对两个字串的内容进行
等价性检查
compareTo() 用于对比的一个 String 结果为负、零或正,具体取决于 String
和自变量的字典顺序。注意大写和小写不是相等的!
regionMatches() 这个 String 以及其他 String 的位置偏移,以及要比较的区域
长度。覆盖加入了“忽略大小写”的特性 一个布尔结果,指出要对比的区域是
否相同
startsWith() 可能以它开头的 String。覆盖在自变量里加入了偏移 一个布尔
结果,指出 String 是否以那个自变量开头
endsWith() 可能是这个 String 后缀的一个 String 一个布尔结果,指出自变量
是不是一个后缀
indexOf(),lastIndexOf() 已覆盖:char,char 和起始索引,String,String 和起
始索引 若自变量未在这个 String 里找到,则返回-1;否则返回自变量开始处的
位置索引。lastIndexOf()可从终点开始回溯搜索
substring() 已覆盖:起始索引,起始索引和结束索引 返回一个新的 String
对象,其中包含了指定的字符子集
concat() 想连结的 String 返回一个新 String 对象,其中包含了原始 String 的
字符,并在后面加上由自变量提供的字符
relpace() 要查找的老字符,要用它替换的新字符 返回一个新 String 对象,
其中已完成了替换工作。若没有找到相符的搜索项,就沿用老字串
toLowerCase(),toUpperCase() 无 返回一个新 String 对象,其中所有字符的大
小写形式都进行了统一。若不必修改,则沿用老字串
trim() 无 返回一个新的 String 对象,头尾空白均已删除。若毋需改动,则沿
用老字串
valueOf() 已覆盖:object,char[],char[]和偏移以及计数,boolean,char,int,
long,float,double 返回一个 String,其中包含自变量的一个字符表现形式
Intern() 无 为每个独一无二的字符顺序都产生一个(而且只有一个)String
句柄
可以看到,一旦有必要改变原来的内容,每个 String 方法都小心地返回了一
个新的 String 对象。另外要注意的一个问题是,若内容不需要改变,则方法只返
回指向原来那个 String 的一个句柄。这样做可以节省存储空间和系统开销。
下面列出有关 StringBuffer(字串缓冲)类的方法:
方法 自变量,覆盖 用途
构建器 已覆盖:默认,要创建的缓冲区长度,要根据它创建的 String 新建
一个 StringBuffer 对象
toString() 无 根据这个 StringBuffer 创建一个 String
length() 无 StringBuffer 中的字符数量
capacity() 无 返回目前分配的空间大小
ensureCapacity() 用于表示希望容量的一个整数 使 StringBuffer 容纳至少希
望的空间大小
setLength() 用于指示缓冲区内字串新长度的一个整数 缩短或扩充前一个字
符串。如果是扩充,则用 null 值填充空隙
charAt() 表示目标元素所在位置的一个整数 返回位于缓冲区指定位置处的
char
setCharAt() 代表目标元素位置的一个整数以及元素的一个新 char 值 修改指
定位置处的值
getChars() 复制的起点和终点,要在其中复制的数组以及目标数组的一个索
引 将 char 复制到一个外部数组。和 String 不同,这里没有 getBytes()可供使用
append() 已覆盖:Object,String,char[],特定偏移和长度的 char[],boolean,
char,int,long,float,double 将自变量转换成一个字串,并将其追加到当前缓
冲区的末尾。若有必要,同时增大缓冲区的长度
insert() 已覆盖,第一个自变量代表开始插入的位置:Object,String,char[],
boolean,char,int,long,float,double 第二个自变量转换成一个字串,并插入
当前缓冲区。插入位置在偏移区域的起点处。若有必要,同时会增大缓冲区的长
度
reverse() 无 反转缓冲内的字符顺序
最常用的一个方法是 append()。在计算包含了+和+=运算符的 String 表达式
时,编译器便会用到这个方法。insert()方法采用类似的形式。这两个方法都能对
缓冲区进行重要的操作,不需要另建新对象。
12.4.5 字串的特殊性
现在,大家已知道 String 类并非仅仅是 Java 提供的另一个类。String 里含有
大量特殊的类。通过编译器和特殊的覆盖或过载运算符+和+=,可将引号字符串
转换成一个 String。在本章中,大家已见识了剩下的一种特殊情况:用同志
StringBuffer 精心构造的“不可变”能力,以及编译器中出现的一些有趣现象。
I. java中怎么把字符串转化为方法
不明白你的意思,字符串是字符串,方法是方法。两码事