检查以下代码是否有问题: StringBuilder info = new StringBuilder(); if (CollectionUtils.isNotEmpty(adminCreateVO.getSalaryGroupResourceList())){ for (SalaryGroupResourceVO salaryGroupResourceVO : adminCreateVO.getSalaryGroupResourceList()) { StringBuilder salaryGroupName = new StringBuilder("【" + salaryGroupMap.get(salaryGroupResourceVO.getSalaryGroupId()) + "】"); for (SalaryGroupIdentityVO resourceIdentity : salaryGroupResourceVO.getResourceIdentities()) { if (!Objects.equals(resourceIdentity.getName(), SalaryGlobalConstants.PAYROLL_GROUP_MANAGEMENT_SALARY_APPROVAL)){ salaryGroupName.append(resourceIdentity.getName()).append("、"); } } info.append(salaryGroupName.substring(0, salaryGroupName.length() - 1)).append(";"); } }

时间: 2024-04-20 09:26:28 浏览: 20
代码看起来没有明显的语法错误,但可能存在逻辑上的问题。以下是一些需要注意的地方: 1. `CollectionUtils.isNotEmpty()`是Apache Commons Collections库中的方法,用于检查集合是否不为空。请确保你已经导入了正确的库,并正确使用该方法。 2. 在循环中,你使用了`salaryGroupMap.get(salaryGroupResourceVO.getSalaryGroupId())`来获取`salaryGroupId`对应的值。请确保`salaryGroupMap`已经被正确初始化,并且包含了所需的键值对。 3. 在`salaryGroupName.append(resourceIdentity.getName()).append("、")`这一行,你将每个`resourceIdentity.getName()`都添加到了`salaryGroupName`中,并在后面添加了一个逗号。但请注意,在最后一个元素后面不需要添加逗号。因此,在使用`info.append(salaryGroupName.substring(0, salaryGroupName.length() - 1)).append(";")`之前,你应该检查一下`salaryGroupName`的长度是否大于1,以避免出现空指针异常。 希望这些提示对你有帮助!如果你有任何其他问题,请随时提问。
相关问题

fun getAddressFromLocation(context: Context,latitude: Double, longitude: Double): String? { val geocoder = Geocoder(context, Locale.getDefault()) val addresses: List<Address>? var addressText = "" try { addresses = geocoder.getFromLocation(latitude, longitude, 1) if (addresses != null && addresses.isNotEmpty()) { val address = addresses[0] val sb = StringBuilder() for (i in 0..address.maxAddressLineIndex) { sb.append(address.getAddressLine(i)).append("\n") } addressText = sb.toString().trim() } } catch (e: IOException) { e.printStackTrace() } return addressText }这个代码如何只获取市

您可以在获取地址的循环中判断地址的类型,如果是市级地址,就只获取对应的部分即可。以下是修改后的代码示例: ```kotlin fun getCityFromLocation(context: Context, latitude: Double, longitude: Double): String? { val geocoder = Geocoder(context, Locale.getDefault()) val addresses: List<Address>? var city = "" try { addresses = geocoder.getFromLocation(latitude, longitude, 1) if (addresses != null && addresses.isNotEmpty()) { val address = addresses[0] val sb = StringBuilder() for (i in 0..address.maxAddressLineIndex) { val addressLine = address.getAddressLine(i) if (addressLine.contains("市")) { city = addressLine break } } } } catch (e: IOException) { e.printStackTrace() } return city } ``` 在上述代码中,我添加了一个判断,如果地址中包含"市"字,就将该地址赋值给city变量并跳出循环。这样就只获取了市级地址。注意,这里假设返回的地址列表中第一个地址就是最精确的地址,如果需要更多精确度,请根据实际情况进行调整。

