finally return 与String.replaceAll()

本文通过几个具体的Java函数示例,展示了finally代码块在不同情况下的执行效果,并测试了String类的replaceAll()方法。总结了finally块中返回值对函数整体行为的影响及对象引用的变化。
函数finally return 与String replaceAll()测试,代码如下:

/**
* 函数finally return 与String replaceAll() 测试
* @author jsl
* @date 2010-6-8
*/
public class Test {
public static boolean get() {
try {
return false;
} finally {
return true;
}
}
public static int get1() {
int a=0;
try {
return a;
} finally {
a=4;
}
}
public static int get2() {
try {
System.out.println("步骤1");
if (true)
throw new Exception("");
return 1;
} catch (Exception e) {
System.out.println("步骤2");
return 2;
} finally {
System.out.println("步骤3");
return 3;
}
}
public static Object get3() {
Object o = new Object();
try {
System.out.println("first Object:"+o);
return o;
} finally {
o = new Object();
System.out.println("second Object:"+o);
}
}
public static Student get4() {
Student s = new Student();
try {
s.name = "jsl";
return s;
} finally {
s.name = "lsj";
}
}
public static void main(String[] args) {
System.out.println("测试get()...........................");
System.out.println(get());
System.out.println("测试get1()...........................");
System.out.println(get1());
System.out.println("测试get2()...........................");
System.out.println(get2());
System.out.println("测试get3()...........................");
System.out.println(get3());
System.out.println("测试get4()...........................");
System.out.println(get4().name);

System.out.println("测试String.replaceAll()...........................");
/**
* 特殊字符"." "\" "$" 在替换时必须在字符前加 "\\"
* 测试代码如下
*/
String classPath = "java.lang.String";
System.out.println(classPath.replaceAll(".", "/"));
System.out.println(classPath.replaceAll("\\.", "/"));
System.out.println("abc23abc123$".replaceAll("\\d", "/").replaceAll("\\$", ""));
}
}

class Student {
public String name = "";
}


返回结果:

测试get()...........................
true
测试get1()...........................
0
测试get2()...........................
步骤1
步骤2
步骤3
3
测试get3()...........................
first Object:java.lang.Object@35ce36
second Object:java.lang.Object@757aef
java.lang.Object@35ce36
测试get4()...........................
lsj
测试String.replaceAll()...........................
////////////////
java/lang/String
abc//abc///

结论

finally()代码块如果有返回值,则必会覆盖之前的return的值

