String字符串小结

五,String字符串小结。

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

 

如何定义字符串对象呢?String s = "abc";只要是双引号引起的数据都是字符串对象。

 

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

------------------------------------------------------

String s1 = "abc"; // s1指向的内存中只有一个对象abc。

String s2 = new String("abc"); // s2指向的内容中有两个对象abc、new 。

 

System.out.println(s1==s2);//false

System.out.println(s1.equals(s2));//true ,字符串中equals比较的是字符串内容是否相同。

-------------------------------------------------------

字符串的方法:

 

1:构造方法:将字节数组或者字符数组转成字符串。

String s1 = new String();//创建了一个空内容的字符串。 

String s2 = null;//s2没有任何对象指向,是一个null常量值。

String s3 = "";//s3指向一个具体的字符串对象,只不过这个字符串中没有内容。

//一般在定义字符串时,不用new。

String s4 = new String("abc");

String s5 = "abc"; 一般用此写法

new String(char[]);//将字符数组转成字符串。

new String(char[],offset,count);//将字符数组中的一部分转成字符串。

 

2:一般方法:

按照面向对象的思想:

2.1 获取:

2.1.1:获取字符串的长度。length();

2.1.2:指定位置的字符。char charAt(int index);

2.1.3:获取指定字符的位置。如果不存在返回-1,所以可以通过返回值-1来判断某一个字符不存在的情况。

int indexOf(int ch);//返回第一次找到的字符角标

int indexOf(int ch,int fromIndex); //返回从指定位置开始第一次找到的角标

int indexOf(String str); //返回第一次找到的字符串角标

int indexOf(String str,int fromIndex);

 

int lastIndexOf(int ch);

int lastIndexOf(int ch,int fromIndex);

int lastIndexOf(String str);

int lastIndexOf(String str,int fromIndex);

2.1.4:获取子串。

String substring(int start);//从start位开始,到length()-1为止.

String substring(int start,int end);//从start开始到end为止。//包含start位,不包含end位。

substring(0,str.length());//获取整串

2.2 判断:

2.2.1:字符串中包含指定的字符串吗?

boolean contains(String substring);

2.2.2:字符串是否以指定字符串开头啊?

boolean startsWith(string);

2.2.3:字符串是否以指定字符串结尾啊?

boolean endsWith(string);

2.2.4:判断字符串是否相同

boolean equals(string);//覆盖了Object中的方法,判断字符串内容是否相同。

2.2.5:判断字符串内容是否相同,忽略大小写。

boolean equalsIgnoreCase(string) ;

 

2.3 转换:

2.3.1:通过构造函数可以将字符数组或者字节数组转成字符串。

2.3.2:可以通过字符串中的静态方法,将字符数组转成字符串。

static String copyValueOf(char[] );

static String copyValueOf(char[],int offset,int count);

static String valueOf(char[]);

static String valueOf(char[],int offset,int count);

2.3.3:将基本数据类型或者对象转成字符串。

static String valueOf(char);

static String valueOf(boolean);

static String valueOf(double);

static String valueOf(float);

static String valueOf(int);

static String valueOf(long);

static String valueOf(Object);

2.3.4:将字符串转成大小写。

String toLowerCase();

String toUpperCase();

2.3.5:将字符串转成数组。

char[] toCharArray();//转成字符数组。

byte[] getBytes();//可以加入编码表。转成字节数组。

2.3.6:将字符串转成字符串数组。切割方法。

String[] split(分割的规则-字符串);

2.3.7:将字符串进行内容替换。注意:修改后变成新字符串,并不是将原字符串直接修改。

String replace(oldChar,newChar);

String replace(oldstring,newstring);

2.3.8: String concat(string); //对字符串进行追加。

String trim();//去除字符串两端的空格

int compareTo();//如果参数字符串等于此字符串,则返回值 0;如果此字符串按字典顺序小于字符串参数,则返回一个小于 0 的值;如果此字符串按字典顺序大于字符串参数,则返回一个大于 0 的值。

