-
Java应用必须通过daprrun启动以与Sidecar共处同一网络命名空间,使用localhost:3500(HTTP)或localhost:50001(gRPC)通信;StateStore名称须与components/YAML中metadata.name严格一致;健康检查失败常因Sidecar未就绪或DaprHealthIndicator触发;Pub/Sub需发布端、订阅端组件名及topic路径精准匹配,且订阅路径须可被Sidecar访问。
-
排查Java异常应遵循“日志→类型→复现→修复→预防”闭环:先盯紧日志中异常堆栈顶端、位置及类型;再分清Checked/Unchecked异常并针对性处理;接着复现问题、打点调试;最后加校验、监控与防御性编程。
-
NoSuchMethodError是运行时错误,因JVM仅在运行时校验方法签名是否存在,编译期不检查;常见于类路径污染导致加载了删改方法的旧版jar。
-
Java中多态调用发生在运行时,通过invokevirtual指令结合虚方法表动态分派;需满足父类引用指向子类实例、方法非static/final/private、子类正确重写三个条件。
-
可见性是指线程修改共享变量后其他线程能否立即看到该修改;因JMM中线程工作内存与主内存分离,且存在缓存、优化和重排序,导致修改未及时同步,从而引发可见性问题。
-
main方法必须是static的,因为JVM启动时未创建任何对象,需直接通过类名调用;其publicstaticvoidString[]签名是JVM规范强制要求,确保启动过程简单、确定且生态兼容。
-
本文详解如何在Android应用被用户彻底关闭(如从最近任务列表滑除、长按Home键清除)时可靠触发清理逻辑,指出onDestroy()的局限性,并提供基于Application.ActivityLifecycleCallbacks的健壮实现方案。
-
break只跳出最内层循环,continue跳过本次迭代,return终止整个方法;三者作用域不同,混用易导致逻辑错误,应优先用return简化控制流。
-
Javaswitch直接用枚举值最安全可读,避免ordinal()或name();需显式覆盖所有枚举常量防逻辑遗漏;复杂行为宜用枚举方法绑定;Java14+switch表达式可防穿透并支持返回值。
-
标记-清除算法易致OOM因内存碎片化,无法满足大对象连续空间需求;新生代用标记-复制因存活率低且需Survivor区容下幸存者;老年代稳态选标记-整理,但G1/ZGC已通过分区+局部整理兼顾低停顿与防碎片。
-
怎么用spring-cloud-starter-gateway启动最简网关SpringCloudGateway不能standalone运行,必须依赖SpringBootWebFlux,且不能引入spring-boot-starter-web(否则启动失败)。常见错误是照着旧版SpringCloudNetflix教程加了MVC依赖,结果报ApplicationContextException:Unabletostartreactivewebserver。
-
compareTo返回负数表示当前字符串字典序小,0表示相等,正数表示字典序大;具体值为首个不同字符Unicode码点之差,不可用==-1判断小于关系。
-
必须用logger.error(String,Throwable)传异常对象,否则丢失堆栈;日志配置需含%ex或%xEx才输出堆栈;资源关闭异常不可吞没;ERROR仅用于影响稳定性的异常,校验类失败用WARN。
-
当使用ApacheTika的tika.parseToString(file)解析文本文件却得到空字符串时,根本原因通常是缺失必要的解析器模块(如tika-parsers-standard-package),导致Tika回退至空解析器(EmptyParser),而非抛出异常。
-
Collectors.toMap抛出IllegalStateException:Duplicatekey是因Map的key必须唯一,而输入key列表存在重复值;解决方式包括校验数据、使用mergeFunction处理冲突或显式指定map工厂。