如果函数返回的是对象,当finally()代码块修改了返回值对象内容时,则会引起对象的改变,如果是修改了对象的引用,则无效。这个结论类似java传参(都是传值)。
private final ObjectMapper objectMapper = new ObjectMapper(); private final XmlMapper xmlMapper = new XmlMapper(); private Tesseract tesseract; @PostConstruct public void initOcrEngine() { tesseract = new Tesseract(); try { //语言包路径和支持语言 tesseract.setDatapath("D:\\maven_use\\lingxi-lhc\\lingxi-ai-extend\\lingxi-ai-comparison\\src\\main\\resources\\tessdata"); tesseract.setLanguage("eng+chi_sim"); tesseract.setPageSegMode(6); // 自动页面分割 tesseract.setOcrEngineMode(1); // LSTM引擎 } catch (Exception e) { throw new RuntimeException("OCR引擎初始化失败: " + e.getMessage(), e); } } /** * 支持PDF和图片 */ public String extractContent(MultipartFile file) { String contentType = file.getContentType(); String fileName = file.getOriginalFilename().toLowerCase(); if (contentType == null) { return "不支持的文件类型: " + contentType; } if (fileName.endsWith(".pdf")) { return readPdfText(file); } return extractImageText(file); } /** * 读取PDF文本内容 * * @param file * @return */ public String readPdfText(MultipartFile file) { try (PDDocument doc = PDDocument.load(file.getInputStream())) { PDFTextStripper stripper = new PDFTextStripper(); // 设置行分隔符 stripper.setLineSeparator("\n"); // 设置字符间距 stripper.setSortByPosition(true); String rawText = stripper.getText(doc); System.out.println("内容" + rawText); return rawText.trim(); } catch (Exception e) { return MessageUtils.message("file.red.pdf.error"); } } /** * OCR识别图片内容 */ private String extractImageText(MultipartFile file) { try { // 创建临时文件 Path tempFile = Files.createTempFile("ocr_", getFileExtension(file.getOriginalFilename())); Files.copy(file.getInputStream(), tempFile, StandardCopyOption.REPLACE_EXISTING); // 执行OCR识别 File imageFile = tempFile.toFile(); String result = tesseract.doOCR(imageFile) .replaceAll("\\s+", " ").trim(); System.out.println("读取的内容" + result); // 清理临时文件 Files.deleteIfExists(tempFile); return result; } catch (Exception e) { return "OCR处理失败: " + e.getMessage(); } } private String getFileExtension(String filename) { if (filename == null) return ".tmp"; int dotIndex = filename.lastIndexOf('.'); return (dotIndex == -1) ? ".tmp" : filename.substring(dotIndex); } public JsonNode parseJson(String jsonContent) throws Exception { return this.objectMapper.readTree(jsonContent); // try { // // 尝试解析 JSON // return objectMapper.readTree(jsonContent); // } catch (Exception e) { // try { // // 尝试解析 XML // return xmlMapper.readTree(jsonContent); // } catch (Exception ex) { // throw new Exception("Failed to parse JSON or XML", ex); // } // } } public List<ValidationResult> compareContent(String pdfText, JsonNode jsonConfig) { List<ValidationResult> results = new ArrayList<>(); // 去除读取内容中的多余空格 pdfText = pdfText.replaceAll("\\s+", ""); // 处理JSON结构(支持单个对象或数组) JsonNode dataNode; if (jsonConfig.isArray() && jsonConfig.size() > 0) { dataNode = jsonConfig.get(0); } else if (jsonConfig.isObject()) { dataNode = jsonConfig; } else { results.add(new ValidationResult("ERROR", "JSON格式错误", "期望一个对象或包含对象的数组", "实际格式不匹配", false)); return results; } // 动态定义地址字段列表 Set<String> addressFields = new HashSet<>(); Iterator<String> fieldNames = dataNode.fieldNames(); while (fieldNames.hasNext()) { String fieldName = fieldNames.next(); if (fieldName.contains("CITY") || fieldName.contains("STATE") || fieldName.contains("ZIP")) { addressFields.add(fieldName); } } // 字段直接匹配 checkNonAddressFields(pdfText, dataNode, results, addressFields); // 连续匹配 checkAddressFields(pdfText, dataNode, results, addressFields); return results; } /** * 检查 JSON 中非地址字段是否严格存在于 PDF 文本中 */ private void checkNonAddressFields(String pdfText, JsonNode jsonConfig, List<ValidationResult> results, Set<String> addressFields) { Iterator<Map.Entry<String, JsonNode>> fields = jsonConfig.fields(); while (fields.hasNext()) { Map.Entry<String, JsonNode> entry = fields.next(); String fieldName = entry.getKey(); JsonNode valueNode = entry.getValue(); if (valueNode.isValueNode() && !addressFields.contains(fieldName)) { //去除多余空格 String expectedValue = valueNode.asText().trim().replaceAll("\\s+", ""); if (expectedValue.isEmpty()) continue; // 直接进行字符串匹配 boolean found = pdfText.contains(expectedValue); results.add(new ValidationResult( "FIELD", fieldName, expectedValue, found ? "Found" : "Not Found", found )); } } } /** * 检查 JSON 中地址字段是否严格存在于 PDF 文本中 */ private void checkAddressFields(String pdfText, JsonNode jsonConfig, List<ValidationResult> results, Set<String> addressFields) { // HanLP分词 List<Term> terms = HanLP.segment(pdfText); List<String> addressParts = new ArrayList<>(); for (Term term : terms) { String word = term.word; if (word.matches("\\d{5,7}")) { addressParts.add(word); } else if (term.nature.toString().startsWith("ns")) { addressParts.add(word); } } // 遍历 JSON 配置中的地址字段 Iterator<Map.Entry<String, JsonNode>> fields = jsonConfig.fields(); while (fields.hasNext()) { Map.Entry<String, JsonNode> entry = fields.next(); String fieldName = entry.getKey(); JsonNode valueNode = entry.getValue(); if (valueNode.isValueNode() && addressFields.contains(fieldName)) { //去除多余空格 String expectedValue = valueNode.asText().trim().replaceAll("\\s+", ""); if (expectedValue.isEmpty()) continue; boolean found = false; for (String part : addressParts) { if (part.equals(expectedValue)) { found = true; break; } } results.add(new ValidationResult( "FIELD", fieldName, expectedValue, found ? "Found" : "Not Found", found )); } } }逻辑有问题吗
07-11
内容概要:本文介绍了一个基于MATLAB实现的无人机三维路径规划项目,采用蚁群算法(ACO)多层感知机(MLP)相结合的混合模型(ACO-MLP)。该模型通过三维环境离散化建模,利用ACO进行全局路径搜索,并引入MLP对环境特征进行自适应学习启发因子优化,实现路径的动态调整多目标优化。项目解决了高维空间建模、动态障碍规避、局部最优陷阱、算法实时性及多目标权衡等关键技术难题,结合并行计算参数自适应机制,提升了路径规划的智能性、安全性和工程适用性。文中提供了详细的模型架构、核心算法流程及MATLAB代码示例,涵盖空间建模、信息素更新、MLP训练融合优化等关键步骤。; 适合人群:具备一定MATLAB编程基础,熟悉智能优化算法神经网络的高校学生、科研人员及从事无人机路径规划相关工作的工程师;适合从事智能无人系统、自动驾驶、机器人导航等领域的研究人员; 使用场景及目标:①应用于复杂三维环境下的无人机路径规划,如城市物流、灾害救援、军事侦察等场景;②实现飞行安全、能耗优化、路径平滑实时避障等多目标协同优化;③为智能无人系统的自主决策环境适应能力提供算法支持; 阅读建议:此资源结合理论模型MATLAB实践,建议读者在理解ACOMLP基本原理的基础上,结合代码示例进行仿真调试,重点关注ACO-MLP融合机制、多目标优化函数设计及参数自适应策略的实现,以深入掌握混合智能算法在工程中的应用方法。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值