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-04-22 作业
暄染



感觉还能再精简(懒
package charactor;

public class TestChar {
	
	public static String getstring() {
        
        char[] cs1 = new char[2];
        short start = '0';
        short end = 'z'+1;
        for (int i = 0; i < cs1.length; i++) {
            while(true) {
                char c = (char)(Math.random()*(end-start)+start);
                if (Character.isDigit(c) || Character.isLetter(c)) {
                    cs1[i] = c;
                    break;
                }
            }
        }
        String result = new String(cs1);
        return result;
    }
		
	public static void main(String[] args) {
		
		int count = 0;
		String str1[] = new String[100];
		for (int i = 0; i < str1.length; i++ ) {
			str1[i] = getstring();
		}
		for (int i = 0; i < 5; i++) {
			for (int j = 0; j < 20; j++) {
				System.out.print(str1[i*10+j]+" ");
			}
			System.out.printf("\r\n");
		}
		for (int i = 0; i < 100; i++) {
			for (int j = i+1; j < 100; j++) {
				if (str1[i].equals(str1[j])) {
					count++;
				}
			}
		}
		System.out.printf("总共有%d种重复的字符串%n分别是:%n",count);
		for (int i = 0; i < 100; i++) {
			for (int j = i+1; j < 100; j++) {
				if (str1[i].equals(str1[j])) {
					System.out.printf(str1[i]+" ");
				}
			}
		}	
	}
}

							






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





2018-04-20 统计字符串数组中相同元素出现的次数
啊哈大菠萝
请问一下怎么统计重复字符串出现的个数呢?








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




2018-04-07 分析一下挺有意思的...我的残缺答案
2018-03-22 交作业,重复两遍就会输出两次
2018-03-21 作业 自己码的
2018-03-18 比较字符串作业
2018-03-04 作业题
2018-03-03 站长,有错误
2018-02-24 最后一题代码,没看答案自己码的。里面加了些注释,方便理解。不知道有没有错误,望指出
2018-02-23 最后一题的答案
2018-02-20 pos值是怎么来的
2018-02-14 最后一问:::通过(选择排序)的双层循环方法+字符串.contains()方法 很简单,欢迎指正。
2018-02-14 最后一问:::通过(选择排序)的双层循环方法+字符串.contains()方法 很简单,欢迎指正。
2018-02-01 有哪里能帮忙优化的不,感觉我的循环太多了。。
2018-01-29 自己没看答案写的。
2018-01-24 我这样可不可以,站长的那个后面代码有点看不太明白
2018-01-24 最后一个for循环问题!
2018-01-22 代码优化
2018-01-22 代码优化
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个

上传截图