-
Java里&&和||为什么有时不执行右边?因为它们是短路运算符——左边结果已能确定整个表达式真假时,右边直接跳过。这不是bug,是设计行为。比如if(obj!=null&&obj.isValid()),如果obj是null,obj.isValid()根本不会调用,避免空指针。但反过来,if(obj.isValid()&&obj!=null)就会崩。用&&做安全判空时,把可能为null或false的条件放左边用||做默认值兜底时(如str
-
Exchanger怎么在双缓冲里交换两个缓冲区Java的Exchanger本质是线程间**成对同步交换对象**的工具,用在双缓冲场景时,它不负责分配内存、不管理读写状态,只管“等两个线程都到齐了,就互换手里的缓冲区引用”。典型用法是:一个线程持续往A缓冲区填数据(生产),另一个线程从B缓冲区取数据处理(消费),填满/取空后双方调用exchange()换一次引用,角色轮转。必须严格成对调用——一个线程调用exchange(buffer)后,必须有且仅有一个另一线程在同一Ex
-
Java用户登录注册核心是厘清职责边界:前端传参、后端校验(长度/加密/状态/防暴破)、数据库约束(UNIQUE/字段设计)、SpringSecurity兜底安全,不可手写明文比对。
-
Java为基本类型提供包装类是因为JVM的泛型、集合、反射、序列化等机制只支持对象;包装类使基本类型能参与面向对象流程,如被Object引用、GC管理、支持equals()等。
-
不能。抽象类不能被实例化,故其方法无法直接调用;但子类继承后可通过子类实例调用父类非抽象方法,抽象方法则需子类实现且在多态上下文中调用。
-
Mockito创建的Mock对象不会调用真实类的构造函数,因此构造函数中对字段的初始化(如super(colour,18.99))完全被忽略;所有方法(包括getPrice())默认返回对应类型的“空值”(如Double返回null,double返回0.0),除非显式stub。
-
能。泛型擦除后List的add()方法可通过反射调用,JVM仅校验参数是否为Object类型,不检查泛型约束,添加非Integer元素不会立即报错,而是在后续强转或拆箱时抛ClassCastException。
-
interrupt()不生效的主因是线程未响应中断:纯计算循环未检查isInterrupted()、吞掉InterruptedException未重设标志、阻塞IO不响应、守护线程无法用于超时控制;可靠方案是Future+ExecutorService配合任务内中断检查。
-
LinkedHashSet是Set接口的实现类,基于哈希表和双向链表结构,既能保证元素唯一性,又能按插入顺序遍历。创建后添加元素即可自动维持顺序,重复元素不被添加;与HashSet无序、TreeSet按排序不同,LinkedHashSet性能适中且顺序稳定。删除后重新添加会置于末尾,迭代时不可直接修改集合,否则抛出异常。使用简单,无需额外编码即可确保插入顺序。
-
getItems()返回原始引用导致内部状态被篡改,因Java集合默认不拷贝、final仅锁引用不锁内容;安全做法是返回不可变视图或独立副本。
-
Java服务器中可通过jstat、jinfo、jstack及JMX/HTTP端点查看JVM信息:jstat实时监控GC与内存,jinfo查看并动态修改启动参数,jstack分析线程与锁,JMX或Actuator提供结构化指标用于监控告警。
-
本文详解如何为Circle类设计add(Circleother)方法,使其将当前圆与传入圆的面积之和,映射为一个等效的新圆,并原地更新当前圆的半径,支持链式调用。
-
Java中Base64编码应使用JDK8+内置Base64.getEncoder().encodeToString(),线程安全且无需依赖;URL安全场景用getUrlEncoder().withoutPadding();解码后需按原始编码(如UTF-8)转字符串,不可直接newString(byte[]);避免手动拼接、错误字符集处理及误当加密使用。
-
BigInteger初始化禁用空字符串或null,须校验非空再构造;运算必须用add()等方法而非+−*/;比较大小用compareTo()而非>==。
-
Java并发应从Thread和Runnable入门,先实践线程启动、共享变量可见性、sleep/join协作;再深入synchronized三种用法及锁对象本质;接着掌握ThreadPoolExecutor核心参数;最后理解CompletableFuture的执行时机与线程池选择。