我的 UI 的元素之一是显示项目列表的表格,按类别聚合,并带有一些公式(请参阅下面的目标输出)。
允许用户将单元格绑定到类似电子表格的公式的最佳方法是什么?
- 性能:实际数据变化频繁,表可能很大,公式很复杂,因此性能和 CPU 使用率是一个问题。
- 易于配置(假设配置由开发人员完成,因此可能涉及编程)
- 配置的可维护性
到目前为止我设想的方法:
- 使用 Java Scripting API,但我宁愿坚持使用基于 JVM 的方法以获得更好的性能
- 在运行时创建
interface Formula { double calculate(); }
并生成、编译和加载实现 - 允许 JIT 编译生成的方法 - 与 2 相同,但使用另一种基于 JVM 的语言,例如 clojure,它允许轻松的即时编译并具有非常适合的功能方法(例如,map/reduce 将有助于下面的平均值和总和计算) - 不确定关于性能影响。
哪种方法更有意义?我应该考虑其他任何解决方案或库吗?
例子
为了使目标更清晰,这里是一个人为的例子——让我们假设表中的项目是:
public class Item() {
public String category;
public String name;
public int quantity;
public double price;
}
目标输出
Category Name Quantity Price (avg) Value (sum)
All 82 1,090
Bikes 45 650
Bike 1 10 40 400
Bike 2 5 50 250
Cars 120 440
Car 1 3 100 300
Car 2 1 140 140
列配置
列可以这样定义:
Column # Formula
1 item.name;
2 item.quantity;
3 item.price;
4 Math.abs(column_2 * column_3); //calls a JDK method
聚合配置
聚合类别和汇总公式可以这样定义:
AGGREGATION #1: Category cat = item.category();
Column # Formula
1 cat;
2 "";
3 thisColumn.filter(cat).items().average(); //utility method
//this one is more complex
4 { double sum = 0;
for (double value : thisColumn.filter(cat).items())
sum += value;
return sum;
}