-
HttpMediaTypeNotSupportedException本质是客户端Content-Type与服务端consumes声明或@RequestBody使用不匹配。需检查三处:客户端实际请求头、控制器consumes属性、是否遗漏@RequestBody;禁用混用@RequestBody与@RequestParam;Feign调用需显式设Content-Type头。
-
能,但仅限子类重写父类方法时返回更具体的子类型,即协变返回类型;要求父类返回类类型,子类返回其子类,且必须使用@Override。
-
Collections.max和min用于获取集合极值,支持自然排序与自定义Comparator比较,如按字符串长度找最长最短,使用时需确保集合非空且元素可比较,时间复杂度O(n),适用于中小规模数据。
-
反射调用比直接调用慢10倍以上,核心在于JVM层动态查元数据、权限检查、参数校验及无法内联;高频路径须缓存Method/Field,优先用MethodHandle或成熟框架替代手写反射。
-
TestRunner插件不识别@Test方法,主因是项目未被正确识别为Java项目或构建配置未加载,需检查Java扩展包、pom.xml/build.gradle、执行Java:ReloadProject、确认JDK配置,并确保JUnit5依赖正确声明。
-
JVM规范未规定boolean大小,实际取决于上下文:字段占1字节(对齐填充),数组元素占1字节(底层为byte[]),局部变量可能不存内存;javap显示其运算按int处理,数组不支持位图因规范未要求且HotSpot复用byte[]实现。
-
final关键字用于限制类和方法的修改,提升代码安全与性能;final类不可继承,适用于不可变类和安全敏感类,如String;final方法不可重写,用于保护核心逻辑,如银行存款操作。
-
Arrays.binarySearch用于在已排序数组中高效查找元素,1.调用形式为intindex=Arrays.binarySearch(array,key),返回目标索引或负值;2.未找到时返回-(插入点)-1,表示应插入位置以维持有序;3.可指定搜索范围fromIndex到toIndex(左闭右开),如Arrays.binarySearch(arr,1,4,3)在子区间查找;4.支持基本类型和对象数组,对象比较需实现Comparable或使用Comparator,如String.CASE_INSE
-
先设置全局JDK再配置默认项目选项。打开ProjectStructure添加JDK,进入NewProjectsSetup设置ProjectSDK和languagelevel,再在Compiler中设定字节码版本,确保新建项目自动使用指定Java版本。
-
LinkedList最适合频繁在头尾增删元素的场景,因其addFirst、removeLast等操作均为O(1);但随机访问慢、内存占用大、缓存不友好,不宜用于大数据量索引查找。
-
本文详解LeetCode1389题「创建目标数组」的正确解法:根据索引数组index中指定的位置,将nums中的元素逐个插入到动态增长的目标数组中,关键在于使用ArrayList.add(intindex,Eelement)实现O(1)平均复杂度的中间插入。
-
使用toArray()方法可将集合转为数组,推荐调用带参数的toArray(T[])并传入长度为0的目标类型数组(如newString[0]),以确保类型安全且性能更优。
-
抽象类不能被实例化,因其表达不完整概念(如Animal),编译器禁止new操作;它通过abstract方法强制子类实现,通过具体方法复用逻辑,并支持状态共享、构造初始化和继承约束。
-
Path比File更灵活,能跨平台处理路径逻辑;Files类封装90%以上基础IO操作,提供walk()高效遍历和清晰异常体系。
-
Java轻量推荐功能可用协同过滤、内容匹配和热度兜底三策略实现:用HashMap存用户行为并按交集算相似度;依标签重合匹配物品;冷启动时以加权热门队列补足,辅以Caffeine缓存与统一接口设计。