-
JVM规范未规定boolean大小,实际取决于上下文:字段占1字节(对齐填充),数组元素占1字节(底层为byte[]),局部变量可能不存内存;javap显示其运算按int处理,数组不支持位图因规范未要求且HotSpot复用byte[]实现。
-
静态方法不能访问实例变量,因为静态方法属于类且随类加载,而实例变量属于对象、对象未创建时实例变量不存在。静态方法无this引用,无法访问需通过this调用的实例变量,编译器禁止此类操作以确保安全。若需访问,必须先创建对象再通过对象调用。
-
SynchronousQueue不存储元素,每个put需等待take完成,适用于线程间直接协作,如生产者-消费者模型、即时任务处理及高并发线程池等场景。
-
Java的Character.UnicodeBlock并非枚举类型,无法直接调用values()获取全部实例;本文介绍一种安全、可靠且无需外部依赖的反射方案,通过遍历其静态字段动态收集所有预定义Unicode区块。
-
类是模板,对象是实例;类无状态不能直接调用非静态成员,new才生成独立对象并分配堆内存,引用传递导致共享修改,需警惕空指针与数据污染。
-
TreeMap无法按value排序,正确做法是将entrySet转为List后用自定义比较器排序,再通过Collectors.toMap转回LinkedHashMap;需注意null值处理、类型匹配及构造参数。
-
异常是程序运行中的不正常事件,Java通过try-catch-finally和throw、throws机制处理,将异常封装为Throwable的实例;Exception表示可处理的异常,Error表示系统级错误;使用try捕获、catch处理、finally释放资源;受检异常需显式处理,非受检异常为运行时异常;可自定义异常类继承Exception或RuntimeException,并用throw抛出,提升程序健壮性。
-
不推荐直接用Executors创建线程池,因其默认无界队列易致内存溢出、未指定线程工厂、缺乏自定义拒绝策略;阿里Java手册明确禁止,推荐直接使用ThreadPoolExecutor。
-
本文介绍如何在Android应用中实现类似iOSSKStoreProductViewController的原生内嵌式应用推广能力,即不离开当前App即可唤起GooglePlay商店目标应用详情页,支持深度链接、异常降级与用户体验优化。
-
Java简单搜索应优先用ArrayList/HashMap配合stream().filter()实现内存模糊匹配,TreeSet结合subSet()支持大小写不敏感前缀搜索,需预处理null和空值并避免无效搜索。
-
static字段+私有构造非万能单例,因类初始化即创建实例,不适用于依赖外部资源或需延迟加载的场景;DCL必须用volatile防半初始化;枚举单例线程安全但无懒加载;Springsingleton是容器级而非JVM级。
-
答案:为防止敏感信息泄露,Java应用应统一处理异常,避免暴露原始错误信息。具体措施包括:使用@ControllerAdvice统一返回通用提示;对日志中的手机号、身份证等敏感数据进行脱敏;封装自定义异常以模糊认证失败等敏感原因;控制日志级别,禁用DEBUG/TRACE,限制详细日志访问;包装第三方异常以清除请求上下文。核心原则是对外模糊、对内可追踪、日志受控、异常封装。
-
工厂模式通过封装对象创建过程,使调用者无需依赖具体类,仅通过统一接口获取实例,降低耦合、提升扩展性。1.解耦对象创建与使用:工厂类负责实例化具体产品,使用者面向接口编程,避免直接new导致的强依赖。2.支持开闭原则:新增产品时只需扩展工厂逻辑,无需修改客户端代码,如Factory.create("C")可透明支持新类型。3.常见形式包括简单工厂(集中创建)、工厂方法(子类决定创建)、抽象工厂(创建产品族)。4.广泛应用于JDBCDriverManager、SpringBeanFactory、日志框架等场景
-
EnumSet比HashSet快因用long/long[]作位向量,操作均为O(1)位运算,无哈希冲突与装箱开销;但仅支持编译期已知的单一枚举类型。
-
答案:Java中UUID是128位全局唯一标识符,常用Version4随机生成,通过UUID.randomUUID()创建,适用于分布式系统主键、会话ID等场景,具有高唯一性且线程安全,但需注意其长度较大可能影响存储与索引性能。