两个集合的数据有上万条,导出内存溢出,请将下面的代码优化 for (int i = 0; i <ls.size() ; i++) { Map<String,Object> sb1=new HashMap<>(); Map<String,Object> sb2=new HashMap<>(); boolean sbboolean1=false; boolean sbboolean2=false; for (int j = 0; j <list2.size() ; j++) { if(StringUtils.isNotEmpty(ls.get(i).getSalesorder())&&StringUtils.isNotEmpty(list2.get(j).getSalesorder())){ if(ls.get(i).getSalesorder().trim().equals(list2.get(j).getSalesorder().trim())){ if(StringUtils.isNotEmpty(list2.get(j).getDeliveryresponse())){ sbboolean1=true; sb1.put(list2.get(j).getDeliveryresponse().trim(),null); } if(StringUtils.isNotEmpty(list2.get(j).getOrderdate())){ sbboolean2=true; sb2.put(list2.get(j).getOrderdate().trim(),null); } } } } if(sbboolean1){ StringBuilder sbdate1=new StringBuilder(); for (String s:sb1.keySet()) { sbdate1.append(s+" "); } ls.get(i).setLowmaterialstatusb(sbdate1.toString()); } if(sbboolean2){ StringBuilder sbdate2=new StringBuilder(); for (String s:sb2.keySet()) { sbdate2.append(s+" "); } ls.get(i).setLowmaterialstatus(sbdate2.toString()); } }

这段代码可以进行以下优化: 1. 避免在循环中频繁调用 `ls.get(i)` 和 `list2.get(j)` 方法,可以先将它们的值存储在变量中: ``` for (int i = 0; i < ls.size(); i++) { Map<String, Object> sb1 = new HashMap<>(); Map<String, Object> sb2 = new HashMap<>(); boolean sbboolean1 = false; boolean sbboolean2 = false; Object salesorder1 = ls.get(i).getSalesorder(); if (StringUtils.isNotEmpty(salesorder1)) { String salesorder1Trim = salesorder1.toString().trim(); for (int j = 0; j < list2.size(); j++) { Object salesorder2 = list2.get(j).getSalesorder(); if (StringUtils.isNotEmpty(salesorder2)) { String salesorder2Trim = salesorder2.toString().trim(); if (salesorder1Trim.equals(salesorder2Trim)) { Object deliveryresponse = list2.get(j).getDeliveryresponse(); if (StringUtils.isNotEmpty(deliveryresponse)) { sbboolean1 = true; sb1.put(deliveryresponse.toString().trim(), null); } Object orderdate = list2.get(j).getOrderdate(); if (StringUtils.isNotEmpty(orderdate)) { sbboolean2 = true; sb2.put(orderdate.toString().trim(), null); } } } } } // ... } ``` 2. 如果 `sb1` 和 `sb2` 中存储的值只需要是键的集合,可以使用 `HashSet` 代替 `HashMap`,避免在循环中频繁创建和销毁 value 对象: ``` for (int i = 0; i < ls.size(); i++) { Set<String> sb1 = new HashSet<>(); Set<String> sb2 = new HashSet<>(); boolean sbboolean1 = false; boolean sbboolean2 = false; Object salesorder1 = ls.get(i).getSalesorder(); if (StringUtils.isNotEmpty(salesorder1)) { String salesorder1Trim = salesorder1.toString().trim(); for (int j = 0; j < list2.size(); j++) { Object salesorder2 = list2.get(j).getSalesorder(); if (StringUtils.isNotEmpty(salesorder2)) { String salesorder2Trim = salesorder2.toString().trim(); if (salesorder1Trim.equals(salesorder2Trim)) { Object deliveryresponse = list2.get(j).getDeliveryresponse(); if (StringUtils.isNotEmpty(deliveryresponse)) { sbboolean1 = true; sb1.add(deliveryresponse.toString().trim()); } Object orderdate = list2.get(j).getOrderdate(); if (StringUtils.isNotEmpty(orderdate)) { sbboolean2 = true; sb2.add(orderdate.toString().trim()); } } } } } // ... } ``` 3. 如果需要把 `sb1` 和 `sb2` 中的值拼接成字符串并赋值给对象的属性,可以直接使用 `String.join()` 方法,避免使用 `StringBuilder`: ``` for (int i = 0; i < ls.size(); i++) { Set<String> sb1 = new HashSet<>(); Set<String> sb2 = new HashSet<>(); boolean sbboolean1 = false; boolean sbboolean2 = false; Object salesorder1 = ls.get(i).getSalesorder(); if (StringUtils.isNotEmpty(salesorder1)) { String salesorder1Trim = salesorder1.toString().trim(); for (int j = 0; j < list2.size(); j++) { Object salesorder2 = list2.get(j).getSalesorder(); if (StringUtils.isNotEmpty(salesorder2)) { String salesorder2Trim = salesorder2.toString().trim(); if (salesorder1Trim.equals(salesorder2Trim)) { Object deliveryresponse = list2.get(j).getDeliveryresponse(); if (StringUtils.isNotEmpty(deliveryresponse)) { sbboolean1 = true; sb1.add(deliveryresponse.toString().trim()); } Object orderdate = list2.get(j).getOrderdate(); if (StringUtils.isNotEmpty(orderdate)) { sbboolean2 = true; sb2.add(orderdate.toString().trim()); } } } } } if (sbboolean1) { ls.get(i).setLowmaterialstatusb(String.join(" ", sb1)); } if (sbboolean2) { ls.get(i).setLowmaterialstatus(String.join(" ", sb2)); } } ```

