`
_kudy
  • 浏览: 16569 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

javase_10(String类日常操作)

 
阅读更多

 

第一:

 

package com.javami.kudy.javaapi1.StringStudy;

public class StringDemo {
    /*面试题:
     * 1.Stirng s = "abc" String s = new String("abc"); //有什么区别?
     * 2.String s = new String("abc"); 创建了几个对象 2个(池里没有)或1个(池里有了),
     * 3.String s = "a" + "b" + "c" + "d"; 创建了几个对象? 创建了1个对象
     * 4.String s1 = "a"; String s2 = "b"; String s3 = s1 + s2;  s3=="ab"?
     */
    
    public static void main(String[]args)
    {
        /*
         * 1.String池,由于字符串操作很频繁.java针对String对象提供了缓冲池
         * s1首先会在缓冲池里面看一下有没有"abc" 如果没有的.那么把对象创建的引用返回给s1
         * 当s2开始执行.会检查缓冲池里面有没有.如果有的.直接把对象的地址返回给s2 .所以是相等的.。
        String s1 = "abc";
        String s2 = "abc";
        System.out.println(s1 == s2);
        */
        
        /*
        String s1 = "abc";
        String s2 = new String(s1); 
        outcome : false
        s2在堆内存中创建了一个对象(把地址返回来~),并且在堆内存里面的缓冲池里面创建一个"abc"(这个是对象里面的一个拷贝副本)
        做java的日常维护.所以那么这两个地址一比较.就会不相等..
        */
        
        /*
        String s1 = "a"+"b"+"c";
        String s2 ="abc";
        outCome = "true";
        因为java编译器有个合并已知量的功能,在编译阶段"a"+"b"+"c" 合并为"abc"并且保存在缓冲池里面
        所以s2在检测缓冲池里面.检测到已经有了.直接把对象的引用所返回来.那么证明了s1  s2 是同一个地址/所以比较出来为true
        */
        
        /*
        String s1 = new String("abc");
        String s2 = new String("abc");
        这两个里面创建了多少个对象呢?
        解答:  首先会在堆内存中创建一个对象.在检测池里面有没有,没有也在了缓冲池里面创建了一个.做日常的维护
        s2也会在堆内存中创建一个对象.这时候检测到池里面已经有了.所以就不再创建/
        说百了也就是3个..
        一般面试简单的就直接说:2个就可以.
        */
        
        /*
         * String 是一个常量,是不能改变的量
         * 内部实现:
         * StringBuilder sb = new StringBuilder(s1);
         * sb.append(s2);
         * s3 = sb.toString(); //转换回字符串
         * 返回调用方法的都是创建一个对象的
         * 
         */
        String s1 = "a";
        String s2 = "b";
        String s3 = s1 + s2;
        System.out.println(s3=="ab"); //直接返回一个flase
        
    }

}

 

 第二:

 

package com.javami.kudy.javaapi1.StringStudy;

import java.io.UnsupportedEncodingException;

public class DecodeTest {
    
    /*
     * 解码: 用错误的码再变回来.然后用正确的编码方式就可以
     * 编码错误: 没办法,神仙也救不了
     */
    public static void main(String[]args) throws UnsupportedEncodingException
    {
        String str1 = "中国人";  //使用gb2312编码
        // 使用平台的默认字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中。
        byte[] newbyte = str1.getBytes();
        
        String str2 = new String(newbyte);
        System.out.println(str2);
        
        
        String str3 = new String(newbyte,"iso-8859-1");
        //System.out.println(str3);编码的信息出错
        newbyte = str3.getBytes("iso-8859-1");    
        String str4 = new String(newbyte);
        System.out.println(str4);
        
        byte[]new1 = str1.getBytes("iso-8859-1");
        //一开始编码的信息就出错!因为我的计算机根本就没有这个编码
        String s6 = new String(new1);
        new1 = s6.getBytes("iso-8859-1");
        String st7 = new String(new1);
        System.out.println(st7);
    }
}

 

 第三:

 

package com.javami.kudy.javaapi1.StringStudy;

public class StringTest {
    /*String 为什么要重写toString()方法呢?
        解答:因为在String如果不重写Object的toString方法.那么直接复用父类的方法.打印出的是对象.
        这显然不是String想要得到的结果
     */
        public static void main(String[]args) 
        {
            String s1 = "kudy";
            System.out.println(s1.charAt(3)); //索引是从零开始\
            String s2 ="abcde";
            String s3 = "aBcddddd";
            System.out.println(s2.compareToIgnoreCase(s3));
            
            String s4 = "abc";
            String s5 = "def";
            System.out.println((s4.concat(s5)).toString());
            
            boolean is = s4.contains(s5);
            System.out.println(is);
            
            String fileName = "Demo.jdk";
            if(fileName.endsWith(".java"))
                    System.out.println("您是java文件");
            
            String s6 = "cnabcdbvklabcjdhfabcdhla";
            int newint = s6.indexOf("abc",0);  //注意:索引是从零开始
            System.out.println(newint);
            
            String s7 = "abc";
            String s8 = new String("abc");
            s8.intern();
            System.out.println(s7 == s8);
            
            String s9 = "cascascacvdfdjkgksd";
            int num = s9.lastIndexOf("k",s9.length()-1);
            System.out.println(num);
            
            String s10 = "abc";
            String s11 = s10.replace("abc","***");
            System.out.println(s11);
            
            String s12 = "hello.java";
            String s13 = s12.replace("java","jdk" );
            System.out.println(s13);
            
            
            /*
             * 把有逗号的内容去掉。
             */
            String s14 = "ab,cd,ef";
            String [] s15 = s14.split(",");
            for(String num1 : s15)
                    System.out.print(num1);
            
            String s16 = "abcbsbdasdas";
            char[] newchar = s16.toCharArray();
            for(char num2 : newchar)
                    System.out.print(num2);
            System.out.println();
            
            /*
             * 但注意中间的是不能去掉的~~
             */
            String s17 = "   abc      def     ";
            String s18 = s17.trim();
            System.out.println(s18);
        }
}

 

 第四:

 

package com.javami.kudy.javaapi1.StringStudy;
 
 import java.io.IOException;
 
 public class StringUtil {
     private StringUtil(){} //私有化
     
     /* 查找子字符串在字符串中出现的位置 例:“ab”在"habjklabljhlabhjdjfla"出现的位置为:1 6  12 
      * 思路:
      * 1.定义一个StringBuilder容器,用于存储位置,定义一个pos变量记住出现的位置,初始值为0
      * 2.定义一个while循环,查找子串出现的位置
      * 3.调用indexOf方法,从起始位置开始查找出子串首次出现的位置
      * 4.如果pos为-1,说明没找到,应该结束循环
      * 5.将位置存入StringBuilder容器,再加一个逗号分隔
      * 6.从找到的位置加上子串的长度作为新的起始位置,
      * 7.循环结束,将StringBuffer转为String字符串,调用split方法以逗号进行分隔,获得了String数组
      * 8.准备一个新的int数组,长度和String数组一样,遍历String数组,将每个元素转为int存入int数组
      */
     public static int[]findIndexOfSubstr(String str, String substr)
     {
         StringBuilder sb = new StringBuilder();
         int pos = 0;
         while(true)
         {
              pos = str.indexOf(substr,pos);
              if(pos ==-1)
                  break;
              sb.append(pos+",");
              pos+=substr.length(); //pos假设找ab 找到1 + 2 等于三.刚好从第三个开始找~
         }
         if(sb.length() == 0) //容器什么都没有!
             return null;  //一个都找不到
         String s = sb.toString(); //转换成字符串形式
         String[] parts = s.split(",");
         int[] arr = new int[parts.length];
         for(int i=0; i<parts.length; i++)
         {
             arr[i] = Integer.parseInt(parts[i]);
         }
         return arr;
     }
     
     /*
      * 设计一个方法,读取键盘输入的一行(只支持英文字母)
      * 提示:System.in.read()读取键盘上的一个字符
      * 思路: 
      * 1.定义一个容器StringBuilder容器
      * 2.定义一个while循环,循环读取键盘.
      * 3.如果读到回车或者\n 就跳出循环
      * 4.存入StringBuilfer容器中
      * 5.循环结束,返回一个toString转换为字符串
      */
         public static String readLine() throws IOException
         {
             StringBuilder sb = new StringBuilder();
             while(true)
             {
                 int ch = System.in.read();
                 if(ch == '\r')  //如果回车 跳出去
                     continue;
                 if(ch == '\n')  //等上面的执行完毕.再来
                     break;
                 sb.append((char)ch);
             }
             return sb.toString(); //转换成字符串
         }
         
         /*
          * *将给定的字节数组截取一部分,进行解码,要求输出完整的汉字,例如:"abc中国人"截取6个 输出的是abc中
          * 思路:
          *     1.遍历数组被截取的部分,
          * 2.判断正负数,统计负数个数为count
          * 3.判断count的奇偶,奇数减去1,偶数不变
          * 4.解码
          * 汉字是占了2个字节?我们怎么判断它是汉字呢?
          * 汉字的第一位字节保证是负数!第二个是正数
          * 
          */
         public static String decode(byte[]buf, int len)
         {
             int count = 0;
             for(int i=0; i<buf.length;i++)
                 if(buf[i]<0)
                         count++; //如果第一个字节是负数的.是代表汉字马上来到.咱们+1
             if(count % 2 == 1)
                 len--;
             return new String(buf,0,len);
             /*程序流程图: 咱们输入一个buf   len = 5
              * for 执行5次
              * 因为一个汉字是占了2个字节.而第一个字节保证是负数
              * 如果 buf[i]里面的是负数的 count +1 = 1
              * 如果   % 2  等于1代表的是:   咱们len 传递进来的就减去一个字节.
              * 
              */
         }
         
         public static String decodeBYGBK(byte[]buf,int len)
         {
             boolean b = false; 
             for(int i=0; i<buf.length; i++)
                 if(b)
                     b = false;
                 else if(buf[i]<0)
                     b = true;
             if(b)
                 len --;
             return new String(buf,0,len);
             
         }
         
         /*
          * 查找一个字符串出现次数最多的字符     abvjdabahabballfja   出现次数最多的为:a  6
          * 思路:
          * 1.调用toCharArray字符串把字符串转换成字符数组
          * 2.定义max,用于记住出现最多字符的次数,定义一个maxChar记住出现最多的字符
          * 3.定义一个循环,每次循环都统计一个字符出现最多的次数,每次让次数和max比.谁最大就换,结束条件。当长度的数组
          * 为零
          * 4.定义一个count,记住本次统计字符的次数
          * 5.循环遍历数组,统计第一个字符出现的次数
          * 6.让次数和max比,如果max大,让max记住它的次数,让maxchar记住当前的字符
          * 7.将当前的字符从数组中删除
          * ------
          * 将此字符串转换为一个新的字符数组。
          */
 
         public static char searchMaxChar(String str)
         {
             char[] buf = str.toCharArray();
             int max = 0;
             char maxChar = 0;
             while(buf.length>0)
             {
                 int count = 0; //个数等于0
                 char firstChar = buf[0];
                 for(char c : buf)
                     if(c ==firstChar)
                         count++;
                 if(count>max) //max 已经是默认记住上一个的值!
                 {
                     max = count;
                     maxChar = firstChar; //如果你是最多的就让给你~~
                 }
                 //把当前的字符删除!
                 buf = deleteChar(buf,firstChar,count);
             }
             return maxChar;
         }
 
         private static char[] deleteChar(char[] buf, char firstChar, int count)
         {
             char[]arr = new char[buf.length-count];
             int pos = 0;
             for(int i=0; i<buf.length; i++)
             {
                 if(buf[i]==firstChar)
                         continue;
                 arr[pos++] = buf[i];
             }
             return arr;
         }
         /* 查找两个字符串中的最大子串  jflwertyakjfa;l    fjdlkwertyjf;ajf 最大子串:werty
          * 1.判断出两个字符串的长短,找出较长的和较短的
          * 2.循环遍历较短的字符串的所有子串,由长到短遍历
          *         定义一个循环,每次遍历一种长度的子串,将i作为长度,i的取值: length~1
          *         定义一个内层循环,具体遍历某一种长度的子串,j做为子串的开始位置, j取值:0~length-i
          *         截取子串,substring  起始位置:j  结束位置:j+i
          * 3.每次变量,都判断子串是否为较长的字符串的子串,如果是,直接返回
          * 4.循环结束,依然没有返回,说明没有相同子串,返回null
          */
         public static String searchMaxSubStr(String s1, String s2) 
         {
             String longStr = s1.length() > s2.length() ? s1 : s2;
             String shortStr = s1.length() > s2.length() ? s2 : s1; 
             for(int i=shortStr.length(); i>0; i--)
             {
                 for(int j=0;j<shortStr.length()-i+1;j++)
                 {
                     String sub = shortStr.substring(j, j+i); //例如: abcd 放到sub里面去
                     //abcd abc ab  a 和它里面的做一个对比  
                     //当且仅当此字符串包含指定的 char 值序列时,返回 true。 
                     if(longStr.contains(sub)) 
                         //判断长的字符串里面是否包含这个
                         return sub; //如果包含直接返回.没有包含
                 }
             }
             return null;
         }
 }
 
 
 ----------------------
 
 package com.javami.kudy.javaapi1.StringStudy;
 
 public class StringUtilTest {
         public static void main(String[]args) throws Exception
         {
             /*
             String str = "dsdcvcvxvczxbedfaacff";
             String substr = "y";
             //遍历a 出现的位置
             int[]arr =  StringUtil.findIndexOfSubstr(str, substr);
             if(arr ==null)
             {
                 System.out.println("找不到!");
                 return ;
             }
             for(int num : arr)
             {
                     System.out.print(num+" ");
             }
             System.out.println();
             
             */
             /*
              * 再输入byte的时候就结束,不断的去读
 
             while(true)
             {
                 String str2 = StringUtil.readLine();
                 if("bye".equals(str2))
                     break;
                 System.out.println(str2);
             }
             System.out.println("程序结束");    
             */
             byte[] buf = "abc中国人".getBytes();
             //String s3 = StringUtil.decode(buf, 3);
             String s3 = StringUtil.decodeBYGBK(buf, 5);
             System.out.println(s3);
             
             char maxChar = StringUtil.searchMaxChar("dasfasdfaaaaaaaasfgdagfafgsad");
             System.out.println(maxChar);
             
             String s33 = "jflwertyakjfa;l";
             String s44 = "fjdlkwertyjf;ajf";
             String s55 =StringUtil.searchMaxSubStr(s33,s44);
             System.out.print(s55);
         }
 
 }
 

 

 

分享到:
评论

相关推荐

    JavaSE25套习题(含答案)

    4. **字符串处理**:String类在Java中是不可变的,了解其常用方法如concat,substring,indexOf,replace等对于日常编程至关重要。 5. **异常处理**:Java中的异常处理机制是通过try-catch-finally语句实现的,能...

    JavaSE基础入门视频教程33天之(15) part2

    在Java中,String类是一个非常重要的核心类,因为它在日常编程中无处不在,用于处理文本数据。本教程的几个部分深入讲解了String类的相关知识: 1. **day15_06(常用API)String类的概念和不变性**:这部分内容可能...

    百战程序员答案javase基础部分

    7. **第7章_常用类**:介绍了Java标准库中的常用类,如Math类、String类、Date类,以及各种集合类的基本操作,这些类在日常开发中极为常见。 8. **第8章_容器_集合框架**:详细讲解了集合框架,包括List、Set、Map...

    JavaSE基础学习资料文档

    第09章《java常用类》介绍了Java标准库中的常用类,如String、Date、File等,这些都是日常编程中经常用到的工具类,了解它们的功能和使用方法对于提高代码效率至关重要。 最后,第10章《泛型和集合(1)》讲解了...

    Java学习资料 JavaSE学习练习代码

    7. **字符串处理**:String类在Java中扮演着重要角色,学习如何创建、修改和比较字符串,以及使用正则表达式进行文本匹配是日常编程中常见的任务。 8. **反射和注解**:反射允许程序在运行时动态地获取类的信息并...

    javase基础编程demo

    例如,`String`类用于处理文本字符串,`ArrayList`和`HashMap`是Java集合框架中的重要成员,分别代表动态数组和键值对存储。`Date`和`Calendar`类用于处理时间和日期,而`File`类则用来操作文件和目录。理解并熟练...

    javase30天基础总结

    4. **字符串**:Java中的String类是不可变的,理解其特点和常用方法,如concat,substring,indexOf,replace等,对于日常编程至关重要。 5. **异常处理**:Java通过try-catch-finally结构进行异常处理,学习如何...

    JavaSE7 API 帮助文档

    JavaSE7(Java Standard Edition 7)是Java编程语言的一个重要版本,它的API(Application Programming Interface)帮助文档是开发者日常编程的重要参考资料。这份文档详细解释了Java 7中所有类库、接口、方法和异常...

    day01_Object类、常用API每日作业卷答案1

    在JavaSE的学习过程中,理解并熟练运用`Object`类的方法是基础技能之一。 一、`equals()`方法 `equals()`方法在`Object`类中用于比较两个对象的引用是否指向内存中的同一块存储空间,即判断它们是否是同一个对象。...

    面试汇总包含了javase前端基础数据库.pdf

    - **重写**:某些类如`String`、`Integer`等,为了更加实用地比较对象的值,会重写`equals`方法,使得它可以比较两个对象的值是否相等。 **示例**: ```java String x = "string"; String y = "string"; String z ...

    Java核心知识总结-笔记

    JavaSE高级部分的讲解涵盖了重要的String类、集合以及IO流。String类在Java中扮演着至关重要的角色,因为它是最常用的数据类型之一,用于存储和处理文本信息。以下是对String类的详细分析: 1. **String的底层实现*...

    Java SE编程入门教程 String字符串(共27页).pptx

    - 使用`+`操作符可以连接两个字符串,例如`String s = "Hello, " + "World!";`。 6. **字符串常量池**: - 当创建字符串时,如果字符串常量池中已经存在相同的字符串,那么Java会复用这个字符串,不会创建新对象...

    JavaSE 字符串的总结

    JavaSE中的字符串是编程中非常基础且重要的概念,主要用于存储和操作文本数据。字符串在Java中是不可变的,这意味着一旦创建了一个字符串对象,就不能更改它的内容。它们被表示为`String`类型,并且属于核心库`java....

    浅谈javaSE 面向对象(Object类toString)

    `Object`类是所有Java类的根类,它提供了若干基本的方法,包括`toString()`、`hashCode()`和`getClass()`,这些方法在日常开发中经常被使用。 `toString()`方法是`Object`类的一个成员,它的主要功能是返回对象的...

    Java面试宝典Beta5.0.pdf

    5. String类是不可变的,因此不能被继承,但可以被其他类作为成员变量。 6. Java中的方法参数传递都是值传递,即传递参数的副本。基本数据类型传递值本身,引用数据类型传递引用的副本,但副本指向同一对象。 三、...

    狂神说Java笔记资料

    6. **常用类**:Java标准库提供了大量内置类,这部分会讲解一些常用类的使用,如Math类、String类、Date类等,它们在日常开发中极其常见。 7. **异常机制**:Java的异常处理机制使得程序更加健壮。学习者将了解到...

    java日常总结(面试 技术总结 SCJP考试)

    5. **字符串处理**:了解String类的特性,如不可变性、字符串连接效率等。 6. **反射与注解**:理解反射机制在动态加载类、调用方法等方面的应用,以及注解的用途。 7. **泛型**:理解泛型的概念,知道如何在类、...

    Notepad.rar

    标题 "Notepad.rar" 暗示我们正在讨论一个基于JavaSe实现的简易记事本程序,这个程序可能被设计成一个独立的应用,用于日常文本编辑。描述中提到的功能包括创建新文档、查找文本、复制内容以及保存文件,这些都是一...

    java基础测试

    最后,对于JavaSE的标准库,如Math类、String类和日期时间API(Calendar、Date、LocalDateTime等),也需要有深入的理解,因为它们在日常编码中经常被用到。 总的来说,“java基础测试”资源覆盖了广泛的Java基础...

    【黑马面试宝典】虐面试官神器之必备黑马程序员面试宝典V2.51

    String不能被继承,因为它的final修饰符表明它是最终类。Java中的字符串常量池优化了字符串的使用,提高了效率。 这些知识点的深入理解和掌握对于Java程序员来说至关重要,无论是在日常开发还是面试中,都能体现出...

Global site tag (gtag.js) - Google Analytics