-
AsynchronousCloseException表示通道被外部线程异步关闭,需在IO调用处直接捕获并清理资源、退出循环、取消SelectionKey;它区别于同步关闭后的ClosedChannelException和中断导致的ClosedByInterruptException。
-
Class对象是JVM为每个类生成的唯一元数据载体,代表其结构与运行时身份;它非普通实例,而是java.lang.Class类型对象,是反射入口、类型系统基石,生命周期绑定类加载器。
-
必须用字符串构造BigInteger,因无BigInteger(long)构造方法;超大整数只能通过newBigInteger("str")初始化;算术运算需调用add、multiply等方法;比较用compareTo,转换用longValueExact;注意字符串输入需trim和校验。
-
代理模式通过代理对象为原对象提供额外功能。静态代理需手动编写代理类,编译期确定,每个目标类对应一个代理类,代码重复;动态代理在运行时生成代理类,JDK动态代理基于接口,通过Proxy和InvocationHandler实现,CGLIB基于继承,使用ASM生成子类,适用于无接口类。两者核心区别在于代理类生成时机与灵活性,动态代理更利于解耦和扩展。
-
使用Collectors.toMap()时若键重复会抛IllegalStateException,需提供合并函数处理冲突;常见策略包括取后者、取前者、累加、拼接或构建集合,且合并函数不可返回null。
-
能混用,但XML优先级高于注解,同名方法存在XML时注解自动失效;需按功能域切分使用,确保namespace与接口全限定名严格一致,并正确配置XML加载路径。
-
JDK21在Windows11安装需避开空格路径、PATH配置错误和旧版本干扰三大坑:下载官方MSI包(如Temurin的.msi),取消勾选“AddtoPATH”,手动设JAVA_HOME和%JAVA_HOME%\bin,验证java-version、java-Xshare:check及虚拟线程运行。
-
最轻量Java控制台通讯录用ArrayList<Contact>存数据、Scanner交互,Contact需重写equals/hashCode,输入统一用nextLine().trim()防空格和换行残留,搜索用toLowerCase().contains()支持模糊匹配,退出不保存数据。
-
Thread本质是线程调度封装体,需理解start()与run()分离机制、状态流转及构造参数配合;直接调用run()不启新线程,仅start()触发JVM创建OS线程并进入NEW→RUNNABLE状态。
-
ConcurrentHashMap是Java中线程安全映射的首选,采用分段锁或CAS提升并发性能,相比Hashtable和synchronizedMap更高效;其常用操作如put、get等均为线程安全,支持putIfAbsent、remove、replace及compute、merge等原子复合操作,可避免竞态条件;迭代器具有弱一致性,不抛出ConcurrentModificationException,允许遍历时其他线程修改;推荐使用forEach或entrySet遍历;性能优化建议包括合理设置初始容量
-
SpringBoot整合Prometheus监控的解决方案包括:1.引入MicrometerPrometheus注册表依赖;2.在配置文件中开启Prometheus端点;3.配置Prometheus抓取任务。首先,在pom.xml中添加micrometer-registry-prometheus依赖,使应用具备暴露指标的能力;接着,在application.properties或yml中设置management.endpoints.web.exposure.include=prometheus以暴露监控接
-
本文介绍一种基于FastJSON与Hutool的轻量级、类型安全方案,可自动根据JSON中的dim(维度)和type(数据类型)字段,将嵌套JSON数组(如[[1.2,3.4],[5.6,7.8]]或[1,2,3,4])精准反序列化为对应维度的Java原生数组或泛型集合(如double[][]、int[]、String[]等),无需硬编码多层嵌套逻辑。
-
Java数组的length是编译期确定的final字段而非方法,因数组为JVM内置类型,大小固定且存于对象头中;调用length()、对null数组访问或混淆List.size()均会报错。
-
启用UseContainerSupport可让JVM正确读取cgroup内存限制,避免OOM;JDK8u131+/9+默认开启,旧版需显式添加并打补丁;须配合-m设置容器内存限制及-XX:MaxRAMPercentage等参数才能生效。
-
本文介绍在未推送任何提交的前提下,如何安全、彻底地丢弃本地所有修改(包括已暂存和未暂存的变更),使当前分支完全恢复为GitLab远程仓库对应分支的最新状态。适用于IntelliJ等IDE中误删/误改代码后的快速回退场景。