-
类职责应单一,避免“上帝类”;优先组合而非继承;字段默认private,谨慎暴露getter/setter;接口定义契约,抽象类提供共性实现;设计应映射业务稳定结构而非追求编码便利。
-
确保临时文件正确创建、安全使用并可靠删除需显式控制清理:用createTempFile生成唯一文件,deleteOnExit()适用于短生命周期程序,长期服务应即用即删并检查delete()返回值,生产环境需启动时清理遗留文件。
-
反射解析注解本身不直接导致元空间泄漏,真正危险的是运行时生成带注解的新类、频繁刷新Spring上下文、热部署中ClassLoader未卸载或动态注册注解处理器等行为。
-
双指针法可原地移除数组中目标值元素:left指向结果数组写入位置,right遍历原数组;遇非目标值则复制至left并递增left,时间复杂度O(n),空间复杂度O(1)。
-
面向对象设计应从现实角色出发,优先定义Book、Reader、LibrarySystem三类,通过封装隔离变化,用对象协作替代流程判断,以组合和小步重构代替过早继承。
-
应优先用Lambda替代匿名内部类,仅在需访问外部类私有字段、需自引用且只用一次时才用newSomeInterface(){...}。
-
Java留言板系统用Servlet+HTML实现,数据存静态List,含Message类与两个Servlet;需处理POST中文乱码、自动生成ID和时间;推荐JSP展示,后续可扩展为文件或数据库存储。
-
学生、课程与选课记录构成多对多关系,需通过SelectRecord中间实体及studentRecords、courseRecords两个Map维护双向关联,配合Set去重和HashMap高效查询,选课退课须原子性同步更新三方数据,业务逻辑应封装在服务类中以保障可维护性与可扩展性。
-
微服务架构的真正基石在于对业务领域的深刻理解和划分,即领域驱动设计(DDD),服务应围绕明确的业务能力构建,并实现数据独立性。其次,SpringCloud提供了Eureka、Ribbon、Nacos等工具实现服务发现与负载均衡,支持动态实例管理及智能路由策略。再者,容错通过Hystrix或Resilience4j实现断路器和线程池隔离,限流则在APIGateway或服务内部结合令牌桶、漏桶算法进行保护系统稳定性。最后,可观测性依赖ELK、Prometheus、Grafana、Sleuth与Zipkin等工
-
应遍历NetworkInterface.getNetworkInterfaces()获取真实网卡名,按isUp()、非loopback、有MAC地址筛选;getHardwareAddress()为null时需检查权限或系统限制;获取IPv4地址时应过滤本地、链路本地、回环及APIPA地址;Windows中文名乱码需用GBK重解码。
-
用二维数组实现配置解析,核心是将配置项定义为“字段名→默认值→类型→是否必填”的表格结构,通过遍历匹配、类型转换和嵌套展开,生成类型安全、可直接使用的键值对配置。
-
JavaAgent的两种加载方式核心差异在于介入时机与字节码修改能力:静态加载通过-javaagent在JVM启动前执行premain,可无限制拦截类加载并增强字段访问;动态加载通过VirtualMachine.attach()触发agentmain,仅支持已注册transformer的类重转换,无法新增字段或修改继承关系,且JDK21起默认禁用。
-
分代收集理论的核心是“对象生命周期差异显著”,实战优化关键在于:让短命对象快速回收、长命对象少被扫描、中等寿命对象不卡晋升瓶颈;需根据变量真实存活特征反向设计分配与引用方式,避免误判导致不必要的FullGC。
-
使用BufferedReader逐行读取并计数是统计大文件行数最轻量、内存友好的方式,核心是只读不存、用int计数器、try-with-resources确保关闭资源,空行也计为一行。
-
分代收集理论基于弱分代假说(多数对象朝生夕灭)和强分代假说(高龄对象长期存活),将堆划分为年轻代与老年代,配合记忆集解决跨代引用,并随硬件与应用演进逐步弱化分代刚性。