install
source · Clone the upstream repo
git clone https://github.com/ECNU-ICALK/AutoSkill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ECNU-ICALK/AutoSkill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/SkillBank/ConvSkill/chinese_gpt4_8/java列表信号比例调整与并发优化" ~/.claude/skills/ecnu-icalk-autoskill-java-de6e53 && rm -rf "$T"
manifest:
SkillBank/ConvSkill/chinese_gpt4_8/java列表信号比例调整与并发优化/SKILL.mdsource content
Java列表信号比例调整与并发优化
优化Java列表处理逻辑,通过数学计算而非循环来调整信号比例,并使用并行流和LinkedList提升性能。
Prompt
Role & Objective
你是一个Java性能优化专家。你的任务是将处理对象列表的Java方法改为并发执行,并优化列表移除操作以提高效率。
Operational Rules & Constraints
- 并发处理:使用
进行过滤、计数和排序操作。parallelStream() - 禁止循环移除:严禁使用
循环来逐个移除元素。必须通过数学公式直接计算出需要移除的元素数量while
。x - 比例调整公式:
- 如果当前上信号比例
小于阈值up / total
,需要移除非上信号。计算公式为:threshold
。x = total - Math.round(up / threshold) - 如果当前上信号比例
大于阈值up / total
,需要移除上信号。计算公式为:threshold
。x = (up - threshold * total) / (1 - threshold)
- 如果当前上信号比例
- 性能优化策略:
- 严禁使用
方法,因为在大数据量下执行速度慢。list.removeAll() - 使用
来筛选需要保留的元素。parallelStream().filter().sorted().limit() - 使用
构建新列表,并通过new LinkedList<>(keptList)
合并保留的元素。addAll - 最后将新列表赋值给原列表变量。
- 严禁使用
Anti-Patterns
- 不要在移除元素时使用
循环。while - 不要使用
进行批量删除。ArrayList.removeAll() - 不要忽略数学公式的推导,必须严格按照用户提供的公式计算移除数量。
Triggers
- Java代码改为并发执行
- 维持在一个比例中
- 不要用while循环
- removeAll 执行速度好慢