-
<p>Lambda表达式是Java8引入的函数式编程特性,可将代码作为数据传递,简化匿名内部类写法。其语法为(参数)->{操作},依赖函数式接口(如Runnable、Comparator)。常用于集合排序与遍历,如names.sort((a,b)->a.length()-b.length()),显著提升代码简洁性与可读性。</p>
-
parallelStream是Collection接口提供的并行流方法,利用Fork/Join框架将流操作分解为多线程任务以提升大数据计算性能,适用于计算密集型场景,使用时需注意线程安全、任务粒度和I/O阻塞等问题。
-
Java使用java.util.zip包实现文件压缩与解压,核心类为ZipOutputStream和ZipInputStream。1.压缩文件:通过创建ZipOutputStream,遍历文件并为每个文件创建ZipEntry,将其内容写入流中;2.压缩文件夹:递归遍历文件夹内容,将每个文件及子文件夹以相对路径添加到ZipOutputStream中,保持目录结构;3.常见问题及解决:中文乱码可通过构造ZipOutputStream和ZipInputStream时指定UTF-8编码解决;资源未关闭应使用try
-
Java并发中内存可见性必须依赖JMM同步机制:volatile保证单变量读写可见但不保证原子性;synchronized通过锁的清空+刷出保障可见性与原子性;final字段在正确发布前提下提供初始化值的天然可见性。
-
本文介绍如何使用包含属性值匹配的XPath表达式,统一定位同一父容器下多个具有相同特征(如src含“red”)的img元素,避免为每个索引单独写XPath,提升自动化脚本的健壮性与可维护性。
-
Properties类用于Java中读写键值对配置文件,继承自Hashtable,仅支持字符串类型。通过load()或loadFromXML()方法从类路径加载.properties文件,需将文件置于src/main/resources目录;使用store()或storeToXML()可将配置写回文件,默认以ISO-8859-1编码保存,中文需指定UTF-8编码。建议用try-with-resources管理流,避免资源泄漏,敏感信息不宜明文存储。该类适用于中小项目基础配置管理。
-
Arrays.copyOf复制整个数组并可调整长度,若新长度大于原数组则用默认值填充,小于则截断;Arrays.copyOfRange复制指定范围的子数组,包含起始索引到结束索引前一位,适用于提取部分元素。两者均支持基本类型和对象数组,使用便捷且安全。
-
数字签名在Java中的实现主要包括四个步骤:1.准备密钥对,使用KeyPairGenerator生成RSA密钥对或通过KeyStore加载已有密钥;2.使用私钥签名,通过Signature类初始化并执行签名操作;3.使用公钥验签,同样利用Signature类验证签名的有效性;4.注意数据完整性、密钥管理、证书信任链、编码格式及异常处理等实际问题。整个过程依赖JavaSecurityAPI,确保数据完整性和身份认证的安全性。
-
Swing仍可用但已标记弃用,JavaFX需单独引入;二者线程模型不同(EDTvsApplicationThread),布局与打包方式差异显著,JavaFX依赖模块化且具现代UI能力。
-
Java应用异常必须过滤重写,禁止直接返回Exception.toString()或堆栈;应统一拦截转换为业务错误码+模糊提示,日志需记录完整堆栈并脱敏敏感信息,第三方SDK异常须显式捕获、安全包装且保留cause链。
-
答案是Java中switch语句用于多分支选择,支持byte、short、int、char、对应包装类、enum和String(Java7+),不支持long、float、double、boolean;基本语法为switch(表达式)匹配case值,break防止穿透,default处理默认情况;使用时需注意case值为常量、避免fall-through、default位置任意、表达式非null。
-
Desktop.getDesktop().browse()报java.awt.HeadlessException是因在无图形界面环境(如Linux无X11、Docker默认)下运行,需先调用isDesktopSupported()判断支持性,再检查isSupported(Desktop.Action.BROWSE),否则必然失败。
-
一眼看出强耦合:看是否直接依赖具体实现(如newUserServiceImpl)、硬编码字段/方法名、跨层调用、用字符串控制流程等;接口编程通过分离“做什么”与“谁做”降低耦合,使实现可替换且调用方无感。
-
局部内部类必须定义在方法或代码块内,不能出现在类成员位置;只能用abstract或final修饰,不可用访问控制符或static;可访问外部类所有成员及方法中final或“事实上final”的变量。
-
CAS是JVM通过Unsafe调用CPU硬件指令(如x86的CMPXCHG)实现的原子操作,依赖volatile保证可见性、硬件指令保证原子性;AtomicInteger.incrementAndGet()采用乐观自旋重试,高并发下可能大量失败;ABA问题需AtomicStampedReference解决;CAS仅保障单变量原子性,不可替代多字段/复合操作的锁机制。