-
Java里用Observer接口写观察者模式,现在还行吗?不行。Java9开始java.util.Observer和java.util.Observable已被标记为@Deprecated,JDK14彻底移除。这不是“不推荐”,是“不能用”。官方弃用理由很实在:线程不安全、API设计僵硬、无法支持泛型。别再查老教程照搬Observable.notifyObservers()了。替代方案就一条路:自己定义观察者接口+主动通知逻辑。核心就两件事——谁发通知、谁收通知,中间不
-
InputMismatchException需调用scanner.next()清除非法输入;FileNotFoundException因路径基准是工作目录而非源码目录;try-with-resources自动关闭AutoCloseable资源但可能抑制异常;控制台中文乱码源于终端与JVM编码不一致。
-
Collections.emptyList()和emptySet()返回不可变单例空集合,避免null返回引发异常。二者分别用于List和Set场景,节省内存且安全高效;但不可修改,需修改时应基于其创建新实例。
-
Java不能直接编写以太坊智能合约,但可通过web3j连接以太坊,使用Quorum或Fabric实现Java链码开发。1.Java不被EVM支持,无法直接写以太坊合约,但可用于调用合约、发送交易等;2.使用web3j库可完成账户查询、交易签名、事件监听等操作,并建议结合Infura或SpringBoot使用;3.可选择Quorum(基于以太坊,仍用Solidity)或HyperledgerFabric(支持Java编写链码)进行Java原生合约开发,Fabric需创建Maven项目、引入依赖、打包部署;4
-
本文介绍使用Mockito的spy与thenAnswer实现部分模拟(partialmock),精准控制被测方法内部调用的其他方法的行为,尤其适用于需自定义传入参数并返回预期结果的场景。
-
Future.get()会阻塞,推荐用带超时的get(timeout,unit)避免无限等待;isDone()+get()存在竞态问题,应避免;cancel(true)不保证立即停止线程,需任务主动响应中断;原生Future无回调能力,复杂异步应使用CompletableFuture。
-
URLDecoder和URLEncoder专用于application/x-www-form-urlencoded格式的参数值编解码,必须显式指定UTF-8,不可用于完整URL或路径编码;URLEncoder将空格转为+,非ASCII字符转为%XX,URLDecoder自动处理+和%XX并还原原始字符串。
-
能,但仅限于正确构造的对象;JMM保证未逸出对象的final字段初始化值对其他线程立即可见,反射修改或构造逸出会破坏该保证,final仅保障引用不变而非对象不可变。
-
本文深入分析Processing在RaspberryPi4B等ARMLinuxSBC上OpenGL(P2D/P3D)性能严重劣于Java2D的根本原因,指出其底层GL绑定与驱动适配缺陷,并给出经实测验证的替代方案——迁移到LibGDX,实现从6FPS到60FPS的跨越式提升。
-
必须用try-catch处理编译期异常(如IOException、SQLException),运行时异常(如NullPointerException)应修复逻辑而非捕获;资源操作优先用try-with-resources;catch中重抛需保留原始异常栈轨迹。
-
合理使用三元运算符、逻辑运算符、Optional和switch表达式可简化Java条件判断。例如,用?:替代简单if-else赋值,如Stringresult=(num>0)?"正数":"非正数";;通过&&、||合并条件并利用短路特性避免空指针,如if(user!=null&&user.isActive()&&!user.isLocked());将复杂条件提取为布尔变量提升可读性;使用Optional.ofNu
-
静态方法不能直接访问非静态成员变量,因其属于类而非对象实例,且静态方法在类加载时即可调用,而实例变量需对象创建后才存在;静态方法无this引用,无法定位具体实例。
-
首先设计Transaction类封装金额、类型、分类和日期,再通过FinanceManager管理交易记录并实现增删查及统计功能,接着用文件持久化保存数据,最后用Scanner实现控制台交互,逐步构建出结构清晰的小型个人财务工具。
-
Java中加号(+)用于字符串拼接时,只要任一操作数为String,其余操作数自动调用toString()转为字符串并左结合拼接;null转为"null";自定义类需重写toString();频繁拼接应使用StringBuilder。
-
答案:Collectors.summingInt用于对集合中对象的int属性求和,需配合StreamAPI使用,通过ToIntFunction提取值并累加。示例中统计Product列表的price总和为45,适用于List、Set等集合类型,仅支持int类型,null值需提前处理,性能良好,适合数据聚合。