
以下情况:我有很多日志语句,只有在调试模式下才能被执行.
我有两个选项来实现这个:
一个
public voID log(String message){ if(deBUG) dolog(message);}还有很多这样的陈述:
log(something.toString() + "somelogmessage");乙
public voID log(message){ dolog(message);}还有很多这样的陈述:
if(deBUG) log(something.toString() + "somelogmessage");虽然A更好地读取并产生更少的代码,但如果deBUG为false,则B避免字符串连接.
是否值得为性能增益编写这个额外的样板代码?
或者这些是否相等(例如,由于编译器优化)?
解决方法:
正如其他人所提到的那样(并且你已经用你的标签承认),这是一种微观优化,在绝大多数情况下都可能无关紧要.但是,如果您希望避免连接而不会弄乱代码,则可以添加一个接受两个参数的重载:
public voID log(Object prefix, String message){ if(deBUG) dolog(prefix.toString() + message);}然后打电话
log(something, "somelogmessage");如果您的消息可以由多个值组成,则可以使用varargs:
public voID log(String... values){ if(deBUG) dolog(String.join("", values));}虽然在这种情况下性能优势更值得怀疑.
总结以上是内存溢出为你收集整理的java – 字符串连接的性能如何?全部内容,希望文章能够帮你解决java – 字符串连接的性能如何?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)