标签:java string logging concatenation netbeans
我正在我的java-app中创建一个记录器(使用NetBeans作为IDE)突然我看到一个警告说:“在记录器中使用字符串连接效率低下”.
我的oringinal代码是
srcLogger.getLogger().log(Level.INFO,"UploadBean.doUpload completado [" + file.getName() + "]\n");
但NetBeans建议将其转换为模板(这里的“模板”是什么意思?)给出以下代码:
srcLogger.getLogger().log(Level.INFO, "UploadBean.doUpload completado [{0}]\n", file.getName());
这两种连接方式有什么不同,我从来没有使用过后者.
干杯.
解决方法:
我会忽略警告(如果可能的话,如果它关闭则切换).连接并不是那么低效,因为现代编译器用基于StringBuilder的高效实现替换它(如果查看类文件的字节码,你会看到它).
建议的替换不会连接字符串,但它需要一些额外的处理来解析模板并将其与参数合并.
Netbeans,这是一个糟糕的建议.
这适用于Java 1.5.旧版本的Java(可能)在连接期间创建了许多未使用的String实例.
标签:java,string,logging,concatenation,netbeans 来源: https://codeday.me/bug/20191001/1838722.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。