-
Java处理文件压缩与解压的核心是使用java.util.zip包,支持ZIP和GZIP格式;1.压缩文件或文件夹使用ZipOutputStream,遍历文件并通过addToZip方法写入压缩流;2.解压使用ZipInputStream逐个读取ZipEntry并写入目标路径;3.GZIP格式通过GZIPOutputStream和GZIPInputStream实现单个文件的压缩与解压;4.处理大文件时优化缓冲区大小(如8KB-64KB)、使用Buffered流、合理利用多线程和NIO;5.TAR格式需借助A
-
接口应按调用方角色而非功能模块拆分,如LoginCapable、EmailCapable、ReportCapable;若实现类超1/3方法为空或抛异常,即违反接口分离原则,需及时重构。
-
Addressalreadyinuse:bind错误需先用netstat或lsof定位占用8080端口的PID及进程名;再检查并同步修改server.xml中Connector、Server、AJP三处端口,确保无冲突且XML格式正确。
-
toLowerCase()和toUpperCase()不修改原字符串,仅返回新字符串;需接收返回值,防范null/undefined及Unicodelocale差异,避免链式调用崩溃。
-
课程表自动生成需解决多资源冲突,首先定义课程、教师、教室、班级和时间段等类,建立无时间冲突、满足连堂及资源限制的约束条件,接着使用回溯算法尝试排课,对难排课程优先处理以提升效率,最后输出二维表格形式课表。关键在于准确建模约束并结合启发式策略优化搜索过程,确保课时排完且不超教师负荷。
-
CopyOnWriteArrayList.iterator()返回不可变快照,遍历基于创建时的数组副本,无法感知后续增删改操作;不支持remove()/set(),调用抛UnsupportedOperationException;读无锁、写加锁并复制数组,适用于读多写少场景。
-
能,但需满足接口定义稳定、实现类可独立打包、服务发现路径被正确扫描三个条件;JavaSPI仅支持本地classpath静态加载,不解决微服务远程发现与版本冲突问题。
-
Math.sqrt(-1)不会抛出异常或导致编译失败,而是返回NaN——这是一个符合IEEE754和Java规范的合法浮点值,因此既非语法错误,也非运行时异常;是否构成逻辑错误,取决于程序预期行为与上下文语义。
-
Queue接口是约定行为的契约,不保证FIFO但标准实现默认遵循;add()失败抛异常,offer()返回false更安全;poll()/peek()空时返回null,remove()/element()则抛异常;ArrayDeque适合单线程高性能,LinkedBlockingQueue和queue.Queue才用于多线程。
-
因为Cipher是抽象类,必须通过Cipher.getInstance()指定算法、模式和填充方式才能获取实例,直接new会因未初始化关键字段而抛NullPointerException。
-
String.regionMatches()是Java中高效局部字符串比较方法,跳过子串创建、直接字符数组比对,支持区分/忽略大小写两种重载,时间复杂度O(len)、空间复杂度O(1),需手动校验索引边界,性能显著优于substring+equals。
-
答案:比较对象时应使用equals而非==,因为==比较引用地址,equals比较内容。例如str1和str2内容相同但地址不同,==返回false,equals返回true;基本类型用==比较值,对象类型优先用equals判断逻辑相等。
-
StringTable不扩容——这是最关键的事实。它从JVM启动那一刻起就固定大小,由-XX:StringTableSize决定,后续任何阶段都不会自动增长或收缩。所谓“内存脉冲抖动”在海量配置加载场景中若与StringTable相关,根源几乎一定是哈希冲突激增导致的intern()阻塞和GC标记开销飙升,而非StringTable自身内存膨胀。
-
newThread()一用就卡,因每次创建都触发系统调用、分配8MB内核栈、切换态,1000次即耗时百毫秒且占8GB虚拟内存;CachedThreadPool无上限更危险;应使用有界ThreadPoolExecutor并合理配置参数。
-
AQS共享模式中state语义因同步器而异:Semaphore的state表示剩余许可数(越大越空闲),CountDownLatch的state表示待完成任务数(越小越接近释放线程),该差异决定tryAcquireShared返回逻辑及阻塞/放行时机。