黑马程序员--String、StringBuffer、StringBuilder、基本数据类型对象包装类(Java)

------Java培训、Android培训、iOS培训、.Net培训、期待与您交流! -------

一.String


1.概述:
java中用String类进行描述。对字符串进行了对象的封装。这样的好处是可以对字符串这种常见数据进行方便的操作。对象封装后,可以定义N多属性和行为。
String是字符串的类类型,用于描述字符串事物。


2.特点:
一旦被初始化就不可以被改变。存放在方法区中的常量池中。


3.面试题:
String s1 = "abc";
String s2 = new String("abc");
String s3 = "abc";
s1和s2有什么区别?
s1在内存中有一个对象abc。
s2在内存中有两个对象abc、new。


s1==s2   ( false )
s1.equals(s2) ( true )
String类复写了Object类中的equals方法,该方法用于判断字符串是否相同。


s1==s3   ( true )
因为“abc”这个字符串对象已经在内存中存在,作为字符串这种特殊的对象,这种在常量池中存在的数据。s3进行初始化时,发现abc已经在内存中存在,就不会再独立开辟空间,因为再开辟空间就比较浪费空间。因此为了节约内存,在字符串对象当中只要字符串相同,那么s1和s3就指向同一个对象。


4.操作字符串方法:


1)、获取:
1.1 获取字符串的长度:int length();
1.2 根据位置获取位置上某个字符:char charAt(int index);
1.3 根据字符获取该字符在字符串中位置:
int indexOf(int ch);返回的是ch在字符串中第一次出现的位置。
int indexOf(int ch, int fromIndex);从fromIndex指定位置开始,获取ch在字符串中出现的位置。
int indexOf(String str);返回的是str在字符串中第一次出现的位置。
int indexOf(String str, int fromIndex);从fromIndex指定位置开始,获取str在字符串中出现的位置。
int lastIndexOf();反向索引。


2)、判断:
2.1 字符串中是否包含某一个子串:boolean contains(str);
特殊之处:indexOf(str)可以索引str第一次出现的位置,如果返回-1表示该str不在字符串中存在。所以,也可以用于对指定判断是否包含。
2.2 字符串中是否有内容(长度是否为0):boolean isEmpty();
2.3 字符串是否以指定内容开头:boolean startsWith(str);
2.4 字符串是否以指定内容结尾:boolean endsWith(str);
2.5 判断字符串内容是否相同:boolean equals(str);
2.6 判断内容是否相同,并忽略大小写:boolean equalsIgnoreCase();


3)、转换:
3.1 将字符数组转成字符串:
构造函数:
          String(char[]);
          String(char[],offset,count):将字符数组的一部分转成字符串。
静态方法:
          static String copyValueOf(char[]);
          static String copyValueOf(char[] data, int offset, int count);
          static String valueOf(char[]);
3.2 将字符串转成字符数组:char[] toCharArray();
3.3 将字节数组转成字符串:
              String (byte[]);
              String(byte[],offset,count);将字节数组中的一部分转成字符串。count表示个数。
3.4 将字符串转成字节数组:
              byte[] getBytes();
3.5 将基本数据类型转成字符串:
              StringvalueOf(int);
              StringvalueOf(double);
特殊:字符串和字节数组在转换过程中,是可以指定编码表的。


4)、替换:
String replace(oldchar,newchar);


5)、切割:
String[] split(regex);


6)、子串。获取字符串中的一部分。
String substring(begin);
String substring(begin,end);注:包含头,不包含尾。


7)、转换,去除空格,比较。
7.1 将字符串转成大写或小写:
String toUpperCase();
String toLowerCase();
7.2 将字符串两端的多个空格去除:
String trim();
7.3 对两个字符串进行自然顺序的比较:
int compareTo(string);
注:如果参数字符串等于此字符串,则返回值0;如果此字符串按字典顺序小于字符串参数,则返回一个小于0的值;如果此字符串按字典顺序大于字符串参数,则返回一个大于0的值。