相关推荐

优化这段java代码: private void dealWitchCaseNo(Map<String, String[]> paramsMap,User user) { try { if(paramsMap.containsKey("case_no_year") || paramsMap.containsKey("case_no_middle") || paramsMap.containsKey("case_no_tail")){ StringBuilder caseNo = new StringBuilder(); StringBuilder caseNoSource = new StringBuilder(); String[] yearArray = paramsMap.get("case_no_year"); String[] daiZiArray = paramsMap.get("case_no_middle"); String[] xhArray = paramsMap.get("case_no_tail"); //标准案号查询 if(ArrayUtil.isNotEmpty(yearArray)&&ArrayUtil.isNotEmpty(daiZiArray)&&ArrayUtil.isNotEmpty(xhArray)){ caseNo.append(yearArray[0]+"年最高法"+daiZiArray[0]+"字第"+xhArray[0]+"号"); caseNoSource.append("("+yearArray[0]+")最高法"+daiZiArray[0]+xhArray[0]+"号"); }else{ //模糊查询 if(ArrayUtil.isNotEmpty(yearArray)){ caseNo.append(yearArray[0]); } if(ArrayUtil.isNotEmpty(daiZiArray)){ if(ArrayUtil.isNotEmpty(yearArray)){ caseNo.append("年最高法"+daiZiArray[0]); caseNoSource.append(yearArray[0]+")最高法"+daiZiArray[0]); }else if(ArrayUtil.isNotEmpty(xhArray)){ caseNo.append(daiZiArray[0]+"字第"); caseNoSource.append(daiZiArray[0]+xhArray[0]); }else { caseNo.append(daiZiArray[0]); } saveUsuallyUse(daiZiArray[0], user); } if(ArrayUtil.isNotEmpty(xhArray)){ caseNo.append(xhArray[0]); } } paramsMap.remove("case_no_year"); paramsMap.remove("case_no_middle"); paramsMap.remove("case_no_tail"); if(caseNo.length()>0) { String condition = ""; if (ArrayUtil.isNotEmpty(paramsMap.get("condition"))) { condition = paramsMap.get("condition")[0] + " and case_no like '%" + caseNo.toString() + "%'"; if(caseNoSource.length()>0) condition = paramsMap.get("condition")[0] + " and (case_no like '%" + caseNo.toString() + "%' or case_no like '%" + caseNoSource.toString() + "%')"; } else { condition = " and case_no like '" + caseNo.toString() + "' "; if(caseNoSource.length()>0) condition = " and (case_no like '" + caseNo.toString() + "' or case_no like '%" + caseNoSource.toString() + "%')"; } paramsMap.put("condition",new String[]{condition}; } } } catch (Exception e) { e.printStackTrace(); } }

@Transactional(rollbackFor = Exception.class) public void IntendedSignHandle(IntendedSignReq intendedSignReq, Map<String, IntentionEquResp> intentionEquRespMap, SaleStateEnum currentSaleStateEnum, SaleStateEnum goalSaleStateEnum) { StringBuilder message = new StringBuilder(); List<EquMarketablePrice> updateMarketablePriceList = new ArrayList<>(); for (String equNo : intendedSignReq.getEquNoList()) { Optional.ofNullable(intentionEquRespMap.get(equNo)).ifPresent(intentionEquResp -> { // 构建更新对象 if (intentionEquResp.getSaleState().equals(currentSaleStateEnum.getCode())) { EquMarketablePrice updateEquMarketablePrice = new EquMarketablePrice(); updateEquMarketablePrice.setId(intentionEquResp.getId()); updateEquMarketablePrice.setSaleState(goalSaleStateEnum.getCode()); updateEquMarketablePrice.setEditBy(intendedSignReq.getOperatorAd()); updateEquMarketablePrice.setEditByName(intendedSignReq.getOperatorName()); updateMarketablePriceList.add(updateEquMarketablePrice); } else { message.append(String.format("[%s] 当前意向状态[%s] 非[%s]状态,无法标记[%s]状态,请与资产方向确认", equNo, SaleStateEnum.getDescByCode(intentionEquResp.getSaleState()), currentSaleStateEnum.getDesc(), goalSaleStateEnum.getDesc())).append("\n"); } }); } if (CollectionUtils.isNotEmpty(updateMarketablePriceList)) { equMarketablePriceService.updateBatchById(updateMarketablePriceList, Constant.ONE_HUNDRED); } TransactionSynchronizationManager.registerSynchronization(new TransactionSynchronizationAdapter() { @Override public void afterCommit() { if (StringUtils.isBlank(message) ) { return; } String errorMessage = message.toString(); log.info(errorMessage); if (Boolean.TRUE.equals(intendedSignSwitch)) { alarmService.alarm("意向标记失败", errorMessage); } } }); } 允许报这个错java.lang.IllegalStateException: Transaction synchronization is not active

String singleSend = (String) map.get("singleSend"); String expressProductCode = (String) map.get("expressProductCode"); LinkedHashMap<String,String> senderInformation = (LinkedHashMap<String,String>)map.get("senderInformation"); String senderName = senderInformation.get("label"); String senderPhone = senderInformation.get("value"); String productName = (String) map.get("productName"); if("1".equals(singleSend)) { for(Map<String, String> oo : list ) { String receiverName = oo.get("receiverName"); String receiverPhone = oo.get("receiverPhone"); String contactAddress = oo.get("contactAddress"); String orderNos = oo.get("orderNo"); OrderApiCreate orderApiCreate = genParam(expressProductCode,productName,senderName,senderPhone,receiverName,receiverPhone,contactAddress,"1", orderNos); String ret = apiUtil.createOrder(orderApiCreate); LoginUser loginUser = SecurityUtils.getLoginUser(); OrderInfo orderinfo = new OrderInfo(); orderinfo.setUpdateBy(loginUser.getUsername()); orderinfo.setApiOrderNo(orderApiCreate.getOrderNumber()); if(StringUtils.isNotEmpty(ret)) { orderinfo.setSendError(ret); orderinfo.setSendState("3"); orderinfo.setSendCount(0); } else { orderinfo.setSendState("2"); } orderService.updateApiSendInfo(new String[]{String.valueOf(oo.get("uuid"))}, orderinfo); } } else { String receiverName = (String) map.get("receiverName"); String receiverPhone = (String) map.get("receiverPhone"); String contactAddress = (String) map.get("contactAddress"); String productNumber = String.valueOf(uuids.length); String orderNos = list.stream().map(item->String.valueOf(item.get("orderNo"))).collect(Collectors.joining(",")); OrderApiCreate orderApiCreate = genParam(expressProductCode,productName,senderName,senderPhone,receiverName,receiverPhone,contactAddress,productNumber, orderNos); String ret = apiUtil.createOrder(orderApiCreate); LoginUser loginUser = SecurityUtils.getLoginUser(); OrderInfo orderinfo = new OrderInfo(); orderinfo.setUpdateBy(loginUser.getUsername()); orderinfo.setApiOrderNo(orderApiCreate.getOrderNumber()); if(StringUtils.isNotEmpty(ret)) { orderinfo.setSendError(ret); orderinfo.setSendState("3"); orderinfo.setSendCount(0); } else { orderinfo.setSendState("2"); } orderService.updateApiSendInfo(uuids, orderinfo); } apiUtil.getOrderSendState(); return AjaxResult.success(result);优化这段代码

最新推荐

recommend-type

基于Selenium的Java爬虫实战(内含谷歌浏览器Chrom和Chromedriver版本116.0.5808.0)

资源包括: 1.Java爬虫实战代码 2.selenium学习笔记 3.代码演示视频 4.谷歌浏览器chrom116.0.5808.0 chrome-linux64.zip chrome-mac-arm64.zip chrome-mac-x64.zip chrome-win32.zip chrome-win64.zip 5.谷歌浏览器驱动器Chromedriver116.0.5808.0 chromedriver-linux64.zip chromedriver-mac-arm64.zip chromedriver-mac-x64.zip chromedriver-win32.zip chromedriver-win64.zip 特别说明:Chrome 为测试版(不会自动更新) 仅适用于自动测试。若要进行常规浏览,请使用可自动更新的标准版 Chrome。)
recommend-type

2024消费趋势报告.pdf

2024消费趋势报告.pdf
recommend-type

PCB的电磁兼容设计+电子设计领域

1、EMC由EMI和EMS组成 2、EMS常见的整改措施 3、干扰=共模干扰+差模干扰 4、元器件的摆放 5、缝隙影响
recommend-type

给排水施工图全套.xdw.pdf

给排水施工图全套.xdw
recommend-type

基于微信小程序的旅游出行必备(后端接口ssm框架实现)-毕设项目

毕业设计基于微信小程序的旅游出行必备(后端接口ssm框架实现)-毕设项目.zip 个人经导师指导并认可通过的高分设计项目,评审分98分。主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 项目介绍: 旅游出行必备项目, 前端为微信小程序,后端接口为ssm框架实现,项目包含源码、数据库毕业设计基于微信小程序的旅游出行必备(后端接口ssm框架实现)-毕设项目.zip 个人经导师指导并认可通过的高分设计项目,评审分98分。主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 项目主要功能: 该项目是一个基于微信小程序的旅游出行应用,结合后端SSM(Spring MVC + Spring + MyBatis)框架提供服务。主要功能包括行程规划、景点信息查询、在线预订等,旨在为用户提供便捷的旅游出行体验。特点在于利用微信小程序的便捷性,实现即用即走,同时通过后端强大的数据处理能力保证服务稳定性。技术栈涵盖微信小程序开发、Java SSM框架、数据库管理等,适合学习和作为毕业设计参考。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB正态分布协方差分析:揭示正态分布变量之间的协方差

![MATLAB正态分布协方差分析:揭示正态分布变量之间的协方差](https://site.cdn.mengte.online/official/2021/11/20211128213137293.png) # 1. 正态分布概述 正态分布,又称高斯分布,是统计学中最重要的连续概率分布之一。它广泛应用于自然科学、社会科学和工程领域。 正态分布的概率密度函数为: ``` f(x) = (1 / (σ√(2π))) * exp(-(x - μ)² / (2σ²)) ``` 其中: - μ:正态分布的均值 - σ:正态分布的标准差 - π:圆周率 正态分布具有以下特性: - 对称性:
recommend-type

我正在开发一款个人碳足迹计算app,如何撰写其需求分析文档,请给我一个范例

为了更全面、清晰地定义个人碳足迹计算app的需求,需求分析文档应该包含以下内容: 1.项目简介:对该app项目的概述及目标进行说明。 2.用户分析:包括目标用户群、用户需求、行为等。 3.功能需求:对app的基本功能进行定义,如用户登录、数据录入、数据统计等。 4.非功能需求:对使用app的性能和质量等进行定义,如界面设计、数据安全、可扩展性等。 5.运行环境:包括app的开发环境和使用环境。 下面是一个范例: 需求分析文档 1. 项目简介 该app项目旨在为用户提供一款方便、易用、可定制的个人碳足迹计算平台,以促进环保和可持续性发展。 2. 用户分析 目标用户群:全球关
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。