-
LambdaMetafactory不是替代反射的工具,而是将反射调用转化为接近直接调用的高性能桥梁,通过MethodHandle+invokedynamic生成函数式接口实现,绕过安全检查、参数装箱与方法查找,使调用耗时从35.8ns降至2.9–3.2ns。
-
子类中定义与父类同名的成员变量会隐藏父类变量,但两者仍独立存在;通过子类对象访问时默认使用子类变量,如Childc=newChild();System.out.println(c.value)输出20,而((Parent)c).value输出10;可使用super关键字访问被隐藏的父类成员,如super.value;此现象仅适用于成员变量,方法同名则为重写,静态成员同名属于静态隐藏;建议避免同名字段以提升代码可读性。
-
首先定义Student类封装学生信息,再通过ScoreManager管理学生列表并实现按学号和姓名查询,接着使用Scanner构建菜单式交互界面,最后可扩展文件存储、HashMap优化查询及图形界面提升体验。
-
没有运行时区别,但语义和可读性差异明显:int[]a符合Java类型声明习惯,inta[]是C风格易误读;声明多个变量时int[]a,b为两个数组,inta[],b则b是int变量;初始化{1,2,3}仅限声明时使用,newint[5]支持运行时长度;类字段默认null,局部变量未初始化直接使用编译报错;方法参数用int[]更安全,利于工具识别与跨语言兼容。
-
n&1能判断奇偶是因为二进制最低位决定奇偶性:偶数末位为0,奇数末位为1;该操作在补码下对正负数均可靠,且为单周期硬件指令,比%2更高效。
-
实现轻量级IoC容器自动发现Bean的核心是准确扫描包下所有类:先用线程上下文类加载器获取file/jar资源,解码路径,再分别通过File或JarFile遍历.class文件,过滤内部类/接口/枚举,识别@Component及其派生注解,生成BeanDefinition并注册;最后实例化与依赖注入完成闭环。
-
并行排序核心是分治任务真正并行化,首选归并排序配合ForkJoinPool:按CPU核数设线程数,小规模回退Arrays.sort(),切片拷贝防冲突,合并用新数组,监控CPU、GC及窃取次数验证效果。
-
数组实现拓扑排序检测依赖环的核心是Kahn算法:用入度数组记录各变量被依赖次数,邻接表数组记录其直接依赖项;通过静态数组模拟队列进行BFS式剥离,最终若处理节点数cnt等于n则无环,否则存在环。
-
Comparator.nullsFirst()的核心作用是生成一个能安全处理null的比较器包装器,使所有null值排在非null值之前,而非null元素仍按原比较逻辑排序。
-
new触发类加载(含初始化)后分配内存并写入对象头,再自顶向下执行构造器链;反射、clone、反序列化等绕过构造器,导致字段未按预期初始化。
-
Springfox3.x在SpringBoot2.6+需配置spring.mvc.throw-exception-if-no-handler-found:false且spring.resources.add-mappings:true,访问路径为/swagger-ui/;SpringBoot3.x不兼容Springfox,须迁移到springdoc-openapi。
-
Path.iterator()不解析变量目录,仅遍历路径字符串按分隔符切分后的逻辑段;需先手动展开变量(如${HOME}),再构建Path并调用iterator()。
-
双亲委派被破坏的典型场景有四类:1.线程上下文类加载器(TCCL)用于SPI加载;2.模块化容器如OSGi实现类隔离;3.JDK自身对动态代理、Lambda等的特殊处理;4.用户自定义ClassLoader主动绕过。
-
顺序栈用top跟踪栈顶,top=-1时data[0]为首个入栈位,入栈先++top后赋值,出栈先取data[top]再--top;top=0时入栈先赋值后++top,出栈先--top再取data[top-1];所有操作须严格判空判满防越界。
-
HashMap允许null作为key和value,这是设计选择而非bug;但get()返回null时存在二义性:既可能键不存在,也可能键存在而值为null,易引发逻辑误判和偶发异常。