<think>好的,用户想了解字符串操作实验的总结或关键点。我需要先回顾一下相关的引用内容,尤其是引用[3]和引用[4],因为这些直接涉及字符串操作和性能比较。 首先,引用[4]中提到了在Java中使用不同的字符串拼接方法(如+运算符、concat()方法和StringBuilder)的性能差异。实验显示StringBuilder明显更快,这点非常重要,应该作为关键点之一。需要解释为什么会有这样的性能差异,比如String的不可变性导致每次拼接都生成新对象,而StringBuilder则是可变的对象,减少了内存分配和复制的开销。 然后引用[3]讨论了字符串拷贝函数,指出在拷贝指定长度时需要注意手动添加结束符'\0',否则可能导致问题。这可能涉及到C语言中的字符串处理,但用户的问题比较通用,可能需要总结不同编程语言中字符串处理的注意事项,比如不可变性、内存管理、结束符处理等。 另外,用户提供的引用中还有关于环境变量设置的问题(引用[2]),但可能和当前问题关联不大,暂时不考虑。引用[1]关于字符串比较的大小写问题,可能和字符串操作相关,比如比较函数的使用,但用户的问题更侧重于实验总结,所以可能不需要深入这点,除非实验中有涉及比较操作。 需要组织关键点,可能包括字符串不可变性、不同拼接方式的性能差异、内存管理、结束符处理、安全性和编码问题等。结论部分应强调在实际开发中选择合适的字符串操作方法,特别是循环体内使用StringBuilder的重要性。 还要注意用户要求回答结构清晰,分点说明,使用中文,并正确应用LaTeX格式。例如,在提到时间复杂度时,使用$O(n^2)$和$O(n)$这样的数学表达式。同时,生成相关问题,可能涉及优化方法、应用场景、不同语言差异等。 检查是否有遗漏的关键点,比如字符串函数的使用注意事项,比如拷贝时不自动添加结束符,需要手动添加,这也是实验中容易出错的地方。另外,可能要考虑字符串池的概念,或者编码问题如UTF-8处理,但根据引用内容,可能主要围绕性能和内存管理。 总结下来,关键点包括: 1. 字符串不可变性导致的性能问题。 2. 不同拼接方法的性能对比。 3. 字符串操作的内存管理(如结束符处理)。 4. 安全性问题(如缓冲区溢出)。 5. 编码和字符集的影响。 结论要强调实验中的性能差异,并推荐最佳实践,如使用StringBuilder处理大量拼接。</think>### 字符串操作实验总结 #### 关键点分析 1. **字符串拼接性能差异** 在循环体内频繁拼接字符串时,不同方法的性能差异显著: - **`+`运算符**:每次操作会创建新字符串对象,时间复杂度为$O(n^2)$。例如,拼接10,000次耗时约**500ms**。 - **`concat()`方法**:与`+`类似,仍涉及对象频繁创建,但略高效,耗时约**400ms**。 - **`StringBuilder`**:通过可变缓冲区直接追加字符,时间复杂度为$O(n)$,耗时仅约**1ms**,性能提升约**525倍**[^4]。 2. **字符串的不可变性** Java中`String`对象不可变,每次修改都会生成新对象,导致内存浪费和性能损耗。`StringBuilder`通过动态扩展缓冲区避免了这一问题[^4]。 3. **内存管理与结束符处理** 在C语言等底层操作中,手动拷贝字符串需注意**结束符`\0`的添加**,否则可能引发未定义行为。例如,`strncpy()`函数不会自动添加结束符,需显式赋值[^3]。 4. **安全性问题** 直接操作字符数组时,需防范缓冲区溢出风险(如`strcpy`不检查目标缓冲区大小)。应使用安全函数(如`strncpy`)或动态内存分配。 5. **字符集与编码影响** 字符串比较或处理时,字符集(如UTF-8、ASCII)可能影响结果。例如,二进制比较区分大小写,而某些字符集可能不区分[^1]。 #### 实验结论 - **高频拼接场景**:优先选择`StringBuilder`或`StringBuffer`(线程安全版本)。 - **短字符串操作**:`+`或`concat()`可读性更佳,性能影响可忽略。 - **底层操作规范**:手动处理字符串时需严格管理内存和结束符[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值