-
Gradle项目需显式配置Java17:Gradle7.0+用java{version=JavaVersion.VERSION_17},旧版用sourceCompatibility='17'与targetCompatibility='17',并确认org.gradle.java.home指向正确JDK路径。
-
Java中MessageDigest生成SHA-256哈希结果长度不对,因digest()返回字节数组而非十六进制字符串,需用String.format或Hex.encodeHexString转换并补零至64位;实例不可复用,须reset()后才能再次update;字符串输入必须指定UTF_8编码。
-
finally里写复杂逻辑危险,因其执行时机不可控且不参与返回值计算,易掩盖异常、篡改返回值或引发死锁;禁用close()、修改返回值、I/O操作、启线程等高危行为。
-
LongAdder在高并发频繁更新时比AtomicLong快,因其采用分段计数减少CAS自旋争抢;适用于监控计数等弱一致性场景,不适用于强一致序列号生成。
-
答案:Java中转义字符以反斜杠开头,用于表示特殊字符如\t(制表符)、\n(换行)、\"(双引号)等,常用于字符串格式化、包含引号、路径表示等场景,需注意正确使用避免编译错误。
-
Java图像像素遍历为什么不能直接改BufferedImage.getRGB()返回的数组因为getRGB()返回的是新拷贝的int数组,原图数据完全不受影响。你改了这个数组,等于在纸上画了个假图——屏幕上的图片纹丝不动。正确做法是用setRGB(x,y,rgb)逐点写入,或更高效地用WritableRaster拿到原始像素缓冲区再批量操作。小图(
-
应使用BufferedReader包裹System.in进行控制台输入,因其readLine()总读完整行、行为确定;写日记用Files.write()配合APPEND/CREATE和UTF-8编码;读日记用Files.readAllLines()但需捕获NoSuchFileException并判空;路径应封装为静态常量并优先使用用户主目录。
-
VectorAPI是JDK16引入的孵化特性(jdk.incubator.vector),用于编写可被编译为CPUSIMD指令的向量化代码,非java.util.Vector;现可用,但需JDK19+、显式添加模块并正确处理数组对齐与掩码。
-
应使用HashMap存储资产以实现O(1)查找,键用String等不可变对象并重写equals/hashCode;操作封装为独立方法;统一用nextLine().trim()处理输入;退出前必须持久化到文件。
-
EnumMap的get/put是O(1)且无哈希开销,因其直接用枚举ordinal()作数组下标访问内部values数组,省去HashMap全套哈希计算与结构维护流程。
-
Collection接口与原生数组操作对象完全不同:Collections只能操作Collection实现类,Arrays专为原生数组设计;排序行为、类型支持、线程安全及不可变包装等方面存在显著差异。
-
抽象类与接口可共存且互补,抽象类提供公共实现和属性,接口定义行为规范;一个类可实现多个接口但只能继承一个抽象类,抽象类适合表达“是什么”,接口强调“能做什么”;常见做法是抽象类实现接口,封装共用逻辑并遵循契约,如Bird实现Flyable接口,子类继承时既获得通用功能又具备特定行为;实际开发中建议用接口定义角色(如Runnable),用抽象类共享代码(如模板方法),从而提升代码灵活性与可维护性。
-
Java分布式事务实现最终一致性的核心思路是异步与补偿。①基于消息队列的异步确保:通过本地事务保障业务操作与消息发送的一致性,结合定时任务重试机制和消费者幂等性处理,适用于大多数业务场景;②TCC模式:通过Try预留资源、Confirm确认、Cancel回滚三个阶段实现强一致性,但对业务侵入性强,适合金融支付等高一致性要求场景;③Saga模式:将长事务拆分为多个本地短事务并配补偿操作,适用于复杂服务链,可选编排式(集中控制流程)或协调式(事件驱动),前者适合复杂流程便于维护,后者去中心化适合简单固定流程。
-
Java中用JarOutputStream打包JAR文件,本质是向ZIP流写入符合JAR规范的条目(JarEntry)并可选添加META-INF/MANIFEST.MF;必须显式设置JarEntry时间戳(如entry.setTime(System.currentTimeMillis())),否则部分JDK版本使用1980-01-01默认值导致解压失败;MANIFEST.MF必须作为第一个条目写入,即先putNextEntry(newJarEntry("META-INF/MANIFEST.MF"))再ma
-
CopyOnWriteArrayList核心用途是多线程下边读边写不抛ConcurrentModificationException,靠读写分离和写时复制实现遍历安全,但遍历看不到新写入元素,适用于读多写少场景。