lambda表达式 StringBuilder

时间: 2023-11-07 07:53:56 浏览: 55
在Kotlin中,lambda表达式是一种函数式编程的特性,它可以作为参数传递给其他函数或方法。Kotlin中的lambda表达式可以分为普通的lambda表达式和带接收者的lambda表达式两种类型。普通的lambda表达式没有接收者,而带接收者的lambda表达式可以在lambda体内访问接收者对象的成员。 Kotlin中的lambda表达式具有真正的闭包特性,与Java中的lambda表达式相比更加灵活,访问的限制也更少。这是因为Kotlin中的lambda表达式会自动捕获外部的变量,使得在lambda表达式内部可以访问和修改这些变量。 在Kotlin中,lambda表达式的变量捕获是通过将外部变量包装成一个对象,并将该对象作为lambda表达式的隐藏参数来实现的。这样,在lambda表达式内部就可以访问和修改这些变量了。 在Kotlin中,lambda表达式的返回值是自动推断的。如果lambda表达式的最后一个表达式是一个返回值,那么这个返回值就是lambda表达式的返回值。 回答完问题后的
相关问题

实验I中,只需要根据以下的词法规则,实现Lexer类中的nextToken()方法,成功解析字符串的tokentype序列即可。 ``` public enum TokenType { //注意:输入中的所有空格应该忽略 EOF,//标识lambda表达式的结束 LAMBDA,// '\',即lambda表达式中的lambda,注意转义 LPAREN,// 左括号 RPAREN,// 右括号 LCID,// 标识符,要求小写字母开头,大写或小写字母组成 DOT// lambda表达式中的'.' } ``` ​ Lexer类的构造函数需要接收一个待解析的String类型lambda表达式,该类的构造函数与成员变量均可自行设计,只要保证nextToken()方法输出指定的结果即可。 ​ nextToken()方法需要解析出字符串表达式的未解析的下一个token,**需要换行打印**并返回解析出的TokenType,测试中会检查输出的TokenType序列是否正确。 比如: ```java String ZERO = "(\\f.\\x.x)"; ``` ​ 此时第一个未解析的字符是"(",它需要被解析为LPAREN,输出出来。 ​ 需要注意的是,lexer被parser调用时,对于LCID类型的token,不仅需要得到待解析token的类型,还需要得到待解析token的内容,这点并不影响实验I的实现,但在设计时可能需要考虑这点。 ​ 除了nextToken()方法外,在Lexer类中还提供了三个待实现的工具方法next(),match()与return(),在接下来的实验中提供给parser调用,请自行阅读注解,**本次作业可以酌情实现** **编写建议** ```java public class Lexer{ public TokenType token; public String tokenvalue; //........ } ```

