黑马程序员--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范围之内,那么数值相同,不会产生新的对象,也就是说多个数值相同的引用指向的是同一个对象。

以下是对提供的参考资料的总结,按照要求结构化多个要点分条输出: 4G/5G无线网络优化与网规案例分析: NSA站点下终端掉4G问题:部分用户反馈NSA终端频繁掉4G,主要因终端主动发起SCGfail导致。分析显示,在信号较好的环境下,终端可能因节能、过热保护等原因主动释放连接。解决方案建议终端侧进行分析处理,尝试关闭节电开关等。 RSSI算法识别天馈遮挡:通过计算RSSI平均值及差值识别天馈遮挡,差值大于3dB则认定有遮挡。不同设备分组规则不同,如64T和32T。此方法可有效帮助现场人员识别因环境变化引起的网络问题。 5G 160M组网小区CA不生效:某5G站点开启100M+60M CA功能后,测试发现UE无法正常使用CA功能。问题原因在于CA频点集标识配置错误,修正后测试正常。 5G网络优化与策略: CCE映射方式优化:针对诺基亚站点覆盖农村区域,通过优化CCE资源映射方式(交织、非交织),提升RRC连接建立成功率和无线接通率。非交织方式相比交织方式有显著提升。 5G AAU两扇区组网:与三扇区组网相比,AAU两扇区组网在RSRP、SINR、下载速率和上传速率上表现不同,需根据具体场景选择适合的组网方式。 5G语音解决方案:包括沿用4G语音解决方案、EPS Fallback方案和VoNR方案。不同方案适用于不同的5G组网策略,如NSA和SA,并影响语音连续性和网络覆盖。 4G网络优化与资源利用: 4G室分设备利旧:面对4G网络投资压减与资源需求矛盾,提出利旧多维度调优策略,包括资源整合、统筹调配既有资源,以满足新增需求和提质增效。 宏站RRU设备1托N射灯:针对5G深度覆盖需求,研究使用宏站AAU结合1托N射灯方案,快速便捷地开通5G站点,提升深度覆盖能力。 基站与流程管理: 爱立信LTE基站邻区添加流程:未提供具体内容,但通常涉及邻区规划、参数配置、测试验证等步骤,以确保基站间顺畅切换和覆盖连续性。 网络规划与策略: 新高铁跨海大桥覆盖方案试点:虽未提供详细内容,但可推测涉及高铁跨海大桥区域的4G/5G网络覆盖规划,需考虑信号穿透、移动性管理、网络容量等因素。 总结: 提供的参考资料涵盖了4G/5G无线网络优化、网规案例分析、网络优化策略、资源利用、基站管理等多个方面。 通过具体案例分析,展示了无线网络优化中的常见问题及解决方案,如NSA终端掉4G、RSSI识别天馈遮挡、CA不生效等。 强调了5G网络优化与策略的重要性,包括CCE映射方式优化、5G语音解决方案、AAU扇区组网选择等。 提出了4G网络优化与资源利用的策略,如室分设备利旧、宏站RRU设备1托N射灯等。 基站与流程管理方面,提到了爱立信LTE基站邻区添加流程,但未给出具体细节。 新高铁跨海大桥覆盖方案试点展示了特殊场景下的网络规划需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值