-
Semaphore通过维护许可数量控制并发访问,acquire()获取许可,release()释放许可,限制如打印机等资源的并发使用。
-
ConcurrentHashMap通过分段锁(JDK7)或CAS+synchronized(JDK8+)解决HashMap的线程不安全问题,支持高并发读写,避免ConcurrentModificationException、数据丢失和死循环。
-
答案:Java中Stream.reduce有三种形式,分别用于非空流归约、指定初始值的归约和并行流归约;通过累加器函数实现求和、拼接等操作,结合Optional处理空流,利用combiner支持并行合并,需注意初始值选择与结合律要求。
-
Math.fma()比a*b+c更准,因其在硬件支持下以扩展精度执行乘加全过程,仅最终舍入一次;而后者需两次独立舍入,易累积误差。
-
IllegalStateException表示对象状态不合法,如在关闭的流中读取数据;IllegalArgumentException表示参数值不合法,如传入负数作为年龄。前者关注对象状态,后者关注输入参数,合理使用可提升代码健壮性。
-
EclipseJava开发环境搭建关键在于JDK、IDE与项目三者版本严格匹配:先确认JDK已正确安装并配置JAVA_HOME,再选择兼容的Eclipse版本(如JDK21需Eclipse2023-12),最后在InstalledJREs中添加JDK并为项目手动指定对应JRESystemLibrary及CompilerComplianceLevel。
-
不能只靠publicstaticfinalint管理状态码,因其缺乏编译期校验、耦合分散、易出错且不可枚举;推荐用enum实现,天然支持字段、方法、序列化与安全查找。
-
os.path.exists()用于判断路径是否存在,返回True或False;它不区分文件与目录,需配合os.path.isfile()或os.path.isdir()确认类型;相对路径依赖当前工作目录,建议转绝对路径;权限不足、损坏软链接或网络设备未挂载时均返回False。
-
Arrays.binarySearch用于在已排序数组中高效查找元素,1.调用形式为intindex=Arrays.binarySearch(array,key),返回目标索引或负值;2.未找到时返回-(插入点)-1,表示应插入位置以维持有序;3.可指定搜索范围fromIndex到toIndex(左闭右开),如Arrays.binarySearch(arr,1,4,3)在子区间查找;4.支持基本类型和对象数组,对象比较需实现Comparable或使用Comparator,如String.CASE_INSE
-
插入排序通过将数组分为已排序区和未排序区实现,每次取未排序区首元素插入已排序区合适位置;Java中用循环与元素后移完成,适合基本有序数据。
-
Java格式化输出依靠System.out.printf()和String.format(),基于Formatter类,使用%开头的格式说明符控制类型、宽度、精度等;常用如%d(整数)、%f(浮点数)、%.2f(2位小数)、%s(字符串)、%c(字符)、%b(布尔值)、%tY(年份)。
-
Java学生成绩排序需实现Comparable或提供Comparator;List用sort()或Collections.sort(),数组用Arrays.sort();并列名次需手动计算rank=i+1;大数据量优先就地排序。
-
Math.log()返回自然对数(ln),非常用对数(log₁₀);需用Math.log(x)/Math.LN10或封装log10函数;Math.exp()是计算e^x的最优方式,比Math.pow(Math.E,x)更准更快;log与exp互为反函数但浮点下存在微小误差。
-
OOP是用类、对象、封装、继承、多态映射现实世界的结构和行为逻辑;Java通过抽象实体、边界权限、分类关系与行为差异,还原人类认知方式。
-
Java5引入的staticimport仅适合导入高频、无歧义、语义稳定的静态常量(如Math.PI、TimeUnit.SECONDS、StandardCharsets.UTF_8),禁止通配导入或用于第三方/自定义易变常量,因其仅是编译期语法糖,滥用会损害可读性与可维护性。