根据词法规则,我们可以先定义一些常量,例如: ```java public class Lexer { private final String input; // 待解析的字符串 private int pos = 0; // 当前字符的索引 private char currentChar; // 当前字符 // TokenType常量 private static final TokenType EOF = TokenType.EOF; private static final TokenType LAMBDA = TokenType.LAMBDA; private static final TokenType LPAREN = TokenType.LPAREN; private static final TokenType RPAREN = TokenType.RPAREN; private static final TokenType LCID = TokenType.LCID; private static final TokenType DOT = TokenType.DOT; // 构造函数 public Lexer(String input) { this.input = input.replaceAll("\\s", ""); // 去除空格 this.currentChar = this.input.charAt(pos); } // 工具方法next(),返回当前字符并将pos指针后移 private char next() { pos++; if (pos > input.length() - 1) { currentChar = '\0'; // 到达字符串结尾 } else { currentChar = input.charAt(pos); } return currentChar; } // 工具方法match(),如果当前字符匹配上了传入的字符,则将pos指针后移 private void match(char c) { if (currentChar == c) { next(); } else { throw new IllegalArgumentException("Unexpected character: " + currentChar); } } // 工具方法return(),将pos指针回退一格 private void returnBack() { pos--; currentChar = input.charAt(pos); } // 解析下一个token public TokenType nextToken() { while (currentChar != '\0') { if (currentChar == '\\') { match('\\'); return LAMBDA; } else if (currentChar == '(') { match('('); return LPAREN; } else if (currentChar == ')') { match(')'); return RPAREN; } else if (Character.isLowerCase(currentChar)) { StringBuilder sb = new StringBuilder(); while (Character.isLetterOrDigit(currentChar)) { sb.append(currentChar); next(); } returnBack(); return LCID; } else if (currentChar == '.') { match('.'); return DOT; } else { throw new IllegalArgumentException("Unexpected character: " + currentChar); } } return EOF; } } ``` 在Lexer类中,我们定义了一个input成员变量,用于存储待解析的字符串。在构造函数中,我们去除了所有空格,方便后续解析。我们还定义了三个工具方法next()、match()和return(),用于parser调用。其中,next()方法返回当前字符并将pos指针后移,match()方法判断当前字符是否匹配传入的字符,如果匹配则将pos指针后移,否则抛出异常。return()方法将pos指针回退一格。 在解析下一个token时,我们依次判断当前字符的类型,如果匹配上了就返回对应的TokenType。如果是LCID类型的token,需要使用StringBuilder来依次读取所有的字母和数字,直到遇到非字母数字字符为止。最后,我们使用returnBack()方法将pos指针回退一格,因为在读取完LCID后,当前字符是非字母数字字符,需要重新解析该字符。如果当前字符不匹配任何类型,则抛出异常。 注意,在判断LCID时,我们使用了while循环来读取所有的字母和数字,因此需要在循环结束后调用returnBack()方法将pos指针回退一格。否则,如果下一个字符是非字母数字字符,就会误判为新的token类型。

for (CommodityVO good : goods) { StringBuilder name = new StringBuilder(good.getName()); if (StringUtil.isNotBlank(good.getData()) || StringUtil.isNotBlank(good.getAttribute()) || StringUtil.isNotBlank(good.getMaterial())){ name.append("("); } if ((StringUtil.isNotBlank(good.getData()) && StringUtil.isNotBlank(good.getAttribute())) || (StringUtil.isNotBlank(good.getData()) && StringUtil.isNotBlank(good.getMaterial()))) { name.append(good.getData()).append("、"); }else{ name.append(good.getData()); } if (StringUtil.isNotBlank(good.getAttribute()) && StringUtil.isNotBlank(good.getMaterial())) { name.append(good.getAttribute()).append("、"); }else { name.append(good.getAttribute()); } if (StringUtil.isNotBlank(good.getMaterial())) { String[] list = good.getMaterial().split(","); if (list.length > 1){ String join = String.join("/", list); name.append(join); }else { name.append(good.getMaterial()); } } if (StringUtil.isNotBlank(good.getData()) || StringUtil.isNotBlank(good.getAttribute()) || StringUtil.isNotBlank(good.getMaterial())){ name.append(")"); } if (!ObjectUtil.isEmpty(good.getVipMoney())) { good.setMoney(good.getVipMoney()); }}怎么优化更简洁

可以使用 Java 8 的 Stream API 和 Lambda 表达式来简化代码,如下所示: ``` goods.forEach(good -> { StringBuilder name = new StringBuilder(good.getName()); if (Stream.of(good.getData(), good.getAttribute(), good.getMaterial()).anyMatch(StringUtil::isNotBlank)) { name.append("("); } if (StringUtil.isNotBlank(good.getData())) { name.append(good.getData()); if (StringUtil.isNotBlank(good.getAttribute()) || StringUtil.isNotBlank(good.getMaterial())) { name.append("、"); } } if (StringUtil.isNotBlank(good.getAttribute())) { name.append(good.getAttribute()); if (StringUtil.isNotBlank(good.getMaterial())) { name.append("、"); } } if (StringUtil.isNotBlank(good.getMaterial())) { String[] list = good.getMaterial().split(","); if (list.length > 1) { name.append(String.join("/", list)); } else { name.append(good.getMaterial()); } } if (Stream.of(good.getData(), good.getAttribute(), good.getMaterial()).anyMatch(StringUtil::isNotBlank)) { name.append(")"); } if (!ObjectUtil.isEmpty(good.getVipMoney())) { good.setMoney(good.getVipMoney()); } }); ``` 使用 Stream API 和 Lambda 表达式可以使代码更加简洁易读,同时还可以提高代码的运行效率。