这7中字符串操作方法代码体现:
(代码 StringMethodDemo.java):

class StringMethodDemo 
{
	public static void main(String[] args) 
	{
		method_get();//获取
		method_is();//判断
		method_trans();//转换
		method_replace();//替换
		method_split();//切割
		method_sub();//获取子串
		method_7();
	}
	public static void sop(Object obj)
	{
		System.out.println(obj);
	}
	public static void method_get()//获取
	{
		String str = "abcdec";
        sop(str.length());//长度
		sop(str.charAt(3));//根据索引获取字符
		sop(str.indexOf('c',3));//根据字符获取索引
		sop(str.lastIndexOf('b'));//反向索引
	}
	public static void method_is()//判断
	{
		String str = "StringMethodDemo.java";
		sop(str.startsWith("String"));//判断文件名称是否是String单词开头。
		sop(str.endsWith(".java"));//判断文件名称是否是.java的文件。
		sop(str.contains("Demo"));//判断文件中是否包含Demo。
	}
	public static void method_trans()//转换
	{
		char[] arr = {'a','b','c','d','e'};
		String s = new String(arr);//将字符数组转成字符串。
		String s1 = new String(arr,1,3);//注意:1是从角标1开始,3是个数。
		sop("s= "+s);
		sop("s1= "+s1);
		//将字符数组转成字符串。
		String str = "asdfg";
		char[] chs= str.toCharArray();
		for(int x=0;x<chs.length;x++)
			sop("ch="+chs[x]);       
	}
	public static void method_replace()//替换
	{
		String s = "hello java";
		String s1 = s.replace('a','n');
		sop("s="+s);
		sop("s1="+s1);
	}
	public static void method_split()//切割
	{
		String s = "zhangsan,lisi,wangwu";
		String[] arr = s.split(",");
		for(int x =0;x<arr.length;x++)
			sop(arr[x]);
	}
	public static void method_sub()//获取子串
	{
		String s = "abcdef";
		sop(s.substring(2));//从指定位置到结尾。
		sop(s.substring(2,4));//包含头,不包含尾。
	}
	public static void method_7()
	{
		String s = "   Hello Java   ";
		sop(s.toUpperCase());//大写
		sop(s.toLowerCase());//小写
		sop(s.trim());//将字符串两端的多个空格去除。

		String s1 = "acc";
		String s2 = "aaa";
		sop(s1.compareTo(s2));//对两个字符串进行自然顺序的比较。
	}

}


5.字符串操作练习:
(代码 StringTest.java):

//练习1:将一个字符串进行反转。
	/*
	思路:
	1,将字符串变成数组。
	2,将数组反转。
	3,将数组变成字符串。
	*/
class StringTest 
{
	public static void main(String[] args) 
	{
		String s = "abcd";
		System.out.println(s);
		System.out.println(reverseString(s));
	}

	public static String reverseString(String str)
	{
		char[] chs = str.toCharArray();
		reverse(chs);
		return new String(chs);
	}
	//反转指定字符数组位置
	private static void reverse(char[] arr)
	{
		for(int start=0,end=arr.length-1;start<end;start++,end--)
		{
			swap(arr,start,end);
		}
	}
	//交换相应数组元素 
	private static void swap(char[] arr,int x,int y)
	{
		char temp = arr[x];
		arr[x] = arr[y];
		arr[y] = temp;
	}
}


(代码 StringTest2.java):

//练习2:获取一个字符串在另一个字符串中出现的次数。

class StringTest2 
{
	public static void main(String[] args) 
	{
		String str = "asddfgddhhjkdd";
		System.out.println(getSubCount(str,"dd"));
	}
	public static int getSubCount(String str,String key)
	{
		int count = 0;
		int index = 0;
		while((index=str.indexOf(key))!=-1)
		{
			System.out.println(str);
			str = str.substring(index+key.length());
			count++;
		}
		return count;
	}
}


(代码 StringTest3.java):

