-
Java中成员变量不参与多态,编译和运行时均依据引用类型(左边声明类型)访问字段,子类同名字段仅为隐藏而非覆盖,如Animala=newDog();System.out.println(a.name)输出“Animal”。
-
答案:本文介绍如何用Java搭建在线问答平台,采用SpringBoot+MySQL+JPA技术栈,设计用户、问题、回答、标签等数据库表,实现提问、回答、浏览、搜索等功能,结合SpringSecurity完成认证授权,支持JWT鉴权与权限控制,前端可选Thymeleaf或Vue/React实现交互,通过Maven构建并部署至Tomcat或Docker,为后续扩展点赞、评论等功能奠定基础。
-
ERP系统不原生采用SPI架构,但可借鉴其思想实现新旧组件平滑替换:通过接口标准化、运行时路由、插件加载和事件驱动等方式,在冻结契约、双写比对、灰度发布、数据协同四步中渐进演进。
-
Stream.max()遇null必抛NullPointerException,必须用Comparator.nullsLast()包裹原始比较器;nullsLast将null视为最大值,返回Optional可能含null,需二次校验。
-
Optional.ifPresent()是空安全的触发开关,仅当新值非null且异于旧值时才异步推送;需先比对状态再包装,推送逻辑须异步且健壮,不适用于多条件决策或兜底场景。
-
Deque.peek()返回队首元素但不移除,poll()则移除并返回队首元素;二者配合实现“先预览后消费”的非破坏性预检逻辑,需始终配对使用且先判空再调用。
-
Java基本类型内存占用固定:boolean1字节、byte1、char/short2、int/float4、long/double8;引用类型4或8字节;对象字段因对齐填充可能增大,数组含头开销,包装类(如Integer)至少16字节。
-
继承层次过深导致可读性差、维护困难、耦合度高,修改父类易引发副作用;主要弊端包括维护成本上升、依赖过强、重写风险增加和扩展受限;应优先使用组合替代继承,将“是一个”变为“有一个”,通过接口或抽象类定义行为,由独立组件实现并委托调用,提升复用性与灵活性;通用逻辑应提取至工具类或服务,避免污染继承链;利用Java8接口默认方法实现横向功能扩展,降低对单一继承体系的依赖;合理控制继承深度,多用组合、接口与委托,增强系统健壮性与可扩展性。
-
微服务启动频繁FullGC十有八九是Metaspace初始阈值过低(默认20.8MB)所致,应先通过GC日志实测元数据用量峰值,再按峰值上浮20%~50%设置-XX:MetaspaceSize,并同步配置-XX:MaxMetaspaceSize,避免盲目设大导致本地内存争抢。
-
Java集合对null支持差异显著:ArrayList/LinkedList允许任意位置存null;HashMap/LinkedHashMap允许一个null键和多个null值;TreeMap/TreeSet完全禁止null;ConcurrentHashMap拒绝null键值,CopyOnWriteArrayList允许add(null)。
-
Java数组长度上限为Integer.MAX_VALUE(2147483647),因JVM规范强制length字段为int类型且字节码指令仅支持32位操作数,超限会抛NegativeArraySizeException或OutOfMemoryError。
-
URLConnection.getContentType()仅适用于已建立的URL连接,依赖服务器响应头或文件扩展名,不分析实际内容,故无法处理内存中的byte[]或ByteArrayInputStream等变量流。
-
RabbitMQ替代同步调用是为解决阻塞、雪崩与强依赖问题;应定义统一消息契约类并用函数式Consumer绑定,禁用@StreamListener,手动ack需配合异常抛出与重试退避配置。
-
用PriorityQueue求TopK比排序快,因时间复杂度为O(nlogk)而非O(nlogn);需控制堆大小≤K,新元素大于堆顶才offer并poll;取结果必须poll才能有序,toArray等方法不保证顺序。
-
锁粗化是JVMJIT编译器自动将同一锁、同一线程、连续无干扰的多次加锁解锁合并为一次大范围同步的操作,典型场景是循环内对未逃逸局部对象(如StringBuffer)的反复同步调用。