J'ai écrit un peu Linq comme le DSL sur le dessus de Google CollectionsSerait-ce causer des problèmes Garbage Collection
public class IterableQuery {
public static <T> Where<T> from(Iterable<T> originalCollection) {
return new Where<T>(Iterables.transform(originalCollection, IterableQuery.<T>SAME()));
}
private static <T> Function<T, T> SAME() {
return new Function<T, T>(){
public T apply(T arg0) {
return arg0;
}
};
}
public static class SelectOrderBy<T>{
private final Iterable<T> iterable;
public SelectOrderBy(Iterable<T> iteable) {
this.iterable = iteable;
}
public SelectOrderBy<T> orderyBy(Comparator<T> sort){
Ordering.forComparator(sort).sort((List< ? extends T>) iterable);
return new SelectOrderBy<T>(iterable);
}
public <F> Iterable<F> select( Function<? super T,? extends F> function){
return Iterables.transform(iterable, function);
}
public Iterable<T> selectEveryThing(){
return iterable;
}
}
public static class Where<T>{
private final Iterable<T> iterable;
public Where(Iterable<T> iterable) {
this.iterable = iterable;
}
public SelectOrderBy<T> where(Predicate<T> predicate) {
return new SelectOrderBy<T>(Iterables.filter(iterable, predicate));
}
}
}
pour que je puisse faire des collections de la requête d'une manière lisible plus concise
Iterable<? extends NewOrder > currentlyAssigned =
IterableQuery.
from(orders).
where(placedInLast10Days).
orderBy(lastName).
select(orderToNewOrder);
Je suis préoccupé si cette approche provoquera une explosion de mini-objets et causera des problèmes de Garbage Collection (ou d'autres problèmes)?
Problèmes de récupération de place? Je programme dans un langage géré pour ne pas m'inquiéter à ce sujet :) –