NO.76 代码优化初步 3.一些代码优化小技巧

一、用串中搜索变量替换大量变量判断

以下修改方式将运算减少至2次。

【原始代码】

if(!(kindCode.equals("050900")||kindCode.equals("050911")||kindCode.equals("050912")||kindCode.equals("050928")||kindCode.equals("050929")||kindCode.equals("050921")||kindCode.equals("050922")||kindCode.equals("050925")||kindCode.equals("050923")||kindCode.equals("050924")||kindCode.equals("050926")))

【优化参考方案】

if(("050900, 050911, 050912, 050928, 050929, 050921, 050922, 050925, 050923, 050924, 050926").indexOf(kindCode)==-1)

 

二、一种复杂度3n变n的拼分隔符优化算法、大量拼串应使用StringBuilder

【原始代码】

rateCode = "";
for (int j = 0; j < ratecode1.length; j++) {
	if (j == ratecode1.length - 1) {
		rateCode = rateCode + ratecode1[j];
	} else {
		rateCode = rateCode + ratecode1[j] + ",";
	}

}

【优化参考方案】

rateCode = "";
StringBuilder builder = new StringBuilder(128);
for (int j = 0; j < ratecode1.length; j++) {
	builder.append(",").append(ratecode1[j]);
}
rateCode = builder.substring(1);

由于for循环中少一次判断运算及(ratecode1.length - 1),因此整体复杂度降为n;关于StringBuilder拼串与String直接接串的性能对比资料可网上搜索,在此不做详述。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值