zoukankan      html  css  js  c++  java
  • JAVA 字符串的特点

    字符串概述与特点

    java.lang.String类 代表字符串

    API当中说:Java程序中的所有字符串字面值(如“abc“)都作为此类的实例实现。
    其实就是说:程序当中所用的双引号字符串,都是String类的对象。(就算没有new,也照样是。)

    字符串的特点

    1. 字符串的内容永远不可改变。【重点】
    2. 正是因为字符串不可改变,所以字符串是可以共享使用的。
    3. 字符串效果上相当于是char[]字符数组,但是底层原理byte[]字节数组

    创建字符串的常见3+1种方式

    三种构造方法

    复制代码
    public String():
    创建一个空白字符串,不含有任何内容。   String str = new String(); public String(char[] array):
    根据字符数组的内容,来对应的字符串。   char[] charArray = {'A','B','C'};   String str = new String(charArray); public String(byte[] array):
    根据字节数组的内容,来对应的字符串。   byte[] byteArray = {33,55,77};   String str = new String(byteArray)
    复制代码

    一种直接创建:

    String str = "CaiNiap";//右边直接用双引号

    注意:直接写上双引号,就是字符串对象。

    字符串常量池

    程序当中直接写上的双引号字符串,就在字符串常量池中。

    对于基本类型来说,== 是进行数值的比较
    对于引用类型来说,== 是进行【地址值】的比较。
    注意:双引号直接写的字符串在常量当中,new的不在池当中

    字符串的比较

    == 是进行对象的地址值比较,如果确实需要字符串的内容比较,可以使用两方法。

    public boolean equals(Object obj):
    参数可以是任何对象,只有参数是一个字符串并且内容相同的才会给true,否则返回false

    备注:任何对象都能用Object进行接收

    如果比较双方一个常量一个变量,推荐把常量字符串写在前面。

    推荐:”abc“.equals(str) 
    不推荐:str.equals("abc")

    String当中与获取相关的常用方法有

    复制代码
    public int length();
    获取字符串当中含有的字符个数,拿到字符串长度。
    
    public String concat(String str):
    将当前字符串和参数字符串拼接成为返回值新的字符串。
    
    public char charAt(int index):
    获取指定索引位置的单个字符。(索引从0开始)
    
    public int indexOf(String str);
    查找参数字符串在本字符串当中首次出现的索引位置,如果没有返回-1值。
    复制代码

    字符串的截取方法:

    复制代码
    public String substring(int index);
    截取从参数位置一直到字符串末尾,返回新字符串。、
    
    public String substring(int begin,int end)
    截取从begin开始,一直到end结束,中间的字符串
    备注:[begin ,end),包含左边,不包含右边。
    
    String 当中与转换相关的常用方法有:
    
    public char[] toCharArray();
    将当前字符串拆分成为字符串数组作为返回值。
    
    public byte[] getBytes();
    获取当前字符串底层的字节数组
    
    public String replace(CharSequence oldString,CharSequence newString);
    将所有出现的老字符串替换为新的字符串,返回替换后的结果新字符串。
    复制代码

    字符串的分割

    分割字符串的方法;

    public String[] split(String regex):
    按照参数的规则,将字符串切分成为若干部分。

    注意事项:

    • split方法的参数其实是一个“正则表达式”
    • 注意:如果按照英文句点,"."进行切分,必须写"\\."(两个反斜杠)

    例子

    定义一个方法:把数组{1,2,3}按照指定的格式拼接成一个字符串。格式参照如下:[word1#word2#word3#].

    分析:
    1.首先准备一个int[]数组,内容是:1,2,3
    2.定义一个方法,用来将数组变成字符串
    三要素:
    返回值类型:String
    方法名称:fromArrayToString
    参数列表:int[]
    3.格式:[word1#word2#word3#]
    用到:for循环、字符串拼接、每个数组元素之前都有一个word字样、分隔使用的是#、分区下一个是不是最后一个
    4.调用方法,得到返回值,并打印结果字符串

    复制代码
    public class CaiNiao{
        
        public static void main(String[] args){
            int[] array = {1,2,3};
            String result = fromArrayToString(array);
            System.out.println(result);
            
        }
        
        public static String fromArrayToString(int[] array){
        String str = "[";
        for(int i = 0;i<array.length;i++){
            if (i==array.length-1){
                str +="word" + array[i] +"]";
            }else{
                str += "world" + array[i] + "#";
            }
        }
        return str;
        }
    }
    复制代码

    例子:

    题目:
    键盘输入一个字符串,并且统计其中各种字符出现的次数。
    种类有:大写字母、小写字母、数字、其他

    思路:
    1.既然用到键盘输入,肯定是Scanner
    2.键盘输入的是字符串,那么:String str =sc.next();
    3.定义四个变量。分别代表四种字符各自出现的次数 。
    4.需要对字符串一个字、一个字的检查,String -->char[],方法就是toCharArray()
    5.遍历char[]字符数组,对当前字符种类进行判断,并且用四个变量进行++动作。
    6.打印输出四个变量,分别代表四种字符出现的次数。

    复制代码
    import java.util.Scanner;
    
    public class CaiNiao{
        
        public static void main(String[] args){
            Scanner sc = new Scanner(System.in);
            System.out.println("请输入一个字符串: ");
            String input = sc.next();
            //获取键盘输入的一个字符串
            
            int countUpper = 0;//大写字母
            int countLower = 0;//小写字母
            int countNumber = 0;//数字
            int countOther= 0;//其他字符
            
            char[] charArray = input.toCharArray();
            for (int i = 0;i<charArray.length;i++){
                char ch = charArray[i];//当前单个字符
                if('A' <= ch&&ch <='Z'){
                    countUpper++;
                }else if ('a' <= ch && ch <='z'}{
                    countLower++;
                }else if ('0' <= ch && ch <= '9'){
                    countNumber++;
                }else{
                    countOther++;
                }
            }
    System.out.println("大写字母有:" + countUpper); System.out.println("小写字母有:" + countLower); System.out.println("数字有:" + countNumber); System.out.println("其他字符有:" + countOther); }
    }

    原文:https://www.cnblogs.com/cainiao-chuanqi/p/11104473.html

  • 相关阅读:
    BZOJ_2002_[Hnoi2010]Bounce 弹飞绵羊_LCT
    BZOJ_4154_[Ipsc2015]Generating Synergy_KDTree
    BZOJ_2801_[Poi2012]Minimalist Security_dfs树+特判+乱搞
    BZOJ_3123_[Sdoi2013]森林_主席树+启发式合并
    2019集训队作业做题实况[1](1-30):
    牛客挑战赛33 F 淳平的形态形成场(无向图计数,EGF,多项式求逆)
    【NOIP2019模拟2019.10.07】果实摘取 (约瑟夫环、Mobius反演、类欧、Stern-Brocot Tree)
    CodeChef Max-digit Tree(动态规划)
    骚操作:c++如何用goto便捷地写人工栈?
    Comet OJ
  • 原文地址:https://www.cnblogs.com/sucretan2010/p/15769393.html
Copyright © 2011-2022 走看看