rovats / java-utils Goto Github PK
View Code? Open in Web Editor NEWA collection of useful Java utilities
License: Apache License 2.0
A collection of useful Java utilities
License: Apache License 2.0
What is the license on this?
Currently elements collected by each thread are passed to the batch processor without checking the batch size (to save merging the two lists), but if strict mode is enabled, the batch processor should only be called with elements exactly equal to the batch size.
When dealing with a stream of objects that don't override equals
, distinct()
and Collectors.toSet()
won't work.
But if they have a unique key, a distinctByKeyCollector
can be used.
If the stream size is a multiple of the batch size (e.g. stream size = 20, batch size = 10), the finishers calls the batchProcessor with empty list. I'm thinking this may not be necessary? (it's actually causing issue with my batchprocessor as it does not expect empty list)
Adding the empty check may help, but I'm not sure there are other implications of this.
public Function<List<T>, List<T>> finisher() {
return ts -> {
if (!ts.isEmpty()) {
batchProcessor.accept(ts);
recordsProcessed += ts.size();
}
return Collections.emptyList();
};
}
Thanks
Michal
Hi, your tests do not test what is most important - chunking. I your implementation would return the input list, tests would pass.
A declarative, efficient, and flexible JavaScript library for building user interfaces.
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. ๐๐๐
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google โค๏ธ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.