-
Collections.sort()本质是委托List.sort()原地排序,仅支持List子类,不返回新列表;依赖元素实现Comparable或传入Comparator,需防null、不可变列表及并发问题。
-
Java中将集合转为不可变对象的核心是避免后续修改,推荐使用JDK9+的List.of()、Set.of()、Map.of()等工厂方法;Java8可借助Collections.unmodifiableXXX()(需先防御性拷贝);工程级项目建议用Guava的ImmutableList等类。
-
Java中过滤集合数据最常用、最推荐的方式是使用StreamAPI配合Lambda表达式,通过filter()接收Predicate筛选元素并生成新集合,支持链式操作、null防护及并行处理,是现代Java的标准解法。
-
Java异常定位关键在解读三层信息:出错行、异常对象状态、触发路径;需结合异常类型、堆栈首自定义类、日志上下文及工具验证根因。
-
下载JDK并安装,推荐JDK17或JDK21版本;2.配置JAVA_HOME环境变量并添加bin路径到Path;3.使用java-version和javac-version验证安装成功。
-
HashSet底层基于HashMap实现,key存元素、value为共享的PRESENT对象;其唯一性依赖hashCode()和equals()协同,二者必须同时重写且逻辑一致,否则导致重复;null值被特殊支持,可变对象修改后可能无法查找。
-
答案:基于Java面向对象设计,实现学生信息的增删改查及统计功能。通过Student类封装数据,StudentManager管理集合,结合Scanner交互完成控制台成绩管理系统。
-
隐式类型转换是Java中自动将小范围数据类型向大范围类型转换的过程,遵循byte→short→int→long→float→double的顺序,char可转为int及以上类型;赋值和运算时低精度类型会自动提升为高精度类型,如int与double运算时int被提升为double;byte、short、char在运算中默认提升为int,不可直接赋回byte等窄类型;该转换仅限安全方向,反向需强制转换。
-
并行流是Java8StreamAPI基于Fork/Join框架实现的并行处理机制,通过parallelStream()将任务拆分多线程执行,适用于大数据量、计算密集型且无共享状态的场景,能有效提升多核CPU利用率,但需避免用于IO操作、注意线程安全与数据结构选择,并可自定义线程池以优化性能。
-
类变量使用static修饰,属于类本身,存储在方法区(元空间),仅一份副本,被所有实例共享;实例变量属于对象实例,每创建一个对象就在堆中分配独立内存,各实例互不影响。
-
Java配置本地WebSocket环境首选SpringBoot:添加spring-boot-starter-websocket依赖,编写@Configuration类注册Handler,继承TextWebSocketHandler处理消息;纯Servlet方式需容器支持JSR-356,用@ServerEndpoint注解定义端点。
-
Java接口默认方法能实现,是因为从Java8起JVM规范和字节码指令层面原生支持default方法,编译器将其标记为ACC_PUBLIC与ACC_DEFAULT并保留Code属性,JVM运行时通过增强的invokeinterface指令按“类优先、最近优先”规则解析调用。
-
构造方法用于初始化对象,需与类同名且无返回类型。Java在未定义时提供默认无参构造,一旦自定义则不再自动提供。通过重载可实现多种初始化方式,并可用this()复用构造逻辑。私有构造方法限制实例化,常用于单例模式。构造中应进行参数验证并抛出异常以确保对象状态合法,提升程序健壮性。
-
答案是重写equals和hashCode后用Set或Stream去重。需根据业务字段重写equals和hashCode方法,再利用HashSet、LinkedHashSet或Stream的distinct实现去除自定义对象重复,注意可变字段可能引发集合行为异常。
-
答案:Java聊天室通过ServerSocket与多线程处理连接,使用ConcurrentHashMap管理在线用户,结合心跳机制检测上下线状态,并广播列表更新。1.每个客户端由独立ClientHandler线程处理通信;2.在线用户信息存于线程安全Map,支持私聊与状态维护;3.上下线通过连接建立、主动退出或IO异常触发,配合心跳检测;4.用户变更时服务端生成列表并推送至所有客户端,确保实时同步。