StringBuffer类和StringBuilder类

本文对比分析了StringBuffer和StringBuilder两个类的特点与应用场景,并详细介绍了它们的常用方法,包括append()、insert()、capacity()等。

StringBuffer类和StringBuilder类

StringBuffer类

  • 线程安全的可变字符序列。一个类似于 String 的字符串缓冲区,但不能修改。虽然在任意时间点上它都包含某种特定的字符序列,但通过某些方法调用可以改变该序列的长度和内容。
特点
  1. 可变字符序列
  2. 线程安全(因为多线程)
  3. 效率低

StringBuilder类

  • 一个可变的字符序列。此类提供一个与 StringBuffer 兼容的 API,但不保证同步。该类被设计用作 StringBuffer 的一个简易替换,用在字符串缓冲区被单个线程使用的时候(这种情况很普遍)。如果可能,建议优先采用该类,因为在大多数实现中,它比 StringBuffer 要快。
特点
  1. 可变字符序列
  2. 线程不安全(单线程)
  3. 效率高

常用方法:这两个类方法相同

  • append():添加字符到缓冲区的末端
StringBuffer sb = new StringBuffer();
//参数类型很多
sb.append(12);
sb.append('A');
sb.append("abc");
sb.append(true);
sb.append(45.5);
sb.append(new StringBuffer().append("你好"));
System.out.println(sb);//12Aabctrue45.5你好
  • insert():在指定索引出添加字符
StringBuffer sb = new StringBuffer();
//参数类型很多
sb.append("abcdefg");
sb.insert(0,'A');
sb.insert(1,"BB");
sb.insert(3,88);
sb.insert(6,true);
sb.insert(10,11.11);
sb.insert(sb.length(),"末尾");
System.out.println(sb);//ABB88atrue11.11bcdefg末尾
  • capacity():返回该字符串缓冲区的容量
StringBuffer sb = new StringBuffer();
//参数类型很多
int num = sb.capacity();
System.out.println(num);//默认容量为16个字符
sb.append("123456789");
int num1 = sb.capacity();
System.out.println(num1);//小于默认容量的按默认容量算16
sb.append("12345678900000000000000000");
int num2 = sb.capacity();
System.out.println(sb.length());//35
System.out.println(num2);//35
  • chatAt(int index):返回指定索引出的字符
StringBuffer sb = new StringBuffer();
sb.append(123456);
char c = sb.charAt(0);
System.out.println(c);//1
  • delete(int start, int end):删除指定范围内的字符串
StringBuffer sb = new StringBuffer();
sb.append(123456);
sb = sb.delete(2,4);//包含2处的字符,不包含4处的字符
System.out.println(sb);//1256
  • deleteCharAt(int index):删除指定索引处的字符
StringBuffer sb = new StringBuffer();
sb.append(123456);
sb = sb.deleteCharAt(5);
System.out.println(sb);//12345
  • indexof(String str):返回第一次出现该字符串的索引
StringBuffer sb = new StringBuffer();
sb.append(12345634);
int index = sb.indexOf("34");
System.out.println(index);//2
  • lastIndexOf(String str):返回最后一次出现该字符串的索引
StringBuffer sb = new StringBuffer();
sb.append(12345634);
int index = sb.lastIndexOf("34");
System.out.println(index);//6
  • replace(int start, int end, String str):用指定字符串替换指定范围内的字符串
StringBuffer sb = new StringBuffer();
sb.append(12345634);
sb = sb.replace(6,sb.length(),"78");
System.out.println(sb);//12345678
  • subSequence(int start, int end):截取指定范围内的字符序列,返回一个新的字符序列
StringBuffer sb = new StringBuffer();
sb.append(12345634);
CharSequence charSequence = sb.subSequence(3, 6);
System.out.println(charSequence);//456
  • subString():从指定索引处开始或从指定范围内截取字符串,返回一个字符串
StringBuffer sb = new StringBuffer();
sb.append(12345634);
String str = sb.substring(3, 6);
System.out.println(str);//456
(Kriging_NSGA2)克里金模型结合多目标遗传算法求最优因变量及对应的最佳自变量组合研究(Matlab代码实现)内容概要:本文介绍了克里金模型(Kriging)与多目标遗传算法NSGA-II相结合的方法,用于求解最优因变量及其对应的最佳自变量组合,并提供了完整的Matlab代码实现。该方法首先利用克里金模型构建高精度的代理模型,逼近复杂的非线性系统响应,减少计算成本;随后结合NSGA-II算法进行多目标优化,搜索帕累托前沿解集,从而获得多个最优折衷方案。文中详细阐述了代理模型构建、算法集成流程及参数设置,适用于工程设计、参数反演等复杂优化问题。此外,文档还展示了该方法在SCI一区论文中的复现应用,体现了其科学性与实用性。; 适合人群:具备一定Matlab编程基础,熟悉优化算法数值建模的研究生、科研人员及工程技术人员,尤其适合从事仿真优化、实验设计、代理模型研究的相关领域工作者。; 使用场景及目标:①解决高计算成本的多目标优化问题,通过代理模型降低仿真次数;②在无法解析求导或函数高度非线性的情况下寻找最优变量组合;③复现SCI高水平论文中的优化方法,提升科研可信度与效率;④应用于工程设计、能源系统调度、智能制造等需参数优化的实际场景。; 阅读建议:建议读者结合提供的Matlab代码逐段理解算法实现过程,重点关注克里金模型的构建步骤与NSGA-II的集成方式,建议自行调整测试函数或实际案例验证算法性能,并配合YALMIP等工具包扩展优化求解能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值