-
Thread类是Java多线程核心,start()启动新线程并执行run();sleep()使当前线程休眠且不释放锁;join()让当前线程等待目标线程结束;currentThread()等方法用于获取线程信息与状态。
-
UnsupportedOperationException是运行时异常,用于表示操作不被支持,常见于部分实现的接口或不可变集合,可通过thrownewUnsupportedOperationException("消息")手动抛出,并建议提供清晰的异常信息以增强代码可维护性。
-
Java对象默认分配在堆上,但逃逸分析可使未逃逸对象栈上分配或标量替换;对象头含MarkWord和KlassPointer,字段按类型重排并8字节对齐;TLAB优化内存分配,new慢主因是初始化与GC压力。
-
JavaMailAPI发送邮件前必须确认的三件事不配对SMTP服务器和认证方式,代码跑得再顺也发不出去。JavaMail不是“写完就能发”,它本质是把你的邮件内容打包成标准协议数据,扔给SMTP服务器——而这个服务器是否接受你、是否要登录、走不走TLS,全由你填的配置决定。host和port必须匹配:比如用smtp.gmail.com就不能配25端口(默认被禁),得选587(STARTTLS)或465(SSL)大多数现代邮箱(Gmail、Outlook、QQ邮箱
-
多线程核心价值是提升CPU利用率和整体吞吐量,通过让等待I/O的线程释放CPU给其他任务执行;需用线程池复用线程,避免频繁创建销毁;共享变量须用volatile、synchronized或AtomicInteger等机制同步;线程协作优先选用BlockingQueue、CountDownLatch等高级并发工具。
-
活锁现象怎么一眼认出来程序没卡死,线程都在跑,CPU占用正常,但业务逻辑就是不往前走——比如两个线程反复回退重试、互相谦让资源,Thread.getState()一直显示RUNNABLE,日志里却不断刷出“重试第1次”“重试第2次”……这不是死锁,是典型的活锁。常见于基于乐观锁的重试逻辑,比如用AtomicInteger.compareAndSet()或JPA的@Version字段更新失败后立刻重试,又没加延迟或退避机制。为什么固定间隔重试反而加剧活锁多个线程在相同节奏
-
ClassCircularityError发生在类加载阶段,是JVM因类间静态初始化循环依赖而主动中止加载的Error;它不同于Spring循环依赖,编译通过但运行时触发即崩溃,无法捕获,需切断static初始化闭环。
-
应使用SecureRandom而非Random,因其基于系统熵源、抗预测性强;双色球需用shuffle候选列表实现去重与均匀分布,并对红球升序排列;控制台交互须防护输入异常,输出宜用Unicode方块字符跨平台对齐。
-
本文详解如何使用Jackson将含冗余属性(如class、resolves-to)的XML安全转换为简洁JSON,重点实现属性过滤与<lexicalValue>文本提取,无需预定义类或注解。
-
BitSet在并发场景下不安全,需用分段BitSet+LongAdder实现无锁去重;分段大小宜选65536,通过segment=value>>>16定位段,再对低位操作;排序输出时按段调用nextSetBit(0)即可天然有序。
-
不能用String.compareTo()比较版本号,因其按字典序导致"2.10"<"2.9"错误;应拆分"."后逐段转整数比较,注意空段处理与需求对齐。
-
final关键字在Java中用于限制类、方法和变量的修改。1.final类不能被继承,如MathUtils或String类,防止行为被篡改;2.final方法不能被子类重写,确保核心逻辑不变,如Animal类的breathe方法;3.final变量一旦赋值不可更改,包括继承体系中的成员变量,必须在构造前初始化,且子类无法修改父类的final字段。合理使用final可增强代码安全与稳定。
-
Java算术运算符含+、−、*、/、%五种,支持数值计算与字符串拼接(仅+),整数除法截断小数,%余数符号同被除数,++/--分前置后置影响求值顺序。
-
答案:Java中多维数组是“数组的数组”,常用二维数组,支持声明时指定维度或使用不规则数组;可通过嵌套循环遍历,推荐增强for循环;常见操作包括复制(注意深拷贝)、查找极值、矩阵转置及用List替代实现动态扩容;需注意索引越界和空引用问题。
-
Saxon不原生支持类似JXPath的“Java对象→XML节点视图”映射,但可通过将JavaMap显式转换为XPath3.1原生数据类型(如map(*))实现等效功能,需调整表达式语法并使用Saxon的XDM模型进行绑定。