Java学习笔记——字符串

字符串的特点:

1.字符串的内容用不可变。(重点)

2.正是因为字符串不可改变,所以字符串可以共享使用的。

3.字符串效果上相当于是char[ ]字符数组,但是底层原理是byte[ ]字节数组

 

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

三种构造方法:

public  String(),创建一个空白字符串,不含有任何内容

public  String(char[ ]  array),根据字符数组的内容,来创建对应的字符串

public  String(byte[ ]  array),根据字节数组的内容,来创建对应的字符串

一种直接创建:String str = “hello”;

 

字符串的比较

对于基本类型来说,==是进行数值的比较

对于引用类型来说,==是进行地址值的比较

 

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

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

注意事项:

1.任何对象都能用Object进行接收

2.equals方法具有对称性

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

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

public  boolean  equalsIgnoreCase(String str),忽略大小写,进行内容比较

 

字符串中与获取相关的常用方法

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结束,中间的字符串

字符串与转换相关的常用方法

public char[] toCharArray():将当前字符串拆分成为字符数组作为返回值
public byte[] getBytes():获得当前字符串底层的字节数组
public String replace(CharSequence oldString,CharSequence newString);
将所有出现的老字符串替换成为新的字符串,返回替换之后的结果新字符串
备注:CharSequence意思就是说可以接受字符串类型
public class Demo04StringConvert {
    public static void main(String[] args) {
        //转换为字符数组
        char[] chars = "hello".toCharArray();
        System.out.println(chars[0]);
        System.out.println(chars.length);
        System.out.println("==============");

        //转换成为字节数组
        byte[] bytes = "abc".getBytes();
        for (int i = 0; i < bytes.length; i++) {
            System.out.println(bytes[i]);
        }
        System.out.println("==============");

        //字符串的内容替换
        String str1 = "how do you do?";
        String str2 = str1.replace("o","*");
        System.out.println(str1);
        System.out.println(str2);//h*w d* y*u d*?

        String lang1 = "会不会玩啊?你大爷的!";
        String lang2 = lang1.replace("你大爷的", "****");
        System.out.println(lang2);
    }
}

字符串的分割方法

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

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

练习

拼接字符串

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

思路:1.首先准备一个int[ ]数组,内容是:1、2、3

           2.定义一个方法,用来将数组变成字符串

三要素

返回值类型:String

方法名称:arrayToString

参数列表:int[ ]

public class Test01ArrayToString {
    public static void main(String[] args) {
        //定义一个int类型的数组
        int[] array = {1,2,3,4};

        //调用方法
        String result = arrayToString(array);

        //输出结果
        System.out.println(result);
    }
    public static String arrayToString(int[] array) {
        //创建字符串
        String str = "[";
        //遍历数组,并拼接字符串
        for (int i = 0; i < array.length; i++) {
            if (i == array.length-1) {
                str += "word"+array[i]+"]";
            }else {
                str += "word"+array[i]+"#";
            }
        }
        return str;
    }
}

2、键盘输入一个字符串,并统计其中各种字符出现的次数

种类有:大写字母、小写字母、数字、其他

public class Test02StringCount {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.print("请输入字符串:");
        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 (ch>='A' && ch<='Z') {
                countUpper++;
            }else if (ch>='a' && ch<='z') {
                countLower++;
            }else if (ch>='0' && ch<='9') {
                countNumber++;
            }else {
                countOther++;
            }
        }
        System.out.println("大写字母:"+countUpper);
        System.out.println("小写字母:"+countLower);
        System.out.println("数字个数:"+countNumber);
        System.out.println("其他:"+countOther);
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
全部是txt格式的,容量小,以下内容为其中之一: 5.0新特性: 泛型: 泛型的形式: <E> <E extends 类型> <E extends Numner&comparator> 类名&接口,表示E继承Numner类实现comparator接口 <?> 泛型通配符表示任意类型,仅用于传参 <? extends 类型> 表示这个类型可以是该类或者该类的子类。 <? super 类型> 表示这个类型可以是该类或者该类的父类。 泛型的优点: 指定泛型后,取出数据时不需要进行强制类型转换,可以直接赋值给相应类型。 可以限定集合中的元素类型,保证集合中的元素是按照要求放入的。 可以增强多态(继承多个接口而无需写继承类)。 保证参数有效。 泛型的局限性: 不能实例化泛型 T t = new T(); //error 数组不可用泛型限定 List<String>[] list = new List<String>[10]; //错误 E[] a = new E[10]; //错误 类的静态变量不能声明为类的泛型类型 public class GenClass<T> { private static T t; //编译错误 } 静态方法可以是泛型方法(在修饰符和返回值之间写泛型),但是不可以使用类的泛型。 static void copyArrayToList(Object[] os,List<T> ls){ //错误,T为类的泛型 } static <E> void copyArrayToList(E[] os,List<E> ls){ //泛型方法,正确的 } 泛型不能使用简单类型 GenList<int> nList = new GenList<int>(); //编译错误 泛型类不能是异常类,也就是该泛型类不能继承自Throwable以及其子类 public class MyExpection<T> extends Exception{ } //编译错误 可以抛出(throws)泛型类,但catch的参数不能是泛型类。 注意: 编译时类型的泛型和运行时类型的泛型一定要一致,没有多态。 支持泛型的集合,只能存放指定的类型,或者是指定类型的子类型。 注释(元数据): 描述代码的代码,作用是规范编译器的语法。 三种内置注释: @Deprecated 所标注的程序元素是不推荐使用的 @Override 检查是否为合法的覆盖父类的方法 @SuppressWarnings 注释类或方法,忽略其中的某些类型的警告信息 注释的三种类型: 标记注释:不需要任何参数 @Override @Deprecated 单值注释:有一个值的注释 @注释名(值名=值) 值名一般为value,可以省略的,直接写值就可以 值的类型是有限制的,只能是以下几种: 8种基本数据类型 String Class Enum Annotation 以及他们的数组 多值注释:每个值之间用逗号隔开 四种元注释:java.lang.annotation中的类 元注释:注释注释的注释,用来限定注释的特征 @Terget 用来限定某个注释的使用范围,可以对什么元素进行注释 @Retention 用来描述注释的有效范围 @Inherited 用来描述某注释是否有继承性 @Documented 用来限定注释的信息是否能够进行文档化 自定义注释: 在自定义注释时,要用元注释来进行描述。 如: import java.lang.annotation.*; @Target({ElementType.METHOD}) @Inherited @Retention(RetentionPolicy.RUNTIME) @Documented public @interface InProgress { String author(); //定义属性 String limited(); } 解析注释:利用反射 1、Class.forName() 2、getMethod 3、判断是否有注释 4、getAnnotation 并发线程: 三个多线程包: java.util.concurrent 包含了常用的多线程工具,是新的多线程工具的主体。 java.util.concurrent.atomic 包含了不用加锁情况下就能改变值的原子变量。 java.util.concurrent.locks 包含锁定的工具。 Executor接口: 替代了Thread类,他可以创建定量的、动态的以及周期性的线程池。 ExecutorService接口: 线程池,用来存放线程来节省创建和销毁资源的消耗。 Callable和Future接口: Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其它线程执行的任务。Callable和Runnable有几点不同: Callable规定的方法是call(),而Runnable规定的方法是run(). Callable的任务执行后可返回值,而Runnable的任务是不能返回值的。 call()方法可抛出异常,而run()方法是不能抛出异常的。 运行Callable任务可拿到一个Future对象,通过Future对象可了解任务执行情况,可取消任务的执行,还可获取任务执行的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值