DAY6:尚学堂高琪JAVA(55~62)

Java中的String,StringBuilder,StringBuffer的区别

1.运行速度
快慢为:StringBuilder > StringBuffer > String
String为字符串常量,而StringBuilder和StringBuffer均为字符串变量,即String对象一旦创建之后该对象是不可更改的,但后两者的对象是变量,是可以更改的。以下面一段代码为例:

String str="abc";
System.out.println(str);
str=str+"de";
System.out.println(str);

如果运行这段代码会发现先输出“abc”,然后又输出“abcde”,好像是str这个对象被更改了,其实,这只是一种假象罢了,JVM对于这几行代码是这样处理的,首先创建一个String对象str,并把“abc”赋值给str,然后在第三行中,其实JVM又创建了一个新的对象也名为str,然后再把原来的str的值和“de”加起来再赋值给新的str,而原来的str就会被JVM的垃圾回收机制(GC)给回收掉了,所以,str实际上并没有被更改,也就是前面说的String对象一旦创建之后就不可更改了。所以,Java中对String对象进行的操作实际上是一个不断创建新的对象并且将旧的对象回收的一个过程,所以执行速度很慢。
2.安全
在线程安全上,StringBuilder是线程不安全的,而StringBuffer是线程安全的,如果一个StringBuffer对象在字符串缓冲区被多个线程使用时,StringBuffer中很多方法可以带有synchronized关键字,所以可以保证线程是安全的,但StringBuilder的方法则没有该关键字,所以不能保证线程安全,有可能会出现一些错误的操作。所以如果要进行的操作是多线程的,那么就要使用StringBuffer,但是在单线程的情况下,还是建议使用速度比较快的StringBuilder。
3. 总结
String:适用于少量的字符串操作的情况

StringBuilder:适用于单线程下在字符缓冲区进行大量操作的情况

StringBuffer:适用多线程下在字符缓冲区进行大量操作的情况

在这里插入图片描述
在这里插入图片描述

二维数组

二维数组可以看作是数组为元素的数组

package testArray;
public class testArray2 {
	public static void main(String[] args) {
		int[][] a={{1,2},{3,4},{5,6}};//1.静态初始化
		int b[][]=new int[3][];//2.动态初始化,定义一个有3个一维数组的二维数组
		b[0]=new int[10];
		b[1]=new int[9];
		b[2]=new int[9];
		b[0][0]=1;
		b[0][1]=2;
		b[1][0]=3;
		b[1][1]=4;
		b[2][0]=5;
		b[2][1]=6;
 
		System.out.println(a);
		for(int i=0;i<3;i++){
			for(int j=0;j<9;j++){
				System.out.println(b[i][j]);
			}
		}
	}
}

二维矩阵的加法和打印:

package testArray;
public class Matrix {
	public static void print(int[][] cc) {
		for(int i=0;i<cc.length;i++){
			for(int j=0;j<cc.length;j++){
				System.out.print(cc[i][j]+"\t");
			}
			System.out.println();
		}
	}
	public static int[][] add(int[][] aa,int[][] bb) {
		int cc[][]=new int[aa.length][bb.length];
		for(int i=0;i<cc.length;i++){
			for(int j=0;j<cc.length;j++){
				cc[i][j]=aa[i][j]+bb[i][j];
			}
		}
		return cc;
	}
	public static void main(String[] args) {
		int[][] aa={{1,3},
				   {2,4}
		};
		int[][] bb={{4,5},
				{6,7}
		};
		int[][] cc=add(aa, bb);
		print(cc);
	}
}

定义一个长度为8的一维字符串数组,在每一个元素中存放一个单词,然后运行时从命令行输入一个单词,包含这个单词就打印YES 否则就NO

package testArray;
import java.util.Scanner;
public class lianxi {
	public static void main(String[] args) {
		String[] init=new String[8];
		init[0]="aaa0";
		init[1]="aaa1";
		init[2]="aaa2";
		init[3]="aaa3";
		init[4]="aaa4";
		init[5]="aaa5";
		init[6]="aaa6";
		init[7]="aaa7";
		String b;
		Scanner s=new Scanner(System.in);
		System.out.println("Input a String:");
		b=s.next();
		for(int i=0;i<init.length;i++){
			if (b.equals(init[i])) {
				System.out.println("YES");
				break;
			}
			else {
				System.out.println("NO");
			}
		}
	}

}

测试:编写0~n之间的随机数,n为参数。并找出产生的50个这样的随机数中的最值,并统计其中大于等于60的有几个。

package testArray;
import java.lang.reflect.Array;
import java.util.Arrays;
import java.util.Scanner;
public class lianxi02 {
	public static int[] creatarray(int n) {
		int[] a=new int[50];
		for(int i=0;i<50;i++){
			a[i]=(int)(n*Math.random());
			System.out.print(a[i]+"\t");
			if((i+1)%5==0){
				System.out.println();
			}
		}
		System.out.println();
		return a;
	}
	public static void main(String[] args) {
		int n;
		System.out.println("输入要生成随机数字的最大值:");
		Scanner s=new Scanner(System.in);
		n=s.nextInt();
		int test[]=creatarray(n);
		//Arrays.sort(test);
		int min=999,max=0,numOfSixty=0;
		for(int m:test){
			if(m>=max){
				max=m;
				}
			if(m<=min){
				min=m;
			}
			if (m>59) {
				numOfSixty++;
			}
		}
		System.out.println("最大值="+max);
		System.out.println("最小值="+min);
		System.out.println("大于等于60的个数:"+numOfSixty);
	}
}

练习:生成20个随机数,并进行排序

package testArray;
import java.util.Arrays;
public class test03 {
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		int[] a=new int[20];
		for(int i=0;i<a.length;i++){
			a[i]=(int)( Math.random()*100);
		}
		Arrays.sort(a);//如果包含在上一个循环则会有一半的元素显示0,
		//因为i大于1/2的length后,每次的随机元素会冲洗掉已经排序好的元素
		for(int i=0;i<a.length;i++){
			System.out.print(a[i]+"\t");
			if((i+1)%5==0){
				System.out.println();
			}
		}
	}
}

猜你喜欢

转载自blog.csdn.net/qq_40802113/article/details/86629813