-
CyclicBarrier不能替代CountDownLatch因其语义不同:前者是“全部到达后一起继续”且可重用,后者是“倒计数为零后释放等待线程”且不可重用;误用会导致串行、卡死或BrokenBarrierException。
-
是的,Java泛型在编译后被擦除,字节码中仅保留原始类型,类型参数全部替换为Object或上界,运行时无法获取泛型信息,仅通过Class元数据中的Signature属性供反射等有限使用。
-
Java受检异常是编译期强制处理的Exception子类(非RuntimeException),用于应对可预期的外部风险如I/O、数据库、网络等失败,需try-catch或throws声明,体现契约式编程思想。
-
Java单元测试环境的核心是确保JUnit能被正确识别和执行,关键在于依赖范围设为test、避免JUnit4混用、IDE配置正确及SpringBoot版本匹配。
-
内部类是定义在类内部的类,能访问外部类所有成员,主要用于封装辅助逻辑、提升代码组织性。1.成员内部类用于与外部类强关联的场景;2.局部内部类封装方法内的复杂逻辑;3.匿名内部类常用于事件监听等临时实例;4.静态嵌套类适用于无需外部实例绑定的逻辑。通过private修饰可隐藏实现细节,增强封装性。典型应用如ArrayList的Itr类实现迭代器模式,直接访问内部数据,保证安全高效。内部类是解决类与辅助逻辑组织的有效手段,使代码更清晰、安全、易维护。
-
双亲委派模型通过加载路径锁定、委托顺序强制和类唯一性约束三层机制防止篡改;BootstrapClassLoader独占java.*类定义权,绕过委派会触发JVM级SecurityException;同名类因加载器不同而隔离;AppClassLoader等仅转发请求不参与定义。
-
Java的PriorityQueue基于小顶堆实现,poll()返回最小元素但底层数组无序;默认按Comparable排序,可传Comparator自定义规则;不响应元素内部变更;遍历结果为物理顺序而非优先级顺序。
-
<p>C#12+原生支持逗号分隔case标签,如case1,2,3:;TypeScript和C/C++仅通过模拟或扩展实现类似效果;Go、Java、Python不支持,需用if-else、查找表或显式fall-through替代。</p>
-
应显式指定字符集避免乱码,因String.getBytes()无参时依赖平台默认编码(如Windows为GBK、Linux/macOS为UTF-8),导致跨环境字节数组不一致;推荐使用StandardCharsets.UTF_8等静态常量进行编码/解码。
-
栈遵循LIFO,队列遵循FIFO;栈用于函数调用、表达式求值,队列用于任务调度、消息传递;Java中栈可用ArrayDeque或Stack类,队列可用LinkedList、PriorityQueue或BlockingQueue实现。
-
同一个类的两个对象是否相等取决于类加载器;即使类名和字节码相同,不同类加载器加载的类被视为不同类,其实例无法通过类型比较或equals判断,常见于Web容器、OSGi、热部署等场景,需确保关键类由同一类加载器加载以避免问题。
-
静态变量能被类直接访问,因其在类加载时分配内存并存储于方法区,所有实例共享且无需对象即可通过类名访问。
-
Java自定义异常类必须以Exception结尾,采用PascalCase命名,用动宾结构准确描述问题场景,如InvalidOrderException;大型项目可选加BusinessException等语义前缀。
-
Java可变参数是语法糖,编译后为数组,但必须是方法最后一个参数且唯一;不能与同名数组方法重载;调用时字面量会生成临时数组,传入数组则直接复用引用。
-
Java中局部变量必须显式初始化才能使用,未初始化访问会编译失败;而成员变量由JVM自动初始化为默认值(0、false、null),存储于堆,生命周期与对象一致;局部变量存储于栈,方法结束即销毁。