-
最简单的方法是使用Collections.reverse(),它直接修改原列表顺序。示例:Listlist=Arrays.asList("A","B","C");Collections.reverse(list);输出为[C,B,A]。若要保留原列表,可先复制再反转:Listreversed=newArrayList(original);Collections.reverse(reversed)。
-
依赖关系是类间“使用但不拥有”的弱耦合联系,体现为方法参数、局部变量、静态调用或返回值,不通过字段持有实例,区别于关联、组合与继承;Spring通过依赖注入解耦,提升可测试性与可替换性。
-
可见性问题指线程修改共享变量后其他线程可能无法立即看到,根源在于工作内存与主内存不一致及指令重排序;volatile强制读写主内存并禁止重排序,synchronized和Lock通过内存屏障保障可见性与原子性,原子类和线程安全容器也提供可靠可见性保障。
-
需要自定义业务异常,因为Java默认异常无法准确表达“用户余额不足”等业务语义,易混淆bug与合理拦截;应分层定义领域异常、应用异常、接口异常,并统一继承RuntimeException、提供多构造器、使用规范错误码。
-
强引用阻止GC回收,弱引用在GC时立即回收,软引用在内存不足时回收,虚引用不阻止回收仅用于跟踪回收时机。
-
LinkedBlockingQueue是Java中基于链表的阻塞队列,支持有界和无界模式,常用put/take实现生产者-消费者模型,适用于线程池任务队列及多线程解耦通信。
-
可见性是指线程修改共享变量后其他线程能否立即看到该修改;因JMM中线程工作内存与主内存分离,且存在缓存、优化和重排序,导致修改未及时同步,从而引发可见性问题。
-
retainAll本质是原地保留交集,直接修改调用方集合;需浅拷贝保原集合、确保equals/hashCode正确实现;参数为null抛NPE;性能优化关键在于将参数转HashSet以使contains达O(1)。
-
Future.get()默认阻塞,需用超时重载或isDone()判断;抛出InterruptedException、ExecutionException、TimeoutException须分别处理;禁在UI/Servlet主线程调用;cancel()不保证资源清理,任务需自行响应中断。
-
SpringBoot应用部署后大文件(>100MB)上传返回503错误,请求甚至未到达控制器——根本原因常是multipart功能未显式启用,而非仅配置大小限制。
-
逻辑运算符用于布尔操作,包括逻辑与(&&)、或(||)、非(!)。&&要求两边均为true结果才为true,具有短路特性,左侧为false时右侧不执行;||只要一边为true结果即为true,左侧为true时短路;!用于取反,优先级最高。注意区分&与&&,避免副作用操作,混合使用时加括号确保优先级正确。
-
不可变类通过final修饰类和字段确保状态不可变,如Person类;需对可变对象进行防御性拷贝,如ImmutableDate中复制Date对象;不提供setter或修改方法,仅保留getter;构造函数避免this引用泄露,保证初始化安全。String和Integer是典型示例。
-
Collections.copy()方法将源列表元素复制到目标列表,要求目标列表长度不小于源列表。示例中使用Arrays.asList初始化目标列表大小,避免IndexOutOfBoundsException。关键点:目标列表必须预先具备足够容量,否则抛异常;元素被覆盖但长度不变。常见错误是目标列表为空或过短,需通过初始化占位符修正。适用于ArrayList等List实现,不适合Set、Map。性能好但依赖目标列表就绪,适合固定结构列表的批量更新。
-
封装通过类将数据和方法绑定,隐藏内部细节,提升安全性与可维护性;2.继承使子类复用父类属性和方法,建立层次关系;3.多态通过方法重写实现不同行为,增强扩展性;4.抽象通过抽象类和接口定义核心功能,分离“做什么”与“怎么做”。理解四者有助于以对象视角设计清晰、易维护的代码。
-
永久设置JDK环境变量需将JAVA_HOME、PATH(含$JAVA_HOME/bin)写入Shell配置文件并确保加载;推荐用户级修改~/.bashrc或~/.zshrc,或系统级新建/etc/profile.d/java.sh,最后验证java-version和$JAVA_HOME。