-
<p>正确方法是先计算每格理论跨度360.0/n,再随机选取目标格index,最后在该格扇形内均匀采样角度:angle=index360.0/n+Math.random()360.0/n。</p>
-
Java密码校验须分四步:正则分项校验强度、SHA-256加盐哈希、MessageDigest.isEqual防时序攻击、优先用SpringSecurity的DelegatingPasswordEncoder。
-
本文详解如何用Java对两个数字列表执行循环减法操作:以第一个列表中的每个数为起点,依次减去第二个列表中的元素(循环取值),直到该数减至零或负数,并实时输出每一步运算过程。
-
Future.get()抛出ExecutionException是因规范要求将子线程异常封装后上抛,避免线程间未检查异常直传;其cause即原始异常,最多一层嵌套,InterruptedException和CancellationException则直接抛出。
-
位运算符直接操作二进制位,提升效率。①&用于判断奇偶:n&1==1为奇数;②^可交换数值:a=a^b;b=a^b;a=a^b;③n&(n-1)统计1的个数;④^遍历数组找出唯一单次元素;⑤>>保持符号,>>>高位补0;⑥仅适用于整数类型,移位勿超32或64位限制。
-
Properties类用于读取键值对配置文件,继承Hashtable且线程安全。1.可通过FileInputStream加载文件;2.推荐使用ClassLoader读取resources目录下的配置文件;3.常用方法包括load、getProperty、setProperty和store;4.注意编码问题、流关闭、敏感信息保护及封装为单例提升性能。
-
Java集合判断对象相等需同时重写equals()和hashCode(),因先用hashCode()定位桶再用equals()确认;若只重写equals(),逻辑相等的对象可能被散列到不同桶,导致重复添加、查找失败等问题。
-
Executors类提供创建线程池的静态方法:newFixedThreadPool创建固定大小线程池,适用于稳定负载;newCachedThreadPool创建可缓存线程池,适合短期异步任务;newSingleThreadExecutor创建单线程池,保证任务顺序执行;newScheduledThreadPool和newSingleThreadScheduledExecutor分别用于定时及周期性任务调度。
-
类的依赖关系指一个类使用另一个类的功能,如通过参数、成员变量或实例创建;耦合度衡量这种依赖的紧密程度,高耦合导致代码难以维护和扩展。应通过接口编程、依赖注入和依赖倒置原则降低耦合,使类依赖抽象而非具体实现,提升可测试性与灵活性。
-
while循环不执行是因为初始条件为false;常见原因包括变量未初始化、逻辑错误、误用赋值符=代替==,以及字符串判空方式不当;循环内未更新控制变量则导致死循环。
-
PrintWriter默认不自动刷新缓冲区,需构造时传true或手动flush();不指定字符集易致中文乱码;非线程安全,多线程需独立实例或外层加锁。
-
contains()方法先查hashCode()(哈希集合)再逐个equals(),ArrayList全遍历、HashSet定位桶后比较,自定义类须同时重写equals()和hashCode()且逻辑一致,否则查不到;null处理因集合而异,需特别注意。
-
HashMap构造时传入的initialCapacity和loadFactor到底影响什么Java里HashMap的负载因子(loadFactor)不是运行时可改的参数——它只在构造时固化进实例,后续所有扩容逻辑都基于这个值计算阈值。所谓“动态修改”,本质是创建新实例并迁移数据,没有原地修改这回事。常见错误现象:HashMap对象已存在大量数据,有人试图通过反射强行改threshold或loadFactor字段,结果导致put行为异常、get返回null、甚至死循环(JDK7中链表成环)。JDK8后虽
-
不能直接改系统环境变量切换JDK,因为会全局生效、需重启终端和IDE、易导致构建失败或UnsupportedClassVersionError;推荐按需临时修改PATH前缀、IDE单独配置项目JDK、构建工具指定JDK及封装PowerShell函数快速切换。
-
PriorityQueue在offer()插入新元素且底层数组已满时才触发扩容,扩容规则为:旧容量<64时新容量=2×old+2,≥64时为1.5×old;不支持缩容,也无trimToSize()方法。