class Transaction
{
int transactionId,transactionType,transactionStatus;
double transactionAmount;
Date transactionDate;
}
我想使用RxJava基于交易属性组合过滤交易列表。组合会更改运行时,因此有人可以帮助我如何对相同的对象使用filter()运算符
前一段时间,我不得不做你想做的同样的事情。我创建了一个简单的解决方案来处理多重过滤,如下所示:
public class ExampleUnitTest {
@Test
public void testSample() throws Exception {
TransactionDatabase transactionDatabase = new TransactionDatabase();
transactionDatabase.insert(new Transaction(1, 50.00, new Date()));
transactionDatabase.insert(new Transaction(2, 20.00, new Date()));
transactionDatabase.insert(new Transaction(3, 110.00, new Date()));
transactionDatabase.insert(new Transaction(4, 250.00, new Date()));
transactionDatabase.insert(new Transaction(5, 5.00, new Date()));
transactionDatabase.insert(new Transaction(5, 73.00, new Date()));
List<Func1<Transaction, Boolean>> filters = new ArrayList<>();
filters.add(transaction -> transaction.transactionAmount > 20);
filters.add(transaction -> transaction.transactionAmount < 100);
transactionDatabase.getTransactions(filters)
.subscribe(System.out::println);
}
private class Transaction {
int transactionId;
double transactionAmount;
Date transactionDate;
public Transaction(int transactionId, double transactionAmount, Date transactionDate) {
this.transactionId = transactionId;
this.transactionAmount = transactionAmount;
this.transactionDate = transactionDate;
}
@Override
public String toString() {
return "Transaction{" +
"transactionId=" + transactionId +
", transactionAmount=" + transactionAmount +
", transactionDate=" + transactionDate +
'}';
}
}
class TransactionDatabase {
List<Transaction> transactions = new ArrayList<>();
public void insert(Transaction transaction) {
transactions.add(transaction);
}
public Observable<Transaction> getTransactions(List<Func1<Transaction, Boolean>> filters) {
Observable<Transaction> observable = Observable.from(transactions);
for (Func1<Transaction, Boolean> filter : filters) {
observable = observable.filter(filter);
}
return observable;
}
}
}
它将打印以下内容:
Transaction{transactionId=1, transactionAmount=50.0, transactionDate=Tue Jun 14 16:21:24 BRT 2016}
Transaction{transactionId=5, transactionAmount=73.0, transactionDate=Tue Jun 14 16:21:24 BRT 2016}
我认为这是解决您问题的好方法。
希望对您有所帮助。
此致。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句