-
ArrayList基于动态数组,适合随机访问和读取频繁场景;LinkedList基于双向链表,适合频繁增删操作;日常优先选ArrayList,特定需求如队列用LinkedList。
-
Collections提供排序、查找、修改及视图封装等静态方法:sort支持自然/自定义排序,reverse反转,shuffle随机打乱,rotate循环移位;binarySearch需预排序,max/min/frequency用于极值与频次统计;swap、replaceAll、fill、copy实现元素交换、替换、填充与复制;emptyList/singletonList返回不可变轻量视图,unmodifiableXXX提供只读代理,synchronizedXXX增强线程安全。
-
Java发送HTTP请求主要有HttpURLConnection和HttpClient两种方式:前者适用于JDK低版本且无需额外依赖,后者自JDK11起内置,支持同步异步、HTTP/2,API更简洁现代,推荐新项目使用。
-
DataAccessException是Spring对JPA原生异常的统一包装结果,需通过Spring管理的EntityManagerFactory和事务代理才能触发转换,手动获取EntityManager或显式flush会绕过该机制,导致异常未被正确映射。
-
Java7+multi-catch语法为catch(E1|E2e),要求异常类型互不兼容,变量e为最近公共父类类型且final;等价于多个相同逻辑的单catch,但禁止后续宽泛catch重复捕获。
-
新项目应选用slf4j+logback,而非java.util.logging;因JUL配置僵硬、MDC支持弱、异步难实现,而slf4j+logback灵活高效且生态完善,需确保classpath有且仅有一个绑定实现(如logback-classic)。
-
线程是Java中能独立执行代码的最小单位,一个程序至少有一个主线程;进程是操作系统分配资源的基本单位,线程是进程内的执行单元,共享内存但栈独立;创建线程推荐实现Runnable接口;线程状态包括NEW、RUNNABLE、BLOCKED、WAITING、TERMINATED;多线程用于提升CPU密集型和I/O密集型任务效率及GUI响应性,但需防范竞态、死锁等问题。
-
ConcurrentHashMap通过分段锁与无锁读实现高性能线程安全:读操作无锁靠volatile,写操作仅锁单个桶,扩容等用CAS,避免HashMap的环形链表和Hashtable的全局锁瓶颈。
-
Java中变量作用域由代码块{}界定,局部变量在声明的块内有效且遵循嵌套访问与遮蔽规则,如for、if块中声明的变量仅限块内使用,外层不可见,体现事实上的块级作用域特性。
-
能,Java9+接口中支持private方法,用于复用default或static方法的公共逻辑,避免重复代码,但不可被实现类访问或重写,且不能与static同时使用。
-
Java8+推荐使用java.util.Base64,提供标准、URL安全和MIME三类编码器;编码需显式指定UTF-8字符集,解码失败多因输入含空白、URL编码或长度非4倍数;withoutPadding()去除填充符=,适用于URL/Token场景;与ApacheCommonsCodec混用需注意填充、换行及严格性差异。
-
Java无法强制终止线程,唯一安全方式是协作式中断:线程需主动检查interrupt()标志并优雅退出,配合isInterrupted()、正确处理InterruptedException及资源清理。
-
ConcurrentLinkedDeque是基于CAS无锁算法实现的线程安全双端队列,适用于高并发低争用场景;支持两端高效增删、弱一致性迭代器、非实时size(),不允null元素,适合工作窃取、日志缓冲等最终一致性场景。
-
finally总在try或catch执行完后、方法返回前执行,无论是否异常或return;若finally含return则覆盖原返回值;System.exit()等极少数情况不执行。
-
答案:Java中解析XML需通过try-catch处理SAXParseException、ParserConfigurationException、SAXException和IOException等异常,结合DOM、SAX或StAX方式,捕获后可定位错误位置并提升系统健壮性。