• java 字符串


    作业一:请运行以下实例代码StringPool.java,查看其输出结果。如何解释这样的输出结果?从中你能总结出什么?

     

    结论:在Java中,内容相同的字串常量(“Hello”)只保存一份以节约内存,所以s0,s1,s2实际上引用的是同一个对象。
    编译器在编译s2一句时,会去掉“+”号,直接把两个字串连接起来得一个字串(“Hello”)。这种优化工作由Java编译器自动完成。
    当直接使用new关键字创建字符串对象时,虽然值一致(都是“Hello”),但仍然是两个独立的对象。

    作业二:再看……

    为什么会有上述的输出结果?从中你又能总结出什么?

    结论:给字串变量赋值意味着:两个变量(s1,s2)现在引用同一个字符串对象“a”!
    String对象的内容是只读的,使用“+”修改s1变量的值,实际上是得到了一个新的字符串对象,其内容为“ab”,它与原先s1所引用的对象”a”无关,所以,s1==s2返回false;
    代码中的“ab”字符串是一个常量,它所引用的字符串与s1所引用的“ab”对象无关。
    String.equals()方法可以比较两个字符串的内容。

    作业三:请查看String.equals()方法的实现代码,注意学习其实现方法。

    (1)程序代码:

    public class StringEquals {
           
        public static void main(String[] args) {
            
            String s1=new String("Hello");
            
            String s2=new String("Hello");
           
            System.out.println(s1==s2);
            
            System.out.println(s1.equals(s2));
            
            String s3="Hello";
            
            String s4="Hello";
              
            System.out.println(s3==s4);
            
            System.out.println(s3.equals(s4));
               
        }
    }

    运行结果截图:

    课后作业四:String类的方法可以连续调用:
    String str="abc";
    String result=str.trim().toUpperCase().concat("defg");
    请阅读JDK中String类上述方法的源码,模仿其编程方式,编写一个MyCounter类,它的方法也支持上述的“级联”调用特性,其调用示例为:
    MyCounter counter1=new MyCounter(1);
    MyCounter counter2=counter1.increase(100).decrease(2).increase(3);

    程序源代码:

    public class String1 {

        public static void main(String[] args) {
            // TODO Auto-generated method stub
            String str="abc";
            String result=str.trim().toUpperCase().concat("defg");
            System.out.println(result);
        }

    }

    程序源代码:

    class MyCounter
    {
        int data;
        public void set(int d)
        {
            data=d;
        }
        public MyCounter increase(int i)
        {
            MyCounter a=new MyCounter();
            a.data=data+i;
            return a;
        }
        public MyCounter decrease(int d)
        {
            MyCounter a=new MyCounter();
            a.data=data-d;
            return a;
        }
    }
    public class Counter {

        public static void main(String[] args) {
            // TODO Auto-generated method stub
            MyCounter counter1=new MyCounter();
            MyCounter counter2=new MyCounter();
            counter1.set(1);
            counter2=counter1.increase(100).decrease(2).increase(3);
            System.out.println(counter2.data);
        }
    }

    运行结果截图:、

    课后作业五:

    1.字符串加密

    设计思想:

      每个字符都能够转化为整数型,也能将整数型转化为字符类型,这样我们在加密时候由于向后推3个,所以可以将字符转换为整形,然后加3,之后在将运算完的变量转化为字符后输出,就可以实现字符串加密。

    程序流程图:

      输入字符串-》将字符串分解为字符-》字符转换为整形-》整形加3-》转化为字符-》输出。

    源代码:

    import java.util.Scanner;

    public class miwen {

        

    public static void main(String args[])

        {

    char temp;

    int b ;

         System.out.println("Please input string : ");

         Scanner scanner = new Scanner(System.in);

         String a = scanner.next();

         int n=a.length();

         for(int i=0;i<n;i++)

         {if(a.charAt(i)<'x')

         {temp=a.charAt(i);

         b=(int)temp;

         b=b+3;}

         else

         {temp=a.charAt(i);

         b=(int)temp;

         b=b-23;}

            temp =(char) b;

            System.out.println(temp);

          

         }

    }

    }

     

    2.String.equals()方法

    “==”判断的是两个对象是否一致,即内容和地址,而equals()只比较内容;比如判断s1和s2的内容格式s1.equals(s2);

    3.整理String类的Length()、charAt()、 getChars()、replace()、 toUpperCase()、 toLowerCase()、trim()、toCharArray()使用说明

    Length()用来求字符串的长度,返回值为字符串的长度。

    charAt()取该字符串某个位置的字符,从0开始,为char类型

    getChars()将这个字符串中的字符复制到目标字符数组

    replace()将原string 中的元素或子串替换。返回替换后的string

    toUpperCase()将字符串string中字符变为大写

    toLowerCase()将字符串string中字符变为小写

    trim()去除字符串的头为空格

    toCharArray()将字符串转换为字符数组

  • 相关阅读:
    HDU
    2019CCPC秦皇岛自我反省&部分题解
    图论之二分图相关内容
    图论之一般图相关内容
    2019 南昌ICPC网络赛H The Nth Item
    HDU 5486 Difference of Clustering 暴力模拟
    图论之tarjan真乃神人也,强连通分量,割点,桥,双连通他都会
    数论之二次剩余
    没有哈密瓜只有哈密顿----图论之哈密顿回路
    面试题整理:C#(二)
  • 原文地址:https://www.cnblogs.com/gong123/p/6008908.html
Copyright © 2020-2023  润新知