//获取两个字符串中的最大相同子串。
/*
思路:
1、将短的一个字符串与长的进行比较,
如果没有,则将短串的字串按长度递减的方式获取。
2、将每次获取的子串,去长串中判断是否包含,包含即找到。
*/
class StringTest3 
{
	public static void main(String[] args) 
	{
		String s1="asdfhellosfg";  
        String s2="frhelloy";  
        System.out.println(getMaxSubstring(s1,s2)); 
	}
	public static String getMaxSubstring(String s1,String s2)  
    {  
        String max,min;  
        max=(s1.length()>s2.length())?s1:s2; 
        min=(s1.length()<s2.length())?s1:s2;
  
        for (int x=0;x<min.length() ;x++ )
        {  
            for (int y=0,z=min.length()-x;z<min.length()+1;y++,z++)
            {  
                String temp=min.substring(y,z);//获取短字符串子串  
                if(max.contains(temp))//如果长串包含,则表示找到  
                    return temp;
            }  
        }  
        return "没有相同的字符串";
    }  
  
}


 

二.StringBuffer


1.概述:
字符串缓冲区,可以对字符串进行增删改查操作,StringBuffer是一个容器。


2.特点:
1)、长度可变。
2)、可以字节操作多个数据类型。
3)、最终会通过toString方法变成字符串。


3.与数组区别:
1)、StringBuffer长度是可变化的。(数组是固定的)。
2)、StringBuffer可以直接操作多个数据类型。(数组只能操作一个)。


4.容器中的方法:
1)、添加。
StringBuffer append(data):在缓冲区中添加数据。添加到尾部。
StringBuffer insert(index,data):在指定位置插入数据。
2)、删除。
StringBuffer delete(start,end);删除从start至end-1范围的元素(包含头,不包含尾)。
StringBuffer deleteCharAt(index);删除指定位置的元素。
注意:例子:sb.delete(0,sb.length());清空缓冲区(包含头,不包含尾)。
3)、获取(查找)。
int indexOf(string); 返回指定子字符串在此字符串中第一次出现处的索引。没有就返回-1。
int indexOf(string,int fromIndex);从指定位置开始查找字符串。
int lastIndexOf(string); 返回指定子字符串在此字符串中最右边出现处的索引。
int lastIndexOf(string,int fromIndex); 从指定的索引开始反向搜索。
string substring(start); 返回start到结尾的子串。
string substring(start,end); 返回start至end-1的子串。
4)、修改。
StringBuffer replace(start,end,string);将start至end-1替换成string。(包含头,不包含尾)。
void setCharAt(index,char);替换指定位置的字符。
void setLength(len);将原字符串置为指定长度的字符串。
5)、反转。
StringBuffer reverse();字符串反转,如果String想反转就要转换成StringBuffer再反转。
6)、将缓冲区中指定数据存储到指定字符数组中。
void getChars(int srcBegin, int srcEnd,char[] dst,int dstBegin)




三.StringBuilder


1.JDK1.5 版本之后出现了StringBuilder。


2.StringBuffer与StringBuilder区别:
1)、StringBuffer是线程同步。(安全)
2)、StringBuilder是线程不同步。(不安全)
以后开发,建议使用StringBuilder。提高效率。如果遇到多线程,使用StringBuffer或自己加锁。


3.升级三因素:
            1)、提高效率。
            2)、简化书写。
            3)、提高安全性。



四.基本数据类型对象包装类



1.概念:是按照面向对象思想将基本数据类型封装成了对象。


2.好处:
      1)、可以通过对象中的属性和行为操作基本数据。
      2)、可以实现基本数据类型和字符串之间的转换。


3.基本数据类型对象包装类:
byte        Byte
short       Short
int         Integer
long        Long
boolean     Boolean
float       Float
double      Double
char        Character


4.基本数据类型转成字符串:
基本数据类型+" "
基本数据类型.toString(基本数据类型值);
例如:Integer.toString(34);//将34整数变成"34"。


5.字符串转成基本数据类型:
xxx a=Xxx.parseXxx(string);
例如:
int a = Integer.parseInt("123");静态。注意:必须传入数字格式的字符串。
boolean b = Boolean.parseBoolean("true");


Integer i = new Integer("123");
int num = i.intValue();//跟上面的静态方式的结果一样,但这种属于对象调用方式。


6.十进制转成其他进制。
转成二进制:toBinaryString
转成八进制:toOctalString
转成十六进制:toHexString


7.其他进制转成十进制。
parseInt(String,radix);
例如:
int x = Integer.parseInt("110",10);
int a = Integer.parseInt("3c",16);


8.在jdk1.5版本后,对基本数据类型对象包装类进行升级。在升级中,使用基本数据类型对象包装类可以像使用基本数据类型一样,进行运算。
Integer i = new Integer(4);  1.5版本之前的写法。
Integer i = 4;  自动装箱,1.5版本后的写法。
i = i + 2;  i进行自动拆箱。变成了int类型。和2进行加法运算。再将和进行装箱赋给i。


9.小知识点:
Integer x=128;
Integer y=128;
x==y   (false)
Integer m=127;
Integer n=127;
m==n   ( true)
在装箱时,如果数值在byte范围之内,那么数值相同,不会产生新的对象,也就是说多个数值相同的引用指向的是同一个对象。

深度学习是机器学习的一个子领域,它基于人工神经网络的研究,特别是利用多层次的神经网络来进行学习和模式识别。深度学习模型能够学习数据的高层次特征,这些特征对于图像和语音识别、自然语言处理、医学图像分析等应用至关重要。以下是深度学习的一些关键概念和组成部分: 1. **神经网络(Neural Networks)**:深度学习的基础是人工神经网络,它是由多个层组成的网络结构,包括输入层、隐藏层和输出层。每个层由多个神经元组成,神经元之间通过权重连接。 2. **前馈神经网络(Feedforward Neural Networks)**:这是最常见的神经网络类型,信息从输入层流向隐藏层,最终到达输出层。 3. **卷积神经网络(Convolutional Neural Networks, CNNs)**:这种网络特别适合处理具有网格结构的数据,如图像。它们使用卷积层来提取图像的特征。 4. **循环神经网络(Recurrent Neural Networks, RNNs)**:这种网络能够处理序列数据,如时间序列或自然语言,因为它们具有记忆功能,能够捕捉数据中的时间依赖性。 5. **长短期记忆网络(Long Short-Term Memory, LSTM)**:LSTM 是一种特殊的 RNN,它能够学习长期依赖关系,非常适合复杂的序列预测任务。 6. **生成对抗网络(Generative Adversarial Networks, GANs)**:由两个网络组成,一个生成器和一个判别器,它们相互竞争,生成器生成数据,判别器评估数据的真实性。 7. **深度学习框架**:如 TensorFlow、Keras、PyTorch 等,这些框架提供了构建、训练和部署深度学习模型的工具和库。 8. **激活函数(Activation Functions)**:如 ReLU、Sigmoid、Tanh 等,它们在神经网络中用于添加非线性,使得网络能够学习复杂的函数。 9. **损失函数(Loss Functions)**:用于评估模型的预测与真实值之间的差异,常见的损失函数包括均方误差(MSE)、交叉熵(Cross-Entropy)等。 10. **优化算法(Optimization Algorithms)**:如梯度下降(Gradient Descent)、随机梯度下降(SGD)、Adam 等,用于更新网络权重,以最小化损失函数。 11. **正则化(Regularization)**:技术如 Dropout、L1/L2 正则化等,用于防止模型过拟合。 12. **迁移学习(Transfer Learning)**:利用在一个任务上训练好的模型来提高另一个相关任务的性能。 深度学习在许多领域都取得了显著的成就,但它也面临着一些挑战,如对大量数据的依赖、模型的解释性差、计算资源消耗大等。研究人员正在不断探索新的方法来解决这些问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值