-
购物车用ArrayList<CartItem>而非HashMap,因需保留价格、规格等上下文;库存校验先用内存Map模拟再替换为DAO;订单状态用enum+switch限制合法迁移路径。
-
在Hibernate5中,仅靠hibernate.jdbc.time_zone=UTC无法保证LocalDateTime字段读取时保持UTC语义;需改用OffsetDateTime或Instant等时区感知类型,并配合数据库列类型(如TIMESTAMPWITHTIMEZONE)与JDBC驱动协同工作。
-
Java中+=等复合赋值运算符会自动执行隐式窄化类型转换(即强制转为左操作数类型),而普通+运算后直接赋值需显式强制转换,否则编译失败;这是JLS规范定义的行为,并非编译器疏漏。
-
LocalDate仅处理无时区日期,LocalDateTime含日期时间但无时区;二者均不可变且线程安全,但误用易致DateTimeException或时区错误;涉及真实时刻须用Instant或ZonedDateTime。
-
JavaExecutor框架通过线程池解耦任务提交与执行,提升资源复用与管控能力;常用实现包括FixedThreadPool、CachedThreadPool、ScheduledThreadPool和SingleThreadExecutor,需依场景选用,并遵循shutdown→awaitTermination→shutdownNow三步关闭法,推荐submit替代execute以获取异常反馈。
-
HashSet插入和查找通常比TreeSet快,因其基于哈希表实现,平均时间复杂度O(1),而TreeSet基于红黑树,操作均为O(logn);但哈希碰撞严重时HashSet可能退化。
-
LinkedHashMap能保持插入顺序是因为内部维护了独立于哈希表的双向链表,新节点在put时既加入哈希表又追加到链表尾;默认accessOrder=false按插入顺序迭代,重复put同key不改变位置,putAll顺序取决于源Map迭代顺序。
-
不能。JVM不自动检测或解除死锁,ThreadMXBean.findDeadlockedThreads()仅诊断并返回死锁线程ID列表,不终止线程;需人工干预或预防,且仅检测synchronized锁,不覆盖ReentrantLock等显式锁。
-
Java中比较字符串内容必须用.equals()而非==,因为==比较内存地址,equals比较字符内容;推荐使用"abc".equals(str)防空指针,忽略大小写用equalsIgnoreCase,排序用compareTo,避免依赖字符串常量池的==巧合。
-
Java是静态强类型语言,类型在编译期绑定且禁止隐式转换,如intage=25后不可赋值字符串,编译器直接报错;自动装箱等机制不改变其静态强类型本质,确保大型系统类型安全与工具链可靠性。
-
“Java不是内部或外部命令”:需正确配置JAVA_HOME及Path环境变量,确保指向JDK的bin目录。2.“找不到或无法加载主类”:检查类路径、包声明与目录结构是否匹配,使用-cp指定路径。3.“UnsupportedClassVersionError”:编译与运行JDK版本不一致,需统一JDK版本并检查IDE设置。4.端口被占用:通过netstat查进程、taskkill结束或修改配置更换端口。5.Maven依赖下载失败:检查网络、代理设置,更换镜像源,清理本地仓库并强制更新。多数问题源于路径、版
-
Java正则需显式编译Pattern再用Matcher匹配,matches()全串匹配、find()找子串、lookingAt()从开头匹配;String.matches()易误用因默认全串匹配;注意转义、null、flags选项及性能优化。
-
初学者应优先用H2内存数据库练JDBC:无需安装、自动清理、避免MySQL驱动/时区/SSL干扰;需配DB_CLOSE_DELAY=-1;用try-with-resources按Connection→PreparedStatement→ResultSet顺序声明;H2中TIMESTAMP默认值须写CURRENT_TIMESTAMP();先写死UserDao再抽象。
-
Java程序以JVM进程运行,其内线程共享堆和方法区,独享栈与PC寄存器;JVM采用一对一模型映射OS线程,主线程结束且无非守护线程时进程退出。
-
静态内部类不会导致内存泄漏,因为它不持有外部类实例引用,生命周期与外部类解耦;而非静态内部类隐式持有外部类引用,易在Handler、线程等场景中造成内存泄漏。