-
Semaphore是Java中用于控制并发访问资源数量的同步工具,通过维护许可数量限制同时执行的线程数。创建时指定许可数,在关键代码前调用acquire()获取许可,执行完成后在finally块中调用release()释放许可,从而实现流量控制。常用于限制数据库连接、控制API调用频率等场景,需注意避免许可泄露,可选公平模式防止线程饥饿,适用于大多数限流需求。
-
Java中不能直接newLogger,因其构造方法为protected,须通过Logger.getLogger()获取实例;JUL配置繁琐性能一般,推荐SLF4J+Logback组合,解耦API与实现,支持灵活配置和高性能日志输出。
-
ClassCastException本质是运行时向下转型失败,即父类/接口引用强制转为不兼容的子类类型;需用instanceof或模式匹配校验类型,避免盲目强转、泛型擦除及隐式转型。
-
JavaFX项目应分model/view/controller三层:model用POJO含绑定属性,view仅FXML加载与事件绑定,controller通过ObservableList更新UI;耗时操作须用Task并发;SQLite操作必用PreparedStatement;jpackage打包需配注册表、图标及用户目录配置。
-
优先选org.springframework.boot:spring-boot-starter-data-redis;SpringBoot项目自动装配连接池、序列化器和模板类,省80%配置;纯Java项目才用redis.clients:jedis并配commons-pool2。
-
多态通过接口统一调用、运行时绑定实现类,解耦调用方与具体实现,提升扩展性、可维护性与可测试性;支持策略模式、异构集合统一处理及Mock测试。
-
throw用于方法内抛出异常对象,throws用于声明方法可能抛出的异常类型;前者执行后终止方法,后者仅作提示。
-
配置阿里云Maven镜像可提升依赖下载速度,需在settings.xml的<mirrors>中添加阿里云镜像源,推荐使用用户级配置,通过执行mvn命令验证是否生效,也可在pom.xml中配置仅对当前项目生效。
-
多态提升扩展性:新增子类无需修改调用方代码,只需实现统一接口,通过工厂或Spring注入即可;避免if-else硬编码、接口污染和散落new,保障开闭原则与可维护性。
-
OutOfMemoryError:GCoverheadlimitexceeded并非堆内存真正耗尽,而是JVM检测到最近98%时间用于GC却仅回收不足2%堆空间,判定无效运行而主动终止,本质是GC频繁低效,多由内存泄漏或对象生命周期失控导致。
-
Arrays类提供静态工具方法简化数组操作但不改变原数组结构;Arrays.asList()返回固定大小列表,需newArrayList()包装才支持增删;基本类型数组转List须先转包装类型或用Stream。
-
可重入锁允许同一线程多次获取同一把锁而不阻塞,其核心是“线程绑定+计数器”机制,通过state值记录加锁次数、持有线程引用确保仅该线程可重入;用于避免嵌套调用死锁,支持公平/非公平模式,且必须配合try-finally确保unlock。
-
Java中按条件拆分集合推荐用Collectors.groupingBy()配合Lambda,支持单条件(如布尔值或语义化字符串)、多条件(record或字符串拼接)分组,可嵌套收集器取每组前N条,并需妥善处理null值。
-
不能直接newList(),因为List是接口,Java不允许实例化接口;必须使用其实现类如ArrayList,推荐写法为Listlist=newArrayList()。
-
在SpringBoot中配置多数据源和分库分表,核心是通过定义多个DataSourcebean实现多数据源连接与动态切换,并根据分片键将数据分散到不同数据库或表中以提升系统扩展性。1.多数据源配置需在application.yml中定义多个数据源信息,并通过@Bean创建多个DataSource实例;2.使用AbstractRoutingDataSource实现动态数据源切换,结合ThreadLocal和AOP实现运行时上下文识别;3.分库分表策略包括范围分片、哈希分片、时间分片和业务分片,选择合适的分片