-
在Groovy中,若需根据字符串拼接出变量名并获取其值(如"${CODEBASE}_sonar_binaries"),不能直接用"${...}"插值访问局部变量;必须通过this."variableName"访问脚本级或对象属性级变量,或改用Map统一管理变量。
-
观察者模式与事件机制本质相同,均实现对象间松耦合通信。被观察者状态变化时通知所有观察者,形成“一对多”依赖。Java中通过Observable与Observer接口实现,后被事件机制扩展,引入事件源、事件对象和监听器,广泛应用于GUI与事件驱动系统。现代Java推荐使用函数式接口或响应式编程替代过时的Observable,提升类型安全与异步处理能力。
-
JMM是多线程通信的抽象规则,定义主内存与工作内存间变量可见性;JVM内存结构是运行时真实分区,包括堆、元空间、栈等,OOM和GC均发生于此。
-
答案:该记账本应用通过Entry类定义收支条目,AccountBook类实现添加、查看和统计功能,使用ArrayList存储数据,支持控制台交互操作,并可扩展文件持久化。
-
最常用方式是使用Jackson或Gson库。先添加对应Maven依赖,再分别通过ObjectMapper的writeValueAsString()或Gson的toJson()方法将Map转为JSON字符串,两者均几行代码即可完成转换。
-
Future.get()默认阻塞,需用超时重载或isDone()判断;抛出InterruptedException、ExecutionException、TimeoutException须分别处理;禁在UI/Servlet主线程调用;cancel()不保证资源清理,任务需自行响应中断。
-
Java资源未关闭的根本问题是异常发生时finally中关闭逻辑可能被跳过或新异常掩盖原始异常;try-with-resources要求资源实现AutoCloseable且必须在try括号内声明,关闭顺序与声明相反,多重异常时原始异常保留、关闭异常被压制,但资源生命周期超出try块时禁用该语法。
-
ReentrantLock需手动配对acquire/release,必须用try-finally确保unlock;默认非公平锁性能更优;Condition替代wait/notify须用while重检条件;仅在需超时、中断响应或多个条件队列时选用。
-
FileLock是Java中基于操作系统实现的进程级文件锁,用于多进程间协调文件访问,分为排他锁和共享锁,需通过FileChannel获取,属建议性锁且不保证JVM内线程安全。
-
Phaser是Java7引入的可重用、动态注册参与者的分阶段同步工具,适用于阶段明确、参与者数量可变且需多次执行多阶段流程的场景;CountDownLatch不可重置,CyclicBarrier固定人数且不支持分阶段,而Phaser通过arriveAndAwaitAdvance()自然表达阶段协同。
-
ConcurrentHashMap可实现线程安全简易缓存,支持原子操作如computeIfAbsent,适合静态数据;需手动管理过期与清理,不自动回收;Weak/SoftReference不适用因不可控且非线程安全;LinkedHashMap非线程安全且无TTL;复杂场景应选Caffeine。
-
Java安全编程的关键在于通过输入验证、身份验证、授权、加密等手段保障数据的机密性、完整性和可用性。1.输入验证应采用白名单、黑名单、数据类型、长度和范围校验等方式防止SQL注入、XSS攻击等;2.身份验证可通过用户名/密码、MFA、OAuth2.0、JWT等方式确认用户身份;3.授权可使用RBAC或ABAC机制控制用户对资源的访问权限;4.加密需合理使用对称加密(如AES)、非对称加密(如RSA)和哈希算法(如SHA-256)保护敏感数据;5.防止SQL注入应优先使用参数化查询,避免动态拼接SQL语句;
-
Runnable描述“要做什么”,Thread负责“用什么去执行”;Runnable无start()方法,仅Thread可启动线程并回调其run();推荐优先使用Runnable以避免单继承限制、支持复用与线程池。
-
提前返回、提取方法、策略模式和Optional可降低Java多层嵌套。通过尽早处理边界条件减少层级,将复杂判断封装为独立方法提升可读性,用策略模式替代多重if-else,利用Optional避免null链式检查,使代码更清晰易维护。
-
CountDownLatch是用于线程间等待协调的同步工具,适用于主线程等待多任务完成等场景;其计数器一次性递减归零后唤醒等待线程,不可重置,需配合超时或中断处理,并注意子线程异常导致计数卡住问题。