文章目录Java语法基础
- int与Integer的基本使用对比
- 延伸:关于Integer和int的比较
- 排序都有哪几种方法?请列举。口述用JAVA实现快速排序
- ==冒泡排序==
- ==冒泡排序优化==
- ==快速排序==
- String底层是怎么实现的
- StringPool
- String是不可变的有什么好处?
- == 与 equals
- 创建String对象的方式有哪些?
- “ String s1=new String(“abc”)”语句创建了几个对象?
- intern()的理解
- String 类的常用方法都有那些?
- 构造方法
- 判断功能
- 获取功能
- 转换功能
- 替换 比较功能
- String训练
- 模拟登录,给三次机会,并提示还有几次。如果登录成功,就可以玩猜数字小游戏了。
- 统计一个字符串中大写字母字符,小写字母字符,数字字符出现的次数。(不考虑其他字符)
- 把一个字符串的首字母转成大写,其余为小写。(只考虑英文大小写字母字符)
- 把数组中的数据按照指定个格式拼接成一个字符串
- 字符串反转
- 统计大串中小串出现的次数
int与Integer的基本使用对比
- Integer是int的包装类;int是基本数据类型
- Integer变量必须实例化后才能使用;int变量不需要
- Integer实际是对象的引用,指向此new的Integer对象;int是直接存储的数据值
- Integer的默认值是null;int的默认值是0
- new生成的是两个对象,其内存地址不同;Integer变量实际上是对一个Integer对象的引用
Integer i = new Integer(100); Integer j = new Integer(100); System.out.print(i == j); //false
- Integer变量 指向的是 java 常量池 中的对象,而 new Integer() 的变量指向 堆中 新建的对象,两者在内存中的地址不同。
Integer i = new Integer(100); Integer j = 100; System.out.print(i == j); //false
- 两个Integer 变量比较,如果两个变量的值在区间-128到127 之间,则比较结果为true,如果两个变量的值不在此区间,则比较结果为 false 。
Integer i = 100; Integer j = 100; System.out.print(i == j); //true Integer i = 128; Integer j = 128; System.out.print(i == j); //false
分析:
Integer i = 100 在编译时,会翻译成为 Integer i = Integer.valueOf(100),而 java 对 Integer类型的 valueOf 的定义如下:
public static Integer valueOf(int i){
assert IntegerCache.high >= 127;
if (i >= IntegerCache.low && i <= IntegerCache.high){
return IntegerCache.cache[i + (-IntegerCache.low)];
}
return new Integer(i);
}
java对于-128到127之间的数,会进行缓存。
所以 Integer i = 127 时,会将127进行缓存,下次再写Integer j = 127时,就会直接从缓存中取,就不会new了
- 包装类Integer和基本数据类型int比较时,java会自动拆包装为int,然后进行比较,实际上就变为两个int变量的比较
Integer i = new Integer(100); //自动拆箱为 int i=100; 此时,相当于两个int的比较 int j = 100; System.out.print(i == j); //true排序都有哪几种方法?请列举。口述用JAVA实现快速排序
- 排序的方法有:
插入排序(直接插入排序、希尔排序)
交换排序(冒泡排序、快速排序)
选择排序(直接选择排序、堆排序)
归并排序,分配排序(箱排序、基数排序) - 使用快速排序方法对a[0:n-1]排序:
从a[0:n-1]中选择一个元素作为middle,该元素为支点
把余下的元素分割为两端left和right,使得left中的元素都小于等于支点,而right中的元素都是大于支点。
递归的使用快速排序方法对left进行排序
递归的使用快速排序方法对right进行排序。
所得结果为left+middle+right
package 排序;
import java.util.Arrays;
public class BubbleSort {
public static void main(String[] args) {
int a[]={3,44,38,5,47,15,36,26,27,2,46,4,19,50,48};
// 记录比较的次数
int count = 0;
// i=0,第一轮比较
for (int i = 0; i < a.length-1; i++) {
// 第一轮,两两比较
for (int j = 0; j < a.length-1-i; j++) {
if (a[j]>a[j+1]){
int temp = a[j];
a[j] = a[j+1];
a[j+1] = temp;
}
count++;
}
System.out.println(Arrays.toString(a));
System.out.println("第" + i+1 + "轮" + "一共比较了:" + count + "次");
}
}
}
冒泡排序优化
package 排序;
import java.util.Arrays;
public class BubbleSort_best {
public static void main(String[] args) {
//int a[] = {100,45,36,21,17,13,7};
//int count = 0;
//boolean flag = false;//标识变量,表示是否进行过交换
//for (int i = 0; i < a.length-1; i++) {
// for (int j = 0; j < a.length-1-i; j++) {
// if (a[j] > a[j+1]){
// flag=true;
// int temp = a[j];
// a[j] = a[j+1];
// a[j+1] = temp;
// }
// count++;
// }
// System.out.println(Arrays.toString(a));
// System.out.println("第" + i+1 + "轮" + "一共比较了:" + count + "次");
// if(!flag){//在一趟排序中,一次交换都没发生过
// break;
// }
//}
int a[]={3,44,38,5,47,15,36,26,27,2,46,4,19,50,48};
int count=0;
for (int i = 0; i < a.length-1; i++) {
boolean flag=true;
for (int j = 0; j < a.length-1-i; j++) {
if (a[j]>a[j+1]) {
int temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
flag=false;
}
count++;
}
if (flag) {
break;
}
System.out.println(Arrays.toString(a));
System.out.println("第" + i+1 + "轮" + "一共比较了:" + count + "次");
}
}
}
快速排序
package 排序;
import java.util.Arrays;
public class QuickSort {
public static void main(String[] args) {
int a[]={3,44,38,5,47,15,36,26,27,2,46,4,19,50,48};
quickSort(a,0,a.length-1);
System.out.println(Arrays.toString(a));
}
public static void quickSort(int[] a,int left,int rigtht){
int i,j;
if(left > rigtht){
return;
}
i=left;
j=rigtht;
int temp=a[left];//基准位,left=length时,会报异常
while (i
//先从右边开始往左递减,找到比temp小的值才停止
while (temp<=a[j] && i
j--;
}
//再看左边开始往右递增,找到比temp大的值才停止
while (temp>=a[i] && i
i++;
}
if(i
int t=a[i];
a[i]=a[j];
a[j]=t;
}
}
//最后经基准位跟a[i]与a[j]相等的位置,进行交换,此时i=j
a[left]=a[i];
a[i]=temp;
//左递归
quickSort(a,left,j-1);
// 右递归
quickSort(a,j+1,rigtht);
}
}
String底层是怎么实现的
String类的一个最大特性是不可修改性,而导致其不可修改的原因是在String内部定义了一个常量数组final char数组,因此每次对字符串的操作实际上都会另外分配分配一个新的常量数组空间。
StringPool- 常量池是Java的一项技术, 八种基础数据类型除了float和double都实现了常量池技术. 这项技术从字面上是很好理解的: 把经常用到的数据存放在某块内存中, 避免频繁的数据创建与销毁, 实现数据共享, 提高系统性能。
- 字符串常量池中是不会存储相同内容的字符串的,对于利用字面量形式声明的相同字符串,指向的是字符串常量池中的同一字符串对象。字符串常量池被实现在Java堆内存中。
- 因为不可变,所以是线程安全的,可以多线程使用
- 由于不可变,所以可以用于密码存储
- 可以很好的作为hashmap中key值存储等
String s1="abc"; String s2="abc"; System.out.println(s1==s2);//true System.out.println(s1.equals(s2));//true
根据代码顺序,先在常量池中创建”abc“,并指向s1,而后在创建s2时,由于常量池中已经存在”abc“,只需指向s2就可以,而不需要再创建。
(1)在Java中==这个符号是比较运算符,如果是基本数据类型,==比较的是值是否相等,如果是引用数据类型,==比较的是两个对象的内存地址是否相等。
(2)String 中的equals方法经过重写后操作为“比较此字符串与指定的对象。equals方法是Object中的方法,在重写之前也是判断地址,但是重写之后就是判断内容是否相等了。
很明显,s1和s2的字符序列相同,故而结果为true。
- 使用new关键字创建:
1) 如果字符串池中没有该字符串常量池,那么就分别在字符串常量池和堆中创建对象,并将堆中的对象的地址返回
2)如果字符串常量池中有该字符,那么就仅在堆中创建对象,并将堆中的对象地址返回 - 使用双引号创建:
1)此时会在字符串常量池中寻找是否有相应字符串,如果有则返回该地址
2)如果没有则在字符串常量池中创建对象返回地址
- 首先String s1是声明,new String(“abc”)先在常量池中查找,若没有则创建“abc”,而后通过new在堆内存中创建对象,把“abc”拷贝赋值。
- String定义为初始化一个新创建的String对象,表示一个与该参数相同的字符序列;换句话说,新创建的字符串是该参数字符串的一个副本。故创建常量池和堆内存中两个对象,两个对象的地址值不一样。
String s1=new String("abc");
String s2="abc";
System.out.println(s1==s2); //false
System.out.println(s1.equals(s2));//true
s1在堆内存中,s2在常量池中,故结果为false,true
String s1="a"+"b"+"c"; String s2="abc"; System.out.println(s1==s2);//true System.out.println(s1.equals(s2));//true
考察java中常量优化机制,编译时s1已经成为“abc”在常量池中查找创建,s2不需要再创建
String s1="ab"; String s2="abc"; String s3=s1+"c"; System.out.println(s3==s2);//false System.out.println(s3.equals(s2));//true
(1)当字符串相加的部分中全部都是常量时,那么就会直接进入字符串池中进行操作,对象地址就在字符串池中
(2)当字符串相加部分中有变量,那么就会通过 StringBuilder(或 StringBuffer)类及其 append 方法实现的,字符串转换是通过 toString 方法实现的。返回的地址就是堆中的地址
在本题中,先在常量池中创建”ab“,地址指向s1,再创建”abc”,指向s2。对于s3,先创建StringBuilder(或 StringBuffer)对象,通过append连接得到“abc”,再调用toString()转换得到的地址指向s3。故(s3==s2)为false.
String s3 = new String("1") + new String("2");
s3.intern();
String s4 = "12";
System.out.println(s3 == s4); // jdk6:false jdk7/8:true
- 第一行代码创建了六个对象,并且常量池中没有它们拼接之后的"12"这个字符串
此时的s3记录堆中的"12"字符串对象的地址 - 第二行代码,intern方法会在常量池中生成"12"
- 第三行代码中的s4所指向的"12"就是第二行代码在常量池中生成的"12"
- 在jdk6中,确确实实是在常量池创建了一个新的对象"12",所以在jdk6中答案是false
- 在jdk7/8中,字符串常量池已经被移动到了堆中,考虑到了空间节省的问题,此时调用intern方法并不会在字符串常量池里创建一个新的字符串对象"12",而是在常量池中记录该字符串对象在堆空间中的地址,也就是在常量池创建一个指向堆空间中"12"这个字符串对象的引用。那么此时常量池中的"12"实际上指向的是堆空间中的"12",所以当s4以常量的形式声明字符串时,s4记录了常量池中"12"的地址,但是常量池中的"12"实际上是引用的堆空间中的"12",所以到头来s4还是指向了堆空间中的"12",这就是s3=s4的原因。
indexOf():返回指定字符的索引。
charAt():返回指定索引处的字符。
replace():字符串替换。
trim():去除字符串两端空白。
split():分割字符串,返回一个分割后的字符串数组。
getBytes():返回字符串的 byte 类型数组。
length():返回字符串长度。
toLowerCase():将字符串转成小写字母。
toUpperCase():将字符串转成大写字符。
substring():截取字符串。
equals():字符串比较。
package String;
public class StringDemo {
public static void main(String[] args) {
// public String():空构造
String s1 = new String();
System.out.println("s1:" + s1);//s1:
System.out.println("s1.length():" + s1.length());//s1.length():0
System.out.println("--------------------------");
// public String(byte[] bytes):把字节数组转成字符串
byte[] bys = { 97, 98, 99, 100, 101 };
String s2 = new String(bys);
System.out.println("s2:" + s2);//abcde
System.out.println("s2.length():" + s2.length());//s2.length():5
System.out.println("--------------------------");
// public String(byte[] bytes,int index,int length):把字节数组的一部分转成字符串
// 我想得到字符串"bcd"
String s3 = new String(bys, 1, 3);
System.out.println("s3:" + s3);//s3:bcd
System.out.println("s3.length():" + s3.length());//s3.length():3
System.out.println("--------------------------");
// public String(char[] value):把字符数组转成字符串
char[] chs = { 'a', 'b', 'c', 'd', 'e', '爱', '林', '亲' };
String s4 = new String(chs);
System.out.println("s4:" + s4);//s4:abcde爱林亲
System.out.println("s4.length():" + s4.length());//s4.length():8
System.out.println("--------------------------");
// public String(char[] value,int index,int count):把字符数组的一部分转成字符串
String s5 = new String(chs, 2, 4);
System.out.println("s5:" + s5);//s5:cde爱
System.out.println("s5.length():" + s5.length());//s5.length():4
System.out.println("--------------------------");
//public String(String original):把字符串常量值转成字符串
String s6 = new String("abcde");
System.out.println("s6:" + s6);//s6:abcde
System.out.println("s6.length():" + s6.length());//s6.length():5
System.out.println("--------------------------");
//字符串字面值"abc"也可以看成是一个字符串对象。
String s7 = "abcde";
System.out.println("s7:"+s7);//s7:abcde
System.out.println("s7.length():"+s7.length());//s7.length():5
System.out.println("--------------------------");
String s8 = "hello";
s8 += "world";
System.out.println("s8:" + s8); // helloworld
System.out.println("--------------------------");
String s9 = new String("hello");
String s10 = "hello";
System.out.println(s9 == s10);// false
System.out.println(s9.equals(s10));// true
String s11 = "hello";
String s12 = "hello";
System.out.println(s11 == s12);// 字符串字面量,直接从内存找,所以true
System.out.println(s11.equals(s12));// true
System.out.println("--------------------------");
String s13 = "hello";
String s14 = "world";
String s15 = "helloworld";
System.out.println(s13 == s14 + s15);// false。字符串如果是变量相加,先开空间,再拼接。
System.out.println(s13.equals((s14 + s15)));// true
System.out.println(s13 == "hello" + "world");//true。字符串如果是常量相加,是先加,然后在常量池找,如果有就直接返回,否则,就创建。
System.out.println(s13.equals("hello" + "world"));// true
}
}
判断功能
package String;
public class StringDemo2 {
public static void main(String[] args) {
// 创建字符串对象
String s1 = "helloworld";
String s2 = "helloworld";
String s3 = "HelloWorld";
// boolean equals(Object obj):比较字符串的内容是否相同,区分大小写
System.out.println("equals:" + s1.equals(s2));//equals:true
System.out.println("equals:" + s1.equals(s3));//equals:false
System.out.println("-----------------------");
// boolean equalsIgnoreCase(String str):比较字符串的内容是否相同,忽略大小写
System.out.println("equals:" + s1.equalsIgnoreCase(s2));//equals:true
System.out.println("equals:" + s1.equalsIgnoreCase(s3));//equals:true
System.out.println("-----------------------");
// boolean contains(String str):判断大字符串中是否包含小字符串
System.out.println("contains:" + s1.contains("hello"));//contains:true
System.out.println("contains:" + s1.contains("hw"));//contains:false
System.out.println("-----------------------");
// boolean startsWith(String str):判断字符串是否以某个指定的字符串开头
System.out.println("startsWith:" + s1.startsWith("h"));//startsWith:true
System.out.println("startsWith:" + s1.startsWith("hello"));//startsWith:true
System.out.println("startsWith:" + s1.startsWith("world"));//startsWith:false
System.out.println("-----------------------");
// 练习:boolean endsWith(String str):判断字符串是否以某个指定的字符串结尾这个自己玩
// boolean isEmpty():判断字符串是否为空。
System.out.println("isEmpty:" + s1.isEmpty());//isEmpty:false
String s4 = "";
String s5 = null;
System.out.println("isEmpty:" + s4.isEmpty());//isEmpty:true
// NullPointerException
// s5对象都不存在,所以不能调用方法,空指针异常
// System.out.println("isEmpty:" + s5.isEmpty());
}
}
获取功能
package String;
public class StringDemo3 {
public static void main(String[] args) {
// 定义一个字符串对象
String s = "helloworld";
// int length():获取字符串的长度。
System.out.println("s.length:" + s.length());//10
System.out.println("----------------------");
// char charAt(int index):获取指定索引位置的字符
System.out.println("charAt:" + s.charAt(7));//charAt:r
System.out.println("----------------------");
// int indexOf(int ch):返回指定字符在此字符串中第一次出现处的索引。
System.out.println("indexOf:" + s.indexOf('l'));//indexOf:2
System.out.println("----------------------");
// int indexOf(String str):返回指定字符串在此字符串中第一次出现处的索引。
System.out.println("indexOf:" + s.indexOf("owo"));//indexOf:4
System.out.println("----------------------");
// int indexOf(int ch,int fromIndex):返回指定字符在此字符串中从指定位置后第一次出现处的索引。
System.out.println("indexOf:" + s.indexOf('l', 4));//indexOf:8
System.out.println("indexOf:" + s.indexOf('k', 4)); // -1
System.out.println("indexOf:" + s.indexOf('l', 40)); // -1
System.out.println("----------------------");
// 自己练习:int indexOf(String str,int fromIndex):返回指定字符串在此字符串中从指定位置后第一次出现处的索引。
// String substring(int start):从指定位置开始截取字符串,默认到末尾。包含start这个索引
System.out.println("substring:" + s.substring(5));//substring:world
System.out.println("substring:" + s.substring(0));//substring:helloworld
System.out.println("----------------------");
// String substring(int start,intend):从指定位置开始到指定位置结束截取字符串。
//包括start索引但是不包end索引 [start,end)
System.out.println("substring:" + s.substring(3, 8));//substring:lowor
System.out.println("substring:" + s.substring(0, s.length()));//substring:helloworld
}
}
转换功能
package String;
public class StringDemo4 {
public static void main(String[] args) {
// 定义一个字符串对象
String s = "JavaSE";
// byte[] getBytes():把字符串转换为字节数组。
byte[] bys = s.getBytes();
for (int x = 0; x < bys.length; x++) {
System.out.println(bys[x]);
}
System.out.println("----------------");
// char[] toCharArray():把字符串转换为字符数组。
char[] chs = s.toCharArray();
for (int x = 0; x < chs.length; x++) {
System.out.println(chs[x]);
}
System.out.println("----------------");
// static String valueOf(char[] chs):把字符数组转成字符串。
String ss = String.valueOf(chs);
System.out.println(ss);//JavaSE
System.out.println("----------------");
// static String valueOf(int i):把int类型的数据转成字符串。
int i = 100;
String sss = String.valueOf(i);
System.out.println(sss);//100
System.out.println("----------------");
// String toLowerCase():把字符串转成小写。
System.out.println("toLowerCase:" + s.toLowerCase());//toLowerCase:javase
System.out.println("s:" + s);//s:JavaSE
// System.out.println("----------------");
// String toUpperCase():把字符串转成大写。
System.out.println("toUpperCase:" + s.toUpperCase());//toUpperCase:JAVASE
System.out.println("----------------");
// String concat(String str):把字符串拼接。
String s1 = "hello";
String s2 = "world";
String s3 = s1 + s2;
String s4 = s1.concat(s2);
System.out.println("s3:"+s3);//s3:helloworld
System.out.println("s4:"+s4);//s4:helloworld
System.out.println(s3.equals(s4));//true
System.out.println(s3==s4);//false
}
}
替换 比较功能
package String;
public class StringDemo5 {
public static void main(String[] args) {
// 替换功能
String s1 = "helloworld";
String s2 = s1.replace('l', 'k');
String s3 = s1.replace("owo", "ak47");
System.out.println("s1:" + s1);//s1:helloworld
System.out.println("s2:" + s2);//s2:hekkoworkd
System.out.println("s3:" + s3);//s3:hellak47rld
System.out.println("---------------");
// 去除字符串两空格
String s4 = " hello world ";
String s5 = s4.trim();
System.out.println("s4:" + s4 + "---");//s4: hello world ---
System.out.println("s5:" + s5 + "---");//s5:hello world---
// 按字典顺序比较两个字符串
String s6 = "hello";
String s7 = "hello";
String s8 = "abc";
String s9 = "xyz";
System.out.println(s6.compareTo(s7));// 0
System.out.println(s6.compareTo(s8));// 7
System.out.println(s6.compareTo(s9));// -16
}
}
String训练
模拟登录,给三次机会,并提示还有几次。如果登录成功,就可以玩猜数字小游戏了。
package String;
import java.util.Scanner;
public class StringTest1 {
public static void main(String[] args) {
// 定义用户名和密码。已存在的。
String username = "admin";
String password = "admin";
// 给三次机会,用循环改进,最好用for循环。
for (int x = 0; x < 3; x++) {
// x=0,1,2
// 键盘录入用户名和密码。
Scanner sc = new Scanner(System.in);
System.out.println("请输入用户名:");
String name = sc.nextLine();
System.out.println("请输入密码:");
String pwd = sc.nextLine();
// 比较用户名和密码。
if (name.equals(username) && pwd.equals(password)) {
// 如果都相同,则登录成功
System.out.println("登录成功,开始玩游戏");
//猜数字游戏
GuessNumberGame.start();
break;
} else {
// 如果有一个不同,则登录失败
// 2,1,0
// 如果是第0次,应该换一种提示
if ((2 - x) == 0) {
System.out.println("帐号被锁定,请与班长联系");
} else {
System.out.println("登录失败,你还有" + (2 - x) + "次机会");
}
}
}
}
}
统计一个字符串中大写字母字符,小写字母字符,数字字符出现的次数。(不考虑其他字符)
package String;
public class StringTest2 {
public static void main(String[] args) {
//定义一个字符串
String s = "Hello123World";
//定义三个统计变量
int bigCount = 0;
int smallCount = 0;
int numberCount = 0;
//遍历字符串,得到每一个字符。
for(int x=0; x
char ch = s.charAt(x);
//判断该字符到底是属于那种类型的,char类型会转成int类型
if(ch>='a' && ch<='z'){
smallCount++;
}else if(ch>='A' && ch<='Z'){
bigCount++;
}else if(ch>='0' && ch<='9'){
numberCount++;
}
}
//输出结果。
System.out.println("大写字母"+bigCount+"个");
System.out.println("小写字母"+smallCount+"个");
System.out.println("数字"+numberCount+"个");
}
}
把一个字符串的首字母转成大写,其余为小写。(只考虑英文大小写字母字符)
package String;
public class StringTest3 {
public static void main(String[] args) {
// 定义一个字符串
String s = "helloWORLD";
// 先获取第一个字符
String s1 = s.substring(0, 1);
// 获取除了第一个字符以外的字符
String s2 = s.substring(1);
// 把A转成大写
String s3 = s1.toUpperCase();
// 把B转成小写
String s4 = s2.toLowerCase();
// C拼接D
String s5 = s3.concat(s4);
System.out.println(s5);
// 优化后的代码
// 链式编程
String result = s.substring(0, 1).toUpperCase()
.concat(s.substring(1).toLowerCase());
System.out.println(result);
}
}
把数组中的数据按照指定个格式拼接成一个字符串
package String;
public class StringTest4 {
public static void main(String[] args) {
// 前提是数组已经存在
int[] arr = { 1, 2, 3 };
// 写一个功能,实现结果
String result = arrayToString(arr);
System.out.println("最终结果是:" + result);
}
public static String arrayToString(int[] arr) {
// 定义一个字符串
String s = "";
// 先把字符串拼接一个"["
s += "[";
// 遍历int数组,得到每一个元素
for (int x = 0; x < arr.length; x++) {
// 先判断该元素是否为最后一个
if (x == arr.length - 1) {
// 就直接拼接元素和"]"
s += arr[x];
s += "]";
} else {
// 就拼接元素和逗号以及空格
s += arr[x];
s += ", ";
}
}
return s;
}
}
字符串反转
package String;
import java.util.Scanner;
public class StringTest5 {
public static void main(String[] args) {
// 键盘录入一个字符串
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个字符串:");
String line = sc.nextLine();
String s = myReverse(line);
System.out.println("实现功能后的结果是:" + s);
}
public static String myReverse(String s) {
// 定义一个新字符串
String result = "";
// 把字符串转成字符数组
char[] chs = s.toCharArray();
// 倒着遍历字符串,得到每一个字符
for (int x = chs.length - 1; x >= 0; x--) {
// 用新字符串把每一个字符拼接起来
result += chs[x];
}
return result;
}
}
统计大串中小串出现的次数
package String;
public class StringTest6 {
public static void main(String[] args) {
// 定义大串
String maxString = "woaijavawozhenaijavawozhendeaijavawozhendehenaijavaxinbuxinwoaijavagun";
// 定义小串
String minString = "java";
// 写功能实现
int count = getCount(maxString, minString);
System.out.println("Java在大串中出现了:" + count + "次");
}
public static int getCount(String maxString, String minString) {
// 定义一个统计变量,初始化值是0
int count = 0;
int index;
//先查,赋值,判断
while((index=maxString.indexOf(minString))!=-1){
count++;
maxString = maxString.substring(index + minString.length());
}
return count;
}
}



