-
可见性是指线程修改共享变量后其他线程能否立即看到该修改;因JMM中线程工作内存与主内存分离,且存在缓存、优化和重排序,导致修改未及时同步,从而引发可见性问题。
-
main方法必须是static的,因为JVM启动时未创建任何对象,需直接通过类名调用;其publicstaticvoidString[]签名是JVM规范强制要求,确保启动过程简单、确定且生态兼容。
-
本文详解如何在Android应用被用户彻底关闭(如从最近任务列表滑除、长按Home键清除)时可靠触发清理逻辑,指出onDestroy()的局限性,并提供基于Application.ActivityLifecycleCallbacks的健壮实现方案。
-
break只跳出最内层循环,continue跳过本次迭代,return终止整个方法;三者作用域不同,混用易导致逻辑错误,应优先用return简化控制流。
-
Javaswitch直接用枚举值最安全可读,避免ordinal()或name();需显式覆盖所有枚举常量防逻辑遗漏;复杂行为宜用枚举方法绑定;Java14+switch表达式可防穿透并支持返回值。
-
标记-清除算法易致OOM因内存碎片化,无法满足大对象连续空间需求;新生代用标记-复制因存活率低且需Survivor区容下幸存者;老年代稳态选标记-整理,但G1/ZGC已通过分区+局部整理兼顾低停顿与防碎片。
-
Lock接口需手动获取和释放锁,必须在finally中调用unlock();ReentrantLock支持重入、可中断、超时等特性;tryLock()用于非阻塞或超时获取;默认非公平,公平锁性能较差;锁粒度与持有时间需设计合理。
-
答案:Java中应选用合适字符串操作方法以提升性能与安全性。使用+操作符适用于简单拼接,循环中应优先StringBuilder避免性能问题,StringBuffer用于多线程场景,String.join()适合分隔符连接,String.format()或文本块处理格式化输出;比较时禁用==,推荐equals()、equalsIgnoreCase()及Objects.equals()防止空指针;最佳实践包括循环拼接用StringBuilder、常量在前的equals判断及借助工具类处理复杂场景。
-
首先安装JDK17并配置JAVA_HOME与Path环境变量,再选择IntelliJIDEA或VSCode安装并设置JDK路径,最后通过java-version、javac-version及编译运行HelloWorld程序验证环境是否搭建成功。
-
Java调试功能内置于JDK中,无需单独安装;需正确配置JAVA_HOME和PATH,使用IDE图形化调试(基于JDWP协议),或通过jdb命令行、远程调试参数启动调试。
-
JUC不是替代老式同步机制,而是通过高级抽象解决并发场景的可扩展性、可靠性与开发效率问题:提供ReentrantLock、Condition等语义明确工具,线程安全集合,ExecutorService任务调度,以及Atomic原子类和StampedLock等无锁编程支持。
-
Optional不能消除空指针异常,仅将NPE提前至调用get()或orElseThrow()等误用时;它不该包装方法返回值的原始null,而应在必须表达“有/无值”语义且调用方需分支处理时才作为返回类型使用。
-
偏向锁被禁用的直接原因是对象头中hashcode占用了markword的锁状态位,导致偏向锁信息无法写入,二者在31/62位空间内互斥。
-
OOP是用类、对象、封装、继承、多态映射现实世界的结构和行为逻辑;Java通过抽象实体、边界权限、分类关系与行为差异,还原人类认知方式。
-
Java单行注释用//,从//到行末;多行注释用/.../,不支持嵌套和半行续写;文档注释/*.../供javadoc使用;注释内字符串不受影响,但字符常量中误写/*会编译失败。