(一)、字符串加密
设计思想:加密字符串时,将用户输入的字符串转换成字符数组,分别加三,最后将它们相加得到新的字符串,进行输出。解密亦然。
程序流程图:
源代码:
//余尉兴 字符串加密 20151020import javax.swing.*;public class Secret { public static void main(String[] args){ String s=JOptionPane.showInputDialog("加密按1\n解密按2");//用户决定加密解密 if(s.equals("1")) { String s1=JOptionPane.showInputDialog("请输入需要加密的密码"); String s3=""; char[] s2=s1.toCharArray();//转换为字符数组 for(int i=0;i'Z')//如果超过Z对应的数值则减去26 { s2[i]=(char) (s2[i]-26); } s3=s3+s2[i];//转换成字符串 } JOptionPane.showMessageDialog(null,s3); } else if(s.equals("2")) { String s1=JOptionPane.showInputDialog("请输入需要解密的密码"); String s3=""; char[] s2=s1.toCharArray();//转换为字符数组 for(int i=0;i
运行结果:
加密结果:
解密结果:
(二)、方法整理
equal()的源代码:
public boolean equals(Object anObject){ //如果是同一个对象 if (this == anObject) { return true; } //如果传递进来的参数是String类的实例 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;}
length():
public int length()
- 返回此字符串的长度。长度等于字符串中 的数量。
-
- 指定者:
- 接口
中的
- 接口
-
- 返回:
- 此对象表示的字符序列的长度。
charAt():
public char charAt(int index)
- 返回指定索引处的
char
值。索引范围为从0
到length() - 1
。序列的第一个char
值位于索引0
处,第二个位于索引1
处,依此类推,这类似于数组索引。如果索引指定的
char
值是,则返回代理项值。 -
- 指定者:
- 接口
中的
- 接口
-
- 参数:
-
index
-char
值的索引。 返回: - 此字符串指定索引处的
char
值。第一个char
值位于索引0
处。 抛出: -
- 如果
index
参数为负或小于此字符串的长度
-
getChars():
public void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)
- 将字符从此字符串复制到目标字符数组。
要复制的第一个字符位于索引
srcBegin
处;要复制的最后一个字符位于索引srcEnd-1
处(因此要复制的字符总数是srcEnd-srcBegin
)。要复制到dst
子数组的字符从索引dstBegin
处开始,并结束于索引:dstbegin + (srcEnd-srcBegin) - 1
-
- 参数:
-
srcBegin
- 字符串中要复制的第一个字符的索引。 -
srcEnd
- 字符串中要复制的最后一个字符之后的索引。 -
dst
- 目标数组。 -
dstBegin
- 目标数组中的起始偏移量。 抛出: -
- 如果下列任何一项为 true:
srcBegin
为负。srcBegin
大于srcEnd
srcEnd
大于此字符串的长度dstBegin
为负dstBegin+(srcEnd-srcBegin)
大于dst.length
-
replace():
public replace(char oldChar, char newChar)
- 返回一个新的字符串,它是通过用
newChar
替换此字符串中出现的所有oldChar
得到的。如果
oldChar
在此String
对象表示的字符序列中没有出现,则返回对此String
对象的引用。否则,创建一个新的String
对象,它所表示的字符序列除了所有的oldChar
都被替换为newChar
之外,与此String
对象表示的字符序列相同。示例:
"mesquite in your cellar".replace('e', 'o') returns "mosquito in your collar" "the war of baronets".replace('r', 'y') returns "the way of bayonets" "sparring with a purple porpoise".replace('p', 't') returns "starring with a turtle tortoise" "JonL".replace('q', 'x') returns "JonL" (no change)
-
- 参数:
-
oldChar
- 原字符。 -
newChar
- 新字符。 返回: - 一个从此字符串派生的字符串,它将此字符串中的所有
oldChar
替代为newChar
。
-
toUpperCase():、
public toUpperCase()
- 使用默认语言环境的规则将此
String
中的所有字符都转换为大写。此方法等效于toUpperCase(Locale.getDefault())
。注: 此方法与语言环境有关,如果用于应独立于语言环境解释的字符串,则可能生成不可预料的结果。示例有编程语言标识符、协议键、HTML 标记。例如,
"title".toUpperCase()
在 Turkish(土耳其语)语言环境中返回"T?TLE"
,其中“?”是 LATIN CAPITAL LETTER I WITH DOT ABOVE 字符。对于与语言环境有关的字符,要获得正确的结果,请使用toUpperCase(Locale.ENGLISH)
。 -
- 返回:
- 要转换为大写的
String
。 另请参见:
- 要转换为大写的
toLowerCase():
public toLowerCase()
- 使用默认语言环境的规则将此
String
中的所有字符都转换为小写。这等效于调用toLowerCase(Locale.getDefault())
。注: 此方法与语言环境有关,如果用于应独立于语言环境解释的字符串,则可能生成不可预料的结果。示例有编程语言标识符、协议键、HTML 标记。例如,
"TITLE".toLowerCase()
在 Turkish(土耳其语)语言环境中返回"t?tle"
,其中“?”是 LATIN SMALL LETTER DOTLESS I 字符。对于与语言环境有关的字符,要获得正确的结果,请使用toLowerCase(Locale.ENGLISH)
。 -
- 返回:
- 要转换为小写的
String
。 另请参见:
- 要转换为小写的
trim()
public trim()
- 返回字符串的副本,忽略前导空白和尾部空白。
如果此
String
对象表示一个空字符序列,或者此String
对象表示的字符序列的第一个和最后一个字符的代码都大于'\u0020'
(空格字符),则返回对此String
对象的引用。否则,若字符串中没有代码大于
'\u0020'
的字符,则创建并返回一个表示空字符串的新String
对象。否则,假定 k 为字符串中代码大于
'\u0020'
的第一个字符的索引,m 为字符串中代码大于'\u0020'
的最后一个字符的索引。创建一个新的String
对象,它表示此字符串中从索引 k 处的字符开始,到索引 m 处的字符结束的子字符串,即this.substring(k, m+1)
的结果。此方法可用于截去字符串开头和末尾的空白(如上所述)。
-
- 返回:
- 此字符串移除了前导和尾部空白的副本;如果没有前导和尾部空白,则返回此字符串。
toCharArray():
public char[] toCharArray()
- 将此字符串转换为一个新的字符数组。
-
- 返回:
- 一个新分配的字符数组,它的长度是此字符串的长度,它的内容被初始化为包含此字符串表示的字符序列。