相关推荐

jdk8 优化以下代码: for (DqExecuteResult dqExecuteResult : dqExecuteResults) { String errorOutputPath = dqExecuteResult.getErrorOutputPath(); Path path = new Path(errorOutputPath); R> getFileResult = resourceClient.getFilesAtPath(path.toUri().getPath()); if (null != getFileResult && getFileResult.isSuccess()) { for (String fullPath : getFileResult.getData()) { R> previewResult = resourceClient.viewFileByPath(new Path(fullPath).toUri().getPath(), query.getCurrent(), query.getSize(), "\n"); if (null != previewResult && previewResult.isSuccess()) { if("原始库".equals(datasourceName)){ Long datasourceId = iDataSourceClient.queryRawDataSource().getId(); List<MetaColumn> tableColumns = iDataSourceMetaClient.getTableColumns(datasourceId, tableName); for (MetaColumn metaColumn : tableColumns){ headers.add(metaColumn.getColumnName()); } } else if("标准库".equals(datasourceName)){ Long datasourceId = iDataSourceClient.queryModelDataSource().getId(); List<MetaColumn> tableColumns = iDataSourceMetaClient.getTableColumns(datasourceId, tableName); for (MetaColumn metaColumn : tableColumns){ headers.add(metaColumn.getColumnName()); } } int headerSize = headers.size(); List<String> datas = previewResult.getData(); StringBuilder contextBuilder = new StringBuilder(); for(String data : datas){ contextBuilder.append(data.replaceAll("[\r\n\t]", " ")); contextBuilder.append("\n"); } StringReader reader = new StringReader(contextBuilder.toString()); Iterable<CSVRecord> records = CSVFormat.DEFAULT.parse(reader); for (CSVRecord record : records) { if (record.size() == headerSize){ List<String> content = new ArrayList<>(); for (String column : record) { content.add(column); } contents.add(content); } } } } } }

