-
HashSet底层基于HashMap实现,元素作key、PRESENT作value,继承其线程不安全、扩容机制等特性;TreeSet基于TreeMap,依赖Comparable或Comparator排序,null处理需谨慎;二者迭代顺序根本不同。
-
Java多态通过虚方法表(vtable)实现动态分派,非static、非private、非final的实例方法在运行期根据对象实际类型查vtable调用对应版本,final/static/private方法因编译期绑定而无法多态。
-
Windows下InvalidPathException常因路径含非法字符(如:、|、?、*)或保留名(如AUX)触发,Paths.get()会主动校验而newFile().toPath()不校验,跨平台需统一用Paths.get()并清洗不可见字符。
-
默认方法必须用default修饰且不能有static,是Java8为接口添加可选实现以兼容旧代码的机制;静态方法属接口本身,不可继承,调用需带接口名。
-
Java作用域指变量、方法或类可被访问的有效范围,由代码结构(如{})和声明位置决定,分为局部、成员、类与包作用域,并遵循就近查找与层级覆盖原则。
-
推荐使用静态内部类实现线程安全的懒加载工厂,利用类加载机制保证实例唯一且延迟初始化,无锁高效;双重检查锁定需配合volatile防止指令重排,适用于需显式控制同步的场景;枚举实现最简洁,天然防反射且支持序列化安全,适合简单情况;当工厂需传参时,应区分单例与原型模式,可对内部资源采用双重检查锁定实现懒加载;多数场景下静态内部类为最优方案。
-
PSOldGen内存缓慢但持续增长(约1%/天)虽未触发FullGC或报错,但仍可能预示内存泄漏或配置不合理;需结合GC日志、堆转储分析及JVM参数调优进行系统性排查。
-
在SpringReactor中,需避免Thread.sleep()等阻塞操作;可通过Mono.delay()+concatMap或delayElements()等响应式算子,在不切换线程、不阻塞事件循环的前提下,模拟耗时但非阻塞的业务逻辑。
-
Kafka生产者buffer.memory中未发送的数据在应用崩溃或进程终止时会永久丢失;真正的数据可靠性依赖于Broker端的副本机制与合理配置,而非客户端内存缓冲。
-
synchronized实例方法锁的是this对象而非方法本身,等价于synchronized(this),因此同一对象的多个同步方法互斥,不同对象则不互斥;静态方法锁Class对象;synchronized代码块需显式指定锁对象,应避免用this、字符串常量等;wait/notify必须在synchronized块中调用以确保线程安全;JDK6后synchronized经优化(偏向锁、轻量级锁等)在低竞争下性能接近ReentrantLock。
-
Semaphore通过许可机制限制并发线程数,初始化指定许可数量,线程需acquire()获取许可并release()释放,确保最多n个线程访问资源,常用于控制数据库连接等场景,支持公平与非公平模式,应结合try-finally防止许可泄漏。
-
TwilioUsageRecordsAPI不支持按分钟级时间范围(如最近5分钟)直接查询,本文提供基于增量拉取+唯一标识去重的可靠方案,兼容Java/Python/PHP/curl,适用于主账号及子账号的近实时用量监控。
-
必须下载JDK而非JRE,选择匹配系统的x64版本(推荐EclipseTemurin),安装时勾选“AddtoPATH”,配置JAVA_HOME指向JDK根目录,并在Path中添加%JAVA_HOME%\bin;验证java-version和javac-version一致,IDE、Maven等工具依赖JAVA_HOME正确设置。
-
Java提供四种内部类:静态嵌套类不依赖外部实例,适合工具类;非静态内部类持有外部实例引用,可访问所有成员,适用于紧密协作场景;局部内部类定义在方法内,作用域受限;匿名内部类用于实现接口或继承类并立即实例化,常用于事件处理和回调。它们增强封装性、组织逻辑并支持回调机制,但需注意内存泄漏、可读性和序列化问题,最佳实践包括优先使用静态嵌套类、保持简洁、避免过度嵌套,并在复杂场景用独立类替代。
-
Collectors.partitioningBy根据布尔条件将流元素分为两个分区,返回Map<Boolean,List<T>>,适用于偶数奇数、成年未成年等二元分类场景,支持进一步收集操作。