-
为什么在构造方法里要写this.name=name因为不写的话,name=name实际是把参数赋给自己,成员变量根本没被初始化。Java不会自动帮你区分同名的局部变量和成员变量,得靠this显式指代当前对象的成员。常见错误现象:System.out.println(obj.getName())打印出null或默认值,但明明传了参数——大概率是忘了加this。只在成员变量和形参/局部变量重名时才必须用this;不重名时可省略(但有些团队规范强制写)this只能出现在非
-
final关键字用于限制类和方法的修改,提升代码安全与性能;final类不可继承,适用于不可变类和安全敏感类,如String;final方法不可重写,用于保护核心逻辑,如银行存款操作。
-
本文深入解析Java中“thisPoint”的真实含义——它并非某个特定变量(如first或second),而是指当前正在调用方法的那个Point实例对象本身,即隐式参数this所代表的运行时对象。
-
NoSuchFieldException在Java反射中因字段不存在而抛出,常见于拼写错误、访问权限不当或字段被混淆等情况。调用getDeclaredField或getField时若未找到指定字段,则触发该异常。应通过try-catch捕获并处理,结合getDeclaredFields遍历、递归查找父类字段及使用注解等方式提升代码健壮性,避免运行时崩溃。
-
await()后线程进入condition队列:先新建CONDITION节点尾插,清理取消节点,再通过fullyRelease()释放锁并退出同步队列;signal()时迁移头节点至同步队列,CAS修改waitStatus后enq插入,再unpark;唤醒后需重新排队竞争锁,中断则不参与竞争。
-
死锁典型模式是多线程以不同顺序获取同一组锁,导致相互等待;预防需统一加锁顺序、使用tryLock超时机制及lockInterruptibly响应中断,并辅以jstack和ThreadMXBean检测。
-
Exception是程序运行中可预期、可恢复的问题,如文件不存在或网络超时;Error是JVM无法处理的严重故障,如OutOfMemoryError,不可恢复且不应捕获。
-
Math.sqrt(-1)不会抛出异常或导致编译失败,而是返回NaN——这是一个符合IEEE754和Java规范的合法浮点值,因此既非语法错误,也非运行时异常;是否构成逻辑错误,取决于程序预期行为与上下文语义。
-
AtomicInteger的核心作用是在不加锁前提下安全实现int型共享变量的原子读-改-写操作;适用于单变量高频更新场景,如计数器、低并发ID生成、一次性状态标志位管理。
-
类职责应单一,避免“上帝类”;优先组合而非继承;字段默认private,谨慎暴露getter/setter;接口定义契约,抽象类提供共性实现;设计应映射业务稳定结构而非追求编码便利。
-
答案:通过定义Option和VotingSubject类构建投票系统基础,使用ConcurrentHashMap和synchronized保证线程安全,VoteService实现投票逻辑,printResults方法统计并展示各选项得票数与占比。
-
静态变量不可用于链路追踪,因其被所有线程共享,导致多请求间traceId相互覆盖、异步任务失效、无法满足分布式追踪标准;应使用ThreadLocal、MDC或OpenTelemetry等线程隔离方案。
-
Lambda表达式底层通过invokedynamic指令实现,其字节码中表现为invokedynamic#n,0,该指令指向常量池中BootstrapMethods项,由LambdaMetafactory.metafactory在运行时动态生成实现类并跳转至编译器生成的私有静态(或实例)方法执行逻辑。
-
答案:Deque是Java中支持两端操作的线性集合,ArrayDeque为其高效实现,适用于栈、队列及双端队列场景。
-
稀疏数组压缩适用于大棋盘且落子稀疏的场景,核心是仅存储非空位置的行列索引和值;采用行主序扁平三元组数组提升查找与内存效率,并需严格按默认值语义处理读写与还原。