优化这段代码public static void readExcel(String fileName) { List<Version> versions = EasyExcel.read(fileName, Version.class, null).sheet("版本号").doReadSync(); List tableInfoList = EasyExcel.read(fileName, TableInfo.class, null).sheet("数据库&数据表").doReadSync(); List tableFieldList = EasyExcel.read(fileName, TableField.class, null).sheet("字段").doReadSync(); List<HopIndex> hopIndexList = EasyExcel.read(fileName, HopIndex.class, null).sheet("跳数索引").doReadSync(); Map<String, List> tableInfoMap = tableInfoList.stream().collect(Collectors.groupingBy(TableInfo::getEnDataBaseName)); Map<String, List> tableFieldMap = tableFieldList.stream().collect(Collectors.groupingBy(TableField::getEnTableName)); Map<String, List<HopIndex>> hopIndexMap = hopIndexList.stream().collect(Collectors.groupingBy(HopIndex::getEnTableName)); List tableInfos1 = new ArrayList<>(); List tableInfos2 = new ArrayList<>(); tableInfoMap.forEach((dbName, tableList) -> { if (tableList.size() < 200) { tableInfos1.addAll(tableList); } else { tableInfos2.addAll(tableList); } }); List tableFields = new ArrayList<>(); List<HopIndex> hopIndex = new ArrayList<>(); for (TableInfo tableInfo : tableInfos1) { String enTableName = tableInfo.getEnTableName(); tableFields.addAll(tableFieldMap.get(enTableName)); List<HopIndex> hops = hopIndexMap.get(enTableName); if (hops !=null){ hopIndex.addAll(hops); } } String name = filepath + File.separator + "明细层_V1.0_" + DateUtil.date().toString(DatePattern.PURE_DATE_PATTERN) + "1.xls"; ExcelWriter excelWriter = EasyExcel.write(name).build(); ExcelUtil.writerExcel(excelWriter, "版本号", Version.class, versions); ExcelUtil.writerExcel(excelWriter, "数据库&数据表", TableInfo.class, tableInfos1); ExcelUtil.writerExcel(excelWriter, "字段", TableField.class, tableFields); ExcelUtil.writerExcel(excelWriter, "跳数索引", HopIndex.class, hopIndex); ExcelUtil.close(excelWriter); tableFields.clear(); hopIndex.clear(); for (TableInfo tableInfo : tableInfos2) { String enTableName = tableInfo.getEnTableName(); tableFields.addAll(tableFieldMap.get(enTableName)); List<HopIndex> hops = hopIndexMap.get(enTableName); if (hops !=null){ hopIndex.addAll(hops); } } name = filepath + File.separator + "明细层_V1.0" + DateUtil.date().toString(DatePattern.PURE_DATE_PATTERN) + "_2.xls"; excelWriter = EasyExcel.write(name).build(); ExcelUtil.writerExcel(excelWriter, "版本号", Version.class, versions); ExcelUtil.writerExcel(excelWriter, "数据库&数据表", TableInfo.class, tableInfos2); ExcelUtil.writerExcel(excelWriter, "字段", TableField.class, tableFields); ExcelUtil.writerExcel(excelWriter, "跳数索引", HopIndex.class, hopIndex); ExcelUtil.close(excelWriter); }

最新推荐

recommend-type

C++ 中lambda表达式的编译器实现原理

C++ 11加入了一个非常重要的特性——Lambda表达式。这篇文章主要介绍了C++ 中lambda表达式的编译器实现原理,需要的朋友可以参考下
recommend-type

解决mybatis-plus3.1.1版本使用lambda表达式查询报错的方法

主要介绍了解决mybatis-plus3.1.1版本使用lambda表达式查询报错的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

利用Lambda表达式创建新线程案例

主要介绍了利用Lambda表达式创建新线程案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

java中lambda表达式语法说明

“Lambda 表达式”(lambda expression)是一个匿名函数,Lambda表达式基于数学中的λ演算得名,直接对应于其中的lambda抽象(lambda abstraction),是一个匿名函数,即没有函数名的函数。Lambda表达式可以表示闭包...
recommend-type

死磕Lambda表达式(二):Lambda的使用

在上一篇文章(传送门)中介绍了Lambda表达式的基本语法,其中的举了一个Lambda表达式的例子,就是按照品牌给口罩列表进行排序: maskList.sort((Mask o1, Mask o2) -&gt; o1.getBrand().compareTo(o2.getBrand())); ...
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

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

:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章

![:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章](https://img-blog.csdnimg.cn/img_convert/69b98e1a619b1bb3c59cf98f4e397cd2.png) # 1. 目标检测算法概述 目标检测算法是一种计算机视觉技术,用于识别和定位图像或视频中的对象。它在各种应用中至关重要,例如自动驾驶、视频监控和医疗诊断。 目标检测算法通常分为两类:两阶段算法和单阶段算法。两阶段算法,如 R-CNN 和 Fast R-CNN,首先生成候选区域,然后对每个区域进行分类和边界框回归。单阶段算法,如 YOLO 和 SSD,一次性执行检
recommend-type

info-center source defatult

这是一个 Cisco IOS 命令,用于配置 Info Center 默认源。Info Center 是 Cisco 设备的日志记录和报告工具,可以用于收集和查看设备的事件、警报和错误信息。该命令用于配置 Info Center 默认源,即设备的默认日志记录和报告服务器。在命令行界面中输入该命令后,可以使用其他命令来配置默认源的 IP 地址、端口号和协议等参数。
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。