-
线程池拒绝任务是正常流控行为,发生在workQueue已满且线程数达maximumPoolSize时,由所选拒绝策略决定处理方式;默认AbortPolicy抛异常,CallerRunsPolicy交由调用线程执行,DiscardPolicy静默丢弃,DiscardOldestPolicy丢弃队列头任务后重试,自定义策略需解决记录与补偿问题,避免递归提交、阻塞操作及线程安全漏洞。
-
ServiceLoader加载不到实现类主因是META-INF/services位置错误或接口全限定名拼写错误;必须置于classpath根目录(如Maven的src/main/resources/META-INF/services/),文件名须为接口全限定名,内容为实现类全名,且实现类需有public无参构造器;Java9+模块化需在module-info.java中声明provides;其核心价值在于编译期解耦,运行时动态加载,支持插件扩展与多实现共存,但无优先级、条件加载等高级能力。
-
Java通过接口多继承实现行为组合,类可实现多个接口以获得多种能力,如Duck类实现Flyable和Swimmable接口具备飞行与游泳功能;接口可多继承且支持default方法,若两接口含同名default方法,实现类必须重写以解决冲突;接口仅定义行为契约不包含状态,避免了类多继承的复杂性,体现了职责分离原则。
-
String.repeat()是Java11+新增的字符串重复方法,调用str.repeat(n)返回重复n次的新字符串,要求n≥0且str非null,底层基于数组复制优化,性能优于手动循环,但需注意不可见字符重复后的显示问题及JDK版本兼容性。
-
静态变量能被类直接访问,因其在类加载时分配内存并存储于方法区,所有实例共享且无需对象即可通过类名访问。
-
答案:通过Java面向对象设计,将题目封装为抽象基类Question,子类实现具体题型,使用ArrayList管理试卷,遍历题目并调用多态方法checkAnswer实现自动评分,最终统计总分与答题表现。
-
应优先采用用户级安装而非系统目录,即解压JDK到$HOME/jdk并配置JAVA_HOME与PATH;若需系统级安装,须排查SIP、挂载选项、update-alternatives及shell缓存等四层机制。
-
同一个类的两个对象是否相等取决于类加载器;即使类名和字节码相同,不同类加载器加载的类被视为不同类,其实例无法通过类型比较或equals判断,常见于Web容器、OSGi、热部署等场景,需确保关键类由同一类加载器加载以避免问题。
-
子类同名变量访问不到父类值是因为作用域屏蔽而非覆盖;Java中由声明类型决定访问哪个变量,C++中需用Parent::name显式访问父类变量。
-
Java线程池高并发处理关键在避免用错类型、配错参数、漏掉拒绝策略;需按IO/CPU密集型合理设corePoolSize与队列,优先submit()捕获异常,自定义拒绝策略联动监控,分业务隔离线程池,并正确shutdown。
-
抽象类该有构造函数,且通常必须有;它不能是private,推荐用protected修饰,子类构造器需显式调用super(...)。
-
程序计数器只存当前线程正在执行的字节码指令地址(如0x000a),是线程私有、静态分配、无溢出风险的极小内存区域,不会触发OutOfMemoryError。
-
Java文件预览核心是服务端解析+前端轻量渲染,分层处理:底层解析、中间转换、上层展示;支持PDF(PDFBox/pdf.js)、Office(POI)、文本(highlight.js)、图像等格式,强调安全校验、异步转码、缓存与插件扩展。
-
静态方法不能访问实例变量,因为静态方法属于类且随类加载而存在,早于对象创建;实例变量属于对象,仅在new出对象后才分配内存。若允许静态方法直接访问实例变量,可能导致访问尚未存在的变量,故Java禁止此操作。正确方式包括:创建对象后通过实例引用访问、将变量声明为static或把方法改为非静态。核心是静态属于类层级,实例属于对象层级,生命周期不匹配。
-
synchronized无法解决分布式秒杀超卖问题,因其仅作用于单JVM实例;高并发需Redis+Lua或数据库行锁+乐观锁;AtomicInteger仅保障单机原子读写,不支持“查-判-减”复合操作。