Java字符串类基本概念

个人专题目录


一.Java字符串类基本概念

    在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", index1 + 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="s"

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()方法。

StringBuffer sb = new StringBuffer("aaaaaa");
sb.setCharAt(2, 'b');  // 结果aabaaa

二.字符串分割

一.利用字符串类的split方法进行分割

/**
 * 利用字符串的split方法进行分割
 *
 * @param str        待分割的字符串
 * @param sdelimiter 分割符
 * @return
 */
public String[] splitString(String str, String sdelimiter) {
    String[] array = str.split(sdelimiter);
    return array;
}

二.利用StringTokenizer来进行字符串分割

/**
 * 利用StringTokenizer来进行字符串分割
 *
 * @param str        待分割的字符串
 * @param sdelimiter 分割符
 * @return
 */
public String[] useStringTokenizer(String str, String sdelimiter) {
    StringTokenizer token = new StringTokenizer(str, sdelimiter);
    String[] array = new String[token.countTokens()];
    int i = 0;
    while (token.hasMoreTokens()) {
        array[i] = token.nextToken();
        i++;
    }
    return array;
}

三.字符串数组排序

/**
 * 对字符串数组进行排序
 *
 * @param str  原始字符串数组
 * @param flag flag=0:顺序排序  flag=1:倒序排序
 * @return 排序后的字符串数组
 */
public String[] sort(String[] str, int flag) {
    if (str == null || str.length == 0)
        throw new IllegalArgumentException();
    String temp = str[0];
    //顺序排列 ,即从小到大
    if (flag == 0) {
        for (int i = 0; i < str.length - 1; i++) {
            for (int j = i + 1; j < str.length; j++) {
                if (str[i].compareTo(str[j]) > 0) {
                    temp = str[i];
                    str[i] = str[j];
                    str[j] = temp;
                }
            }
        }
    } else if (flag == 1) {//倒序排列
        for (int i = 0; i < str.length - 1; i++) {
            for (int j = i + 1; j < str.length; j++) {
                if (str[i].compareTo(str[j]) < 0) {
                    temp = str[i];
                    str[i] = str[j];
                    str[j] = temp;
                }
            }
        }
    }
    return str;
}

四.使用Hashtable对字符串进行碰撞

利用hashtable对字符串进行过滤,两个字符数组之间的比较,对字符串数组进行过滤

1.在一些字符串数组中,常会有重复的记录,比如手机号码,我们可以通过Hashtable来对其进行过滤

public String[] checkArray(String[] str) {
    Hashtable<String, String> hash = new Hashtable<>();
    for (String aStr : str) {
        if (!hash.containsKey(aStr))
            hash.put(aStr, aStr);
    }
    Enumeration enumeration = hash.keys();
    String[] str_new = new String[hash.size()];
    int i = 0;
    while (enumeration.hasMoreElements()) {
        str_new[i] = enumeration.nextElement().toString();
        i++;
    }
    return str_new;
}

2.A,B均为字符串数组,找出在A中存在,而在B中不存在的字符串

public String[] compareArray(String[] a, String[] b) {
    Hashtable<String, String> hash = new Hashtable<>();
    Hashtable<String, String> hash_new = new Hashtable<>();
    for (String aB : b) {
        hash.put(aB, aB);
    }
    for (String anA : a) {
        if (!hash.containsKey(anA)) {
            hash_new.put(anA, anA);
        }
    }
    String[] c = new String[hash_new.size()];
    int i = 0;
    Enumeration enumeration = hash_new.keys();
    while (enumeration.hasMoreElements()) {
        c[i] = enumeration.nextElement().toString();
        i++;
    }
    return c;
}

3.将一个字符串数组中某一个特定的字符串过滤掉

/**
 * 检验一个字符串数组,若包含某一特定的字符串,则将该字符串从数组中删
 * <p>
 * 除,返回剩余的字符串数组
 *
 * @param str_array  字符串数组
 * @param str_remove 待删除的字符串
 * @return 过滤后的字符串
 */
public String[] removeStrFromArray(String[] str_array, String str_remove) {
    Hashtable<String, String> hash = new Hashtable<>();
    for (int i = 0; i < str_array.length; i++) {
        if (!str_array[i].equals(str_remove))
            hash.put(str_array[i], str_array[i]);
    }
    //生成一个新的数组
    String[] str_new = new String[hash.size()];
    int i = 0;
    Enumeration enumeration = hash.keys();
    while (enumeration.hasMoreElements()) {
        str_new[i] = enumeration.nextElement().toString();
        i++;
    }
    return str_new;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,617评论 18 399
  • 前言 最先接触编程的知识是在大学里面,大学里面学了一些基础的知识,c语言,java语言,单片机的汇编语言等;大学毕...
    oceanfive阅读 3,055评论 0 7
  • 2017年2月9日 天气: 晴 心情: 疑惑 Objective 你对今天学的记得什么? 沟通高手的特质。 1、拥...
    Jiang江柳阅读 441评论 2 1
  • 今天 哈哈哈我和老加 在晚课的时候 又想了个幺蛾子 想翘了晚自习 去操场吃串和啤酒 哈哈 然后我说 叫上他们吧 我...
    一大一阅读 274评论 0 0
  • 今天又是一个大晴天。中午回家又吃了好多羊排,最后六块都吃完啦。跟香香玩猴猴,小伙在后院拉了坨便便,然后猴猴丢到院子...
    张大麦麦麦阅读 186评论 0 1