-
要在SpringCloudGateway中实现API限流,核心步骤包括:1.添加依赖:引入spring-cloud-starter-gateway和spring-boot-starter-data-redis-reactive模块,并可选支持Lua脚本的Redis配置;2.配置限流策略:使用RedisRateLimiter工厂类,在application.yml中定义replenishRate(每秒补充令牌数)、burstCapacity(最大突发容量)及key-resolver(限流维度)等参数;3.定
-
synchronized实例方法锁的是this对象而非方法本身,等价于synchronized(this),因此同一对象的多个同步方法互斥,不同对象则不互斥;静态方法锁Class对象;synchronized代码块需显式指定锁对象,应避免用this、字符串常量等;wait/notify必须在synchronized块中调用以确保线程安全;JDK6后synchronized经优化(偏向锁、轻量级锁等)在低竞争下性能接近ReentrantLock。
-
判断字符串是否为空或仅含空白字符:Java11+用isBlank(),Java8及以前需null检查后trim().isEmpty();substring()在Java7u6后改为复制数组防内存泄漏,Java9起优化为O(1);split()默认丢弃末尾空串,可用负limit保留;拼接优先用String.join()或StringBuilder,避免循环中用+。
-
本文介绍如何利用Java的ToIntFunction等函数式接口替代条件判断,为集合中的对象动态选择任意getter方法执行聚合操作,从而避免冗余的if/else或switch语句,提升代码可扩展性与可维护性。
-
FileNotFoundException是IOException的受检子类,反映JVM无法以指定方式打开路径,原因包括权限不足、目录误用、符号链接断裂等,不单是文件不存在。
-
ConcurrentHashMap更适合高并发场景,因其采用分段锁(JDK7)或CAS+synchronized(JDK8+),仅锁定修改的桶且读操作无锁;而Hashtable所有方法用synchronized修饰,竞争全局锁。
-
Java枚举通过为每个常量重写抽象方法(如nextState(Event))封装状态转移逻辑,避免if-else或switch分散维护;需传入不可变Context处理条件转移,序列化时须用@JsonCreator/@JsonValue显式控制。
-
Java类不能多重继承,根本原因是避免菱形继承问题导致的歧义;但可通过多实现接口(含default方法)和组合委托来安全替代。
-
数组越界由访问非法索引引发,应通过校验索引、使用length属性和集合类避免。例如循环中用arr.length而非固定值,访问前检查index>=0&&index<arr.length,可有效防止ArrayIndexOutOfBoundsException。
-
使用ConcurrentHashMap、Future+Callable、ReadWriteLock或Caffeine等方案可实现Java线程安全缓存。1.ConcurrentHashMap适用于高并发读写场景,通过分段锁或CAS保证线程安全;2.Future方案结合原子操作避免多线程重复计算,提升性能;3.ReadWriteLock提供读写锁分离,适用于强一致性要求的批量更新;4.推荐使用Caffeine或GuavaCache等成熟库,内置线程安全与自动加载机制,简化开发。核心是避免竞态条件并控制读写互斥
-
读写锁是针对“读多写少”场景设计的协作机制,通过分离读锁(可共享)和写锁(独占)提升并发性能,适用于本地缓存、配置热加载等典型场景。
-
Java跨平台的核心是JVM和字节码:源码编译为与平台无关的.class字节码,由各平台JVM统一加载、校验、解释或JIT编译执行,并封装系统差异;标准类库按规范实现,保障行为一致,但需注意路径、换行符等隐含依赖。
-
Java中switch语句支持byte、short、int、char、枚举、String及对应包装类,不支持long、double等;case需常量且不可重复,省略break会导致贯穿;default非必需但建议添加以增强健壮性。
-
BlockingQueue是Java中实现生产者消费者模式的线程安全队列,其put/take方法在队列满或空时自动阻塞,确保线程协作;常用实现有ArrayBlockingQueue、LinkedBlockingQueue等,结合线程池可提升并发处理能力,适用于高可靠数据传递场景。
-
Java中不推荐使用Thread.stop(),因其会立即终止线程,导致锁未释放引发死锁、finally块不执行造成资源泄漏、对象状态损坏及不变量被破坏;应改用interrupt()协作式中断机制。