how2j.cn


本视频是解读性视频,所以希望您已经看过了本知识点的内容,并且编写了相应的代码之后,带着疑问来观看,这样收获才多。 不建议一开始就观看视频



5分14秒
本视频采用html5方式播放,如无法正常播放,请将浏览器升级至最新版本,推荐火狐,chrome,360浏览器 如果装有迅雷,播放视频呈现直接下载状态,请调整 迅雷系统设置-基本设置-启动-监视全部浏览器 (去掉这个选项)



示例 1 : 是否是同一个对象   
示例 2 : 是否是同一个对象-特例   
示例 3 : 内容是否相同   
示例 4 : 是否以子字符串开始或者结束   
示例 5 : 练习-比较字符串   
示例 6 : 答案-比较字符串   

示例 1 :

是否是同一个对象

str1和str2的内容一定是一样的!
但是,并不是同一个字符串对象
package character; public class TestString { public static void main(String[] args) { String str1 = "the light"; String str2 = new String(str1); //==用于判断是否是同一个字符串对象 System.out.println( str1 == str2); } }
package character;

public class TestString {

	public static void main(String[] args) {

		String str1 = "the light";
		
		String str2 = new String(str1);
		
		//==用于判断是否是同一个字符串对象
		System.out.println( str1  ==  str2);
		
	}

}
示例 2 :

是否是同一个对象-特例


str1 = "the light";
str3 = "the light";

一般说来,编译器每碰到一个字符串的字面值,就会创建一个新的对象
所以在第6行会创建了一个新的字符串"the light"
但是在第7行,编译器发现已经存在现成的"the light",那么就直接拿来使用,而没有进行重复创建
package character; public class TestString { public static void main(String[] args) { String str1 = "the light"; String str3 = "the light"; System.out.println( str1 == str3); } }
package character;

public class TestString {

	public static void main(String[] args) {
		String str1 = "the light";
		String str3 = "the light";
		System.out.println( str1  ==  str3);
	}

}
示例 3 :

内容是否相同

使用equals进行字符串内容的比较,必须大小写一致
equalsIgnoreCase,忽略大小写判断内容是否一致
package character; public class TestString { public static void main(String[] args) { String str1 = "the light"; String str2 = new String(str1); String str3 = str1.toUpperCase(); //==用于判断是否是同一个字符串对象 System.out.println( str1 == str2); System.out.println(str1.equals(str2));//完全一样返回true System.out.println(str1.equals(str3));//大小写不一样,返回false System.out.println(str1.equalsIgnoreCase(str3));//忽略大小写的比较,返回true } }
示例 4 :

是否以子字符串开始或者结束


startsWith //以...开始
endsWith //以...结束
package character; public class TestString { public static void main(String[] args) { String str1 = "the light"; String start = "the"; String end = "Ight"; System.out.println(str1.startsWith(start));//以...开始 System.out.println(str1.endsWith(end));//以...结束 } }
package character;
 
public class TestString {
 
    public static void main(String[] args) {
        String str1 = "the light";
        
        String start = "the";
        String end = "Ight";
        
        System.out.println(str1.startsWith(start));//以...开始
        System.out.println(str1.endsWith(end));//以...结束
         
    }
 
}
示例 5 :

练习-比较字符串

Or  姿势不对,事倍功半! 点击查看做练习的正确姿势
创建一个长度是100的字符串数组
使用长度是2的随机字符填充该字符串数组
统计这个字符串数组里重复的字符串有多少种
练习-比较字符串
示例 6 :

答案-比较字符串

在查看答案前,尽量先自己完成,碰到问题再来查看答案,收获会更多
本视频是解读性视频,所以希望您已经看过了本答案的内容,带着疑问来观看,这样收获才多。 不建议一开始就观看视频

16分54秒 本视频采用html5方式播放,如无法正常播放,请将浏览器升级至最新版本,推荐火狐,chrome,360浏览器 如果装有迅雷,播放视频呈现直接下载状态,请调整 迅雷系统设置-基本设置-启动-监视全部浏览器 (去掉这个选项)


package character; public class TestString { public static void main(String[] args) { String[] ss = new String[100]; // 初始化 for (int i = 0; i < ss.length; i++) { ss[i] = randomString(2); } // 打印 for (int i = 0; i < ss.length; i++) { System.out.print(ss[i] + " "); if (19 == i % 20) System.out.println(); } for (String s1 : ss) { int repeat = 0; for (String s2 : ss) { if (s1.equalsIgnoreCase(s2)) { repeat++; if (2 == repeat) { // 当repeat==2的时候,就找打了一个非己的重复字符串 putIntoDuplicatedArray(s1); break; } } } } System.out.printf("总共有 %d种重复的字符串%n", pos); if (pos != 0) { System.out.println("分别是:"); for (int i = 0; i < pos; i++) { System.out.print(foundDuplicated[i] + " "); } } } static String[] foundDuplicated = new String[100]; static int pos; private static void putIntoDuplicatedArray(String s) { for (int i = 0; i < pos; i++){ if (foundDuplicated[i].equalsIgnoreCase(s)) return; } foundDuplicated[pos++] = s; } private static String randomString(int length) { String pool = ""; for (short i = '0'; i <= '9'; i++) { pool += (char) i; } for (short i = 'a'; i <= 'z'; i++) { pool += (char) i; } for (short i = 'A'; i <= 'Z'; i++) { pool += (char) i; } char cs[] = new char[length]; for (int i = 0; i < cs.length; i++) { int index = (int) (Math.random() * pool.length()); cs[i] = pool.charAt(index); } String result = new String(cs); return result; } }


HOW2J公众号,关注后实时获知布最新的教程和优惠活动,谢谢。


问答区域    
2018-01-22 代码优化
fab



感觉还是有点问题啊,哪位大神给我看看?
package practice;

public class StringCompare {
	public static void main(String[] args) {
		String str2[]=new String[100];
		char c[]=new char[2];
		int x='0';
		int y='z';
		for(int i=0;i<str2.length;i++) {
			for(int j=0;j<c.length;j++) {
				while(true) {
					char ch=(char)(Math.random()*(y-x)+x);
					if(Character.isDigit(ch)||Character.isLetter(ch)) {
						c[j]=ch;
						break;
					}
				}
			}
			str2[i]=new String(c);
		}
			for(int k=0;k<20;k++) {
				System.out.print(str2[k]+" ");
			}
			System.out.println(" ");
			for(int k=20;k<40;k++) {
				System.out.print(str2[k]+" ");
			}
			System.out.println(" ");
			for(int k=40;k<60;k++) {
				System.out.print(str2[k]+" ");
			}
			System.out.println(" ");
			for(int k=60;k<80;k++) {
				System.out.print(str2[k]+" ");
			}
			System.out.println(" ");
			for(int k=80;k<100;k++) {
				System.out.print(str2[k]+" ");
			}
			System.out.println(" ");
		for(int i=0;i<str2.length;i++) {
			for(int j=i+1;j<str2.length;j++) {
				if(str2[i].equalsIgnoreCase(str2[j])) {
					System.out.print(str2[i]+" ");
				}
			}
		}
	}

}

							






答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2018-01-22 代码优化
fab



我这个代码感觉还是有问题,谁给我优化一下
package practice;

public class StringCompare {
	public static void main(String[] args) {
		String str2[]=new String[100];
		char c[]=new char[2];
		int x='0';
		int y='z';
		for(int i=0;i<str2.length;i++) {
			for(int j=0;j<c.length;j++) {
				while(true) {
					char ch=(char)(Math.random()*(y-x)+x);
					if(Character.isDigit(ch)||Character.isLetter(ch)) {
						c[j]=ch;
						break;
					}
				}
			}
			str2[i]=new String(c);
		}
			for(int k=0;k<20;k++) {
				System.out.print(str2[k]+" ");
			}
			System.out.println(" ");
			for(int k=20;k<40;k++) {
				System.out.print(str2[k]+" ");
			}
			System.out.println(" ");
			for(int k=40;k<60;k++) {
				System.out.print(str2[k]+" ");
			}
			System.out.println(" ");
			for(int k=60;k<80;k++) {
				System.out.print(str2[k]+" ");
			}
			System.out.println(" ");
			for(int k=80;k<100;k++) {
				System.out.print(str2[k]+" ");
			}
			System.out.println(" ");
		for(int i=0;i<str2.length;i++) {
			for(int j=i+1;j<str2.length;j++) {
				if(str2[i].equalsIgnoreCase(str2[j])) {
					System.out.print(str2[i]+" ");
				}
			}
		}
	}

}

							






答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2017-11-26 小试牛刀
2017-11-26 查重复的代码不知道怎么优化啊
2017-11-26 查找重复的算法不知道能不能优化写
2017-11-18 最后一个题的问题
2017-10-25 发一个最后一题的简单实现
2017-08-31 我的代码
2017-07-29 练习答案
2017-07-16 作业
2017-06-15 思路比较清晰,代码还算简单
2017-04-24 一起吃屎,一起喝尿!!!!
2017-04-14 为什么不用Map呢?会容易些
2017-04-07 我写的这样不知道如何,可能复杂度太高
2017-04-01 好像我的字符串数组没有重复
2017-03-29
2017-01-25 不看答案真的写不出来。。。对着答案还研究了半天
2016-06-07 希望能注释进一步讲解43行到52行代码作用。




提问之前请登陆
关于 JAVA 基础-数字与字符串-比较字符串 的提问

尽量提供截图代码异常信息,有助于分析和解决问题。 也可进本站QQ群交流: 389538688
站长会在每个工作日早上尽量回答提问(如果有漏掉没有回答的,请进群提醒一下)
提问尽量提供完整的代码,环境描述,越是有利于问题的重现,您的问题越能更快得到解答。
对教程中代码有疑问,请提供是哪个步骤,哪一行有疑问,这样便于快速定位问题,提高问题得到解答的速度
站长是玻璃心,提问的时候请语气温柔些 kiss~
截止2017-5-19日累计提问 1638个,站长回答了 1546个
截止2017-8-15日累计提问 2788个,站长回答了 2544个

上传截图