-
使用File类可基础遍历目录,通过listFiles()获取子项并判断类型输出;2.推荐使用NIO.2的Files.list()或Files.walk()结合Stream实现高效、安全的目录浏览,支持流式处理与异常管理。
-
JavaPattern/Matcher在处理含Unicode字符(如℃、Ω)的字符串时,若正则表达式未正确覆盖目标字符大小写或编码语义,会导致find()误判成功但group()返回空或null,且start()位置偏移——根本原因常是正则逻辑缺陷,而非Unicode编码问题。
-
removeIf方法通过传入Predicate实现条件删除,如删除偶数或年龄小于18的用户,需注意集合可变性、线程安全及原集合被修改的问题。
-
通过封装、多态和职责分离将业务逻辑与代码结构对齐,用领域对象替代贫血模型,以Order.pay()为例实现内聚校验,利用DiscountStrategy多态消除条件分支,拆分大Service为小聚合如UserRegistration,通过方法名validateEligibilityForPromotion等表达业务意图,使代码具备可读性与扩展性。
-
Java反射是JVM提供的标准能力,通过Class对象动态获取类型信息并调用成员,但存在性能开销与安全限制;获取Class有三种方式,访问成员需区分getDeclaredXXX与getXXX,invoke()调用有三处易错点,且反射影响JIT优化。
-
答案:Java中通过staticfinal声明类常量,final声明局部常量,命名全大写加下划线,提高可读性、便于维护、避免魔法数字,注意必须初始化且引用类型仅地址不可变。
-
Arrays.binarySearch搜不到明明存在的元素是因为它仅对已排序数组有效;未排序或降序数组(未配对应Comparator)会导致结果不可靠,返回负数表示插入点编码而非简单“未找到”。
-
ScheduledThreadPoolExecutor不能替代synchronized,因其仅负责任务调度,不提供线程安全;并发问题需靠任务内部同步机制(如锁、ConcurrentHashMap)解决,而非调度时机。
-
happens-before是什么:不是执行顺序,而是可见性契约它不是说「A一定在B前面CPU执行」,而是向程序员承诺:如果Ahappens-beforeB,那么A对共享变量的修改,对B一定是可见的;且B不能看到A之前某个中间态(比如只写了一半的long值)。这个保证由JVM在编译期插内存屏障、运行时配合CPU指令(如lockxchg或mfence)共同实现。常见误解:把happens-before当作「时间先后」——错。两个操作即使A在
-
IntelliJIDEA在调用第三方库JAR中的接口方法时,常无法显示原始参数名(如name,type),仅显示占位符(如s,i),而默认方法却能正常显示——根本原因在于Java字节码规范对abstract接口方法不强制保留参数名信息,即使编译时加了-parameters也无效。
-
吞吐量优先应选ParallelGC,因其专为最大化吞吐量设计,全程STW但效率高、无协调开销;G1GC仅在兼顾吞吐与软实时停顿(≤200ms)时才适用。
-
Java自定义业务异常码核心是建立可读、可维护、可扩展的错误码体系,需统一管理、分层分类、携带上下文、与异常类强绑定,推荐枚举+自定义异常实现。
-
ISP核心是客户端不依赖未使用接口,需按需将胖接口拆为小而专的接口,如PowerControllable、Printable等,结合抽象类复用实现逻辑,命名体现能力而非角色,拆分依据是调用方和使用场景。
-
静态方法属于类而非实例,可通过类名直接调用。使用static修饰,用于工具功能或与类相关的操作,如Math类的abs、sqrt等;主方法main也是静态方法。静态方法不能访问非静态成员,除非创建对象。示例中MathUtils类定义了add和max两个静态方法,可在不创建对象的情况下通过MathUtils.add(5,7)等方式调用。常见用途包括工具类、工厂方法(如Integer.valueOf())和辅助功能。
-
答案:Java通过BufferedImage和图像处理API实现滤镜,示例包括灰度、反色、模糊和锐化;使用像素遍历或卷积核处理图像,结合ImageIO读写图片,适用于桌面应用。