-
AQS共享模式中state语义因同步器而异:Semaphore的state表示剩余许可数(越大越空闲),CountDownLatch的state表示待完成任务数(越小越接近释放线程),该差异决定tryAcquireShared返回逻辑及阻塞/放行时机。
-
线程转储是确认IDEA中程序“假死”的最快手段,需在运行或调试状态下触发:运行时点Run窗口的DumpThreads,调试时通过Debug窗口More选GetThreadDump;仅调试模式可捕获虚拟线程和Kotlin协程;查看dump时聚焦WAITING/TIMED_WAITING状态、主线程阻塞点及锁持有情况。
-
newDate()在2026年新项目中应彻底禁用:它是可变、非线程安全、语义模糊的遗留类,月份0起始、年份1900基准等设计反直觉且已弃用;应改用java.time包中的Instant、LocalDateTime等语义清晰、线程安全的类型。
-
答案:搭建Java开发环境需安装JDK、配置JAVA_HOME和Path变量、安装IDE并验证。首先下载JDK11或17,安装后设置JAVA_HOME指向安装路径,并将%JAVA_HOME%\bin加入Path;macOS/Linux在.zshrc中添加对应export命令并生效;通过java-version和javac-version验证;接着安装IntelliJIDEA或Eclipse,手动配置ProjectSDK确保识别JDK;最后创建HelloWorld项目测试运行,输出结果即成功。核心是JDK安
-
ArrayList默认容量为0(JDK12+)或10(早期),size()始终为0直到add();add()末尾追加高效,set()需索引<size(),remove()移除元素导致O(n)移动;遍历时修改会抛ConcurrentModificationException。
-
orTimeout不会中断正在运行的异步任务,仅返回TimeoutException的新CompletableFuture,原任务继续执行;需配合可中断Callable、显式cancel(true)及响应中断的线程池才能实现真正熔断。
-
编译器是否拦截是唯一判断标准:受检异常不处理则编译失败,运行时异常编译通过、运行才抛;关键看继承链是否经过RuntimeException,而非类名或发生时机。
-
继承问题源于误将其当作代码复用首选而非is-a关系建模工具,如Stack继承Vector破坏封装;应优先组合、慎用protected、避免构造器中调用可重写方法。
-
向下转型前必须用instanceof判断,因编译器无法确定父类引用实际指向的子类,直接强转可能触发ClassCastException;Java14+支持instanceof模式匹配(如if(objinstanceofDogdog))简化安全转换。
-
PriorityBlockingQueue不能直接用作任务队列,因其不支持重复元素的稳定排序,且默认不处理Comparable为null的情况,易抛NullPointerException或导致优先级失效;业务多维排序需显式传入健壮Comparator并外置排序逻辑,避免任务类耦合compareTo实现。
-
Class.forName会触发ClassLoader.loadClass的同步锁竞争,导致高并发下线程阻塞;可通过ConcurrentHashMap缓存+computeIfAbsent避免重复加载,配合启动预热和统一ClassLoader复用缓解。
-
PriorityBlockingQueue不能直接当任务队列用,因其并发offer()不保证优先级重排序,需配合显式锁或封装为线程安全的分发器;它不支持peek后修改重排序,且序列化后堆结构可能损坏。
-
InputStream读取需循环处理返回值以防数据不全,OutputStream写入后须flush或close确保落盘;文件流不处理编码,内存流适合中间转换。
-
<textarea>用于多行文本输入,替代单行<input>;通过rows和cols设置默认尺寸,推荐用CSS(如width、min-height、resize)增强响应式体验;支持placeholder、maxlength、required、autofocus等属性提升可用性。
-
单一职责原则(SRP)指一个类应仅有一个引起它变化的原因;如Order类应只管订单数据,计算、开票、通知等职责需按变化动因拆分为OrderCalculator、InvoiceGenerator、NotificationService等独立类。