-
CountDownLatch通过计数器实现线程等待,初始化指定数量,调用countDown()减一,await()阻塞至计数为零,适用于主线程等待多个任务完成的场景。413 收藏 -
for-each遍历时调用remove()会抛ConcurrentModificationException,因modCount与expectedModCount不一致;正确做法是用Iterator.remove()、removeIf()或倒序for循环。330 收藏 -
类是模板,对象是用new创建的具体实例;类不占内存、不能执行方法,仅描述结构,真正存储数据和执行行为的是对象,每个对象拥有独立字段值,静态成员除外。452 收藏 -
Collectors.summarizingLong用于提取流中元素的long值并生成包含计数、总和、最值和平均值的LongSummaryStatistics对象,适用于需一次性获取多项统计指标的场景。420 收藏 -
Flink中自定义RichSinkFunction因同步I/O或不当广播导致任务严重阻塞,可通过移除冗余广播、改用异步I/O(AsyncSink)并配合丢弃型Sink彻底解决性能瓶颈。339 收藏 -
ThreadLocalRandom更适合多线程高并发场景,因线程局部seed避免竞争;Random适用于需可重现序列、正态分布等高级功能的单线程或测试场景。362 收藏 -
合并字符串需根据场景选择方法:少量拼接可用+或concat;循环中推荐StringBuilder提升性能;带分隔符的集合合并首选String.join()。220 收藏 -
逻辑运算符用于布尔类型条件判断,具有短路特性,如&&、||常用于流程控制;位运算符对整数二进制位操作,无短路,如&、|、^用于标志位处理或性能优化。450 收藏 -
接口多态通过抽象行为提升代码扩展性,1.定义清晰契约如Payment接口;2.用多态替代条件判断;3.结合工厂模式解耦创建过程;4.优先使用接口类型引用,实现灵活替换与维护。305 收藏 -
Throwable是Java中错误和异常的父类,通过getMessage()方法可获取异常的详细描述信息,用于定位问题、记录日志或反馈错误原因。219 收藏 -
Condition是java.util.concurrent.locks中需配合ReentrantLock使用的多条件等待工具,区别于Object的wait/notify在于:一个锁可绑定多个Condition实现语义分离,而synchronized仅有一个隐式队列;await/signal必须在lock后unlock前调用,且需用while防虚假唤醒。152 收藏 -
必须下载JDK而非JRE,选择匹配系统的x64版本(推荐EclipseTemurin),安装时勾选“AddtoPATH”,配置JAVA_HOME指向JDK根目录,并在Path中添加%JAVA_HOME%\bin;验证java-version和javac-version一致,IDE、Maven等工具依赖JAVA_HOME正确设置。173 收藏 -
遍历Map时应优先使用entrySet()而非keySet(),避免在循环中重复调用get()造成冗余哈希查找,提升性能并符合SonarQube等静态分析工具的规范要求。432 收藏 -
初学者应避免将所有逻辑塞入main方法,而需分层:Account管余额与密码验证,ATM管交互流程,Main仅启动ATM;输入用nextLine()转数字并捕获异常;密码须用char[]、存文件、SHA-256哈希;所有异常必须捕获并给出用户友好提示。274 收藏 -
HashMap<String,Integer>最适合简易库存管理:键为商品ID,值为库存量;需校验ID合法性、拦截负库存、判空防NPE,并可用LinkedHashMap保持录入顺序。146 收藏