java 暗黑字符串_Java第5次

1.

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

4f3605dfa4f9703403a772a489e2d5e8.png

显示结果:

true

true

false

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

1.

5e6d1095640d98680f2a590fd98219f0.png

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

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

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

public boolean equals(Object anObject) {

if (this == anObject) {

return true;

}

if (anObject instanceof String) {

String anotherString = (String)anObject;

int n = count;

if (n == anotherString.count) {

char v1[] = value;

char v2[] = anotherString.value;

int i = offset;

int j = anotherString.offset;

while (n-- != 0) {

if (v1[i++] != v2[j++])

return false;

}

return true;

}

}

return false;

}

4.

请阅读JDK中String类上述方法的源码,模仿其编程方式,编写一个MyCounter类,它的方法也支持上述的“级联”调用特性,其调用示例为: MyCounter counter1=new MyCounter(1); MyCounter counter2=counter1.increase(100).decrease(2).increase(3);

package dijia;

public class MyCounter {

int a,increase,decrease;

MyCounter(int b)

{

a=b;

}

public final MyCounter increase(int i)

{

increase = a + i;

return this;

}

public final MyCounter decrease(int i)

{

decrease = a - i;

return this;

}

public static void main(String[] args) {

MyCounter a1=new MyCounter(1);

MyCounter a2=a1.increase(100).decrease(2).increase(3);

System.out.println("a2.a是:"+a2.a+"\na2.increase是:"+a2.increase+"\na2.decrease是:"+a2.decrease);

}

}

5.请编写一个程序,使用上述算法加密或解密用户输入的英文字串要求设计思想、程序流程图、源代码、结果截图。

<1>设计思想:先让操作者输入一个字符串,将字符串转变为字符数组,将字符转化为数字,相应的加减,再将数字转化为字符,输出。

<2>程序流程图:

63bac71eba57ea1d858a0ae19fc58532.png

<3>源代码:

package dijia;

import javax.swing.*;

import java.util.Scanner;

public class Jiami {

public static void main(String[] args) {

System.out.println("请输入一串字符:");

Scanner scanner =new Scanner(System.in);

String a=scanner.next();

a.trim();

char b[]=a.toCharArray();

int i;

for(i=0;i

{

int c;

c = (byte )b[i];

if(b[i]!='z'&&b[i]!='y'&&b[i]!='x')

{

c+=3;

b[i]=(char) c;

}

}

for(i=0;i

{

System.out.print(b[i]);

}

}

}

<4>截图:

e2b51a2444ad6b80ac6553813f4e0420.png

6.整理String类的Length()、charAt()、 getChars()、replace()、 toUpperCase()、 toLowerCase()、trim()、toCharArray()使用说明、阅读笔记

(1)

定义和构造初始化

string 提供了很多构造函数,可以以多种方式来初始化string字符串

(2)

赋值,拼接字符串

string重载了 =  +   +=  等多种运算符,让字符串组合拼接更简单

(3)

访问字符操作

string可以按数组方式,以下标来访问。还可以用at()函数访问指定的字符。

可以使用 STL 的接口

可以把 string 理解为一个特殊的容器,容器中装的是字符

(4)

比较操作 ==  !=  >  >=  <  <=  compare 等

string的比较操作,按字符在字典中的顺序进行逐一比较。在字典前面的字符小于后面的字符。

(5)

查找 find  rfind

string中除了find、rfind,还有find_first_of等函数也提供了强大的查找功能

(6)

除了string中的find函数外,char[]数组也有强大的查找函数

C++中有strstr、strchr等也有查找功能。函数说明如下

char *strstr( const char *str, const char *substr );  返回指针,指向substr在字符串str中首次出现的位置。

char *strchr( const char *str, int ch );  返回指针,指向 str 中字符ch 首次出现的位置。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值