-
分布式登录核心是凭证统一管理与跨服务校验,推荐JWT实现无状态认证,配合Redis支持主动踢出,网关层统一鉴权并透传用户信息,兼顾高效性与可控性。
-
DelayQueue要求元素实现Delayed接口,否则poll()始终返回null;需用绝对时间戳实现getDelay()和compareTo(),并配守护线程消费任务。
-
getClass()返回对象实际运行时类型而非声明类型,因Java动态绑定;它不能获取泛型信息,不适用于基本类型,且受类加载器隔离影响。
-
Java中查找集合重复元素最常用高效方式是HashSet,利用add()返回false识别重复;需频次统计则用HashMap;Stream适合简洁场景;自定义对象须重写equals和hashCode。
-
GCRoots是JVM判断对象存活的起点,包括Java线程对象、栈帧局部变量、已加载Class对象、JNI全局引用及JVM内部关键对象;Reference子类实例自身是Roots,但其referent不是。
-
答案:通过定义Employee类和PayrollSystem类,实现员工信息封装与工资计算功能。Employee类包含姓名、工号、基本工资等属性,提供calculateSalary()方法计算总工资(基本工资+加班费),并用displayInfo()输出工资详情;PayrollSystem类使用List存储员工对象,支持添加员工和批量显示工资信息;主程序创建两个员工实例并输出其工资,展示了面向对象的封装与方法调用;可扩展考勤扣款、不同职位规则、用户输入、数据持久化和异常处理等功能,提升系统实用性。
-
封装是将数据与操作打包为类并私有化成员变量,通过publicgetter/setter方法控制访问;目的是防止非法状态、隔离变化和降低耦合,体现为默认private属性、按需提供带校验的存取方法。
-
dowhile循环先执行后判断,循环体至少执行一次;语法为do{...}while(条件);末尾必须加分号;适用于需确保操作至少发生一次的场景。
-
答案:通过Java的Socket编程和多线程技术实现聊天室,服务器端使用ServerSocket监听端口,为每个客户端创建ClientHandler线程处理消息接收与广播,维护客户端输出流列表实现消息转发,客户端通过输入输出流与服务器通信,分别用独立线程处理消息发送与接收,支持多用户实时群聊,可扩展用户名、私聊等功能。
-
静态成员属于类,被所有实例共享,通过类名调用;实例成员属于对象,每个实例独立拥有。
-
Java处理图片的核心在于java.awt.image包和javax.imageio包,它们提供了读取、修改和保存图片的API。1.图片处理基本流程:使用ImageIO.read()将图片读取为BufferedImage对象,通过Graphics2D或直接操作像素进行修改,再使用ImageIO.write()保存结果。2.Java支持的常见图片格式包括JPEG(有损压缩,适合照片)、PNG(无损压缩,支持透明)、GIF(256色,支持动画)和BMP(无压缩,文件大)。3.裁剪使用BufferedImage
-
<p>Lambda表达式是Java8引入的函数式编程特性,可将代码作为数据传递,简化匿名内部类写法。其语法为(参数)->{操作},依赖函数式接口(如Runnable、Comparator)。常用于集合排序与遍历,如names.sort((a,b)->a.length()-b.length()),显著提升代码简洁性与可读性。</p>
-
parallelStream是Collection接口提供的并行流方法,利用Fork/Join框架将流操作分解为多线程任务以提升大数据计算性能,适用于计算密集型场景,使用时需注意线程安全、任务粒度和I/O阻塞等问题。
-
Java使用java.util.zip包实现文件压缩与解压,核心类为ZipOutputStream和ZipInputStream。1.压缩文件:通过创建ZipOutputStream,遍历文件并为每个文件创建ZipEntry,将其内容写入流中;2.压缩文件夹:递归遍历文件夹内容,将每个文件及子文件夹以相对路径添加到ZipOutputStream中,保持目录结构;3.常见问题及解决:中文乱码可通过构造ZipOutputStream和ZipInputStream时指定UTF-8编码解决;资源未关闭应使用try
-
Java并发中内存可见性必须依赖JMM同步机制:volatile保证单变量读写可见但不保证原子性;synchronized通过锁的清空+刷出保障可见性与原子性;final字段在正确发布前提下提供初始化值的天然可见性。