Interfaces are powerful tools to modulate your code. They allow for methods to become variables and be passed in to other methods as parameters. Using lambda expressions interfaces can be shortened to one liners making code clear and concise.
import java.util.Comparator;
import java.util.function.*;
import java.util.stream.Collectors;
public class Interfaces {
public static void main(String[] args) {
System.out.println(predicateLambda("super long string")); // true
primitivePredicate();
consumer();
function();
System.out.println(supplier()); // 10
bi();
System.out.println(methodParams(x -> x + 5, 5)); // 10
comparator();
}
//***//Predicate//***//
// a Predicate is a functional interface that can be used anywhere you need to evaluate a boolean condition
public static boolean predicate() {
Predicate<String> isALongWord = new Predicate<String>() {
@Override
public boolean test(String t) {
return t.length() > 10;
}
};
String s = "successfully";
boolean result = isALongWord.test(s);
return result;
}
// predicate
// List<String> filtered = l.stream().filter( s -> s.length() > 5 ).collect(Collectors.<String>toList());
public static boolean predicateLambda(String word) {
Predicate<String> isALongWord = t -> t.length() > 10;
//new ArrayList<String>().stream().filter(isALongWord).collect(Collectors.<String>toList());
return isALongWord.test(word);
}
public static void primitivePredicate() {
IntPredicate greater = i -> i > 10;
System.out.println(greater.test(12)); // true
}
//***//Consumer//***//
// represents an operation that accepts a single input argument and returns no result. The real outcome is the side-effects it produces
public static class Product {
private double price = 0.0;
public void setPrice(double price) {
this.price = price;
}
public void printPrice() {
System.out.println(price);
}
}
public static void consumer() {
//IntConsumer
Consumer<Product> updatePrice = p -> p.setPrice(5.9);
Product p = new Product();
updatePrice.accept(p); // performs this operation on the given argument
p.printPrice(); // 5.9
Consumer<Product> showPrice = s -> s.printPrice();
Consumer<Product> updateAndShow = updatePrice.andThen(showPrice); // performs passed in consumer after original consumer // 5.9
updateAndShow.accept(p);
}
//***//Function//***//
public static void function() {
//IntToDoubleFunction
Function<Integer, String> typeCast = val -> Integer.toString(val); // val -> val |TYPES| Integer -> String *NOTE does not automatically typecast
System.out.println(typeCast.apply(5).getClass()); // class java.lang.String
Function<Integer, Integer> square = val -> val * val;
System.out.println(square.apply(5)); // 25
// f.andThen(Function) runs f first then param function
// f.compose(Function) runs param function first then f
// F.identity() returns T in apply(T)
// When both generics of Function<> are the same type you can use UnaryOperator
//IntUnaryOperator
UnaryOperator<Double> increase = d -> d++;
System.out.println(increase.apply(5.2)); // 5.2
}
//***//Supplier//***//
// yep
public static int supplier() {
//IntSupplier
Supplier<Integer> add = () -> 10;
return add.get();
}
//***//Bi//***//
public static void bi() {
//ObjIntConsumer
BiConsumer<Integer, Double> sum = (i, d) -> System.out.println(i + d);
sum.accept(5, 2.3); // 7.3
//ToIntBiFunction
BiFunction<Integer, Integer, Double> divide = (x1, x2) -> (double)x1/x2;
System.out.println(divide.apply(5, 2)); // 2.5
//IntBinaryOperator
BinaryOperator<Integer> sub = (x1, x2) -> x1 - x2;
System.out.println(sub.apply(5, 2)); // returns Integer // 3
}
public static <T, R> R methodParams(Function<T, R> f, T num) {
return f.apply(num);
}
public static void collector() {
Collectors.toList(); // convert into List()
Collectors.toSet(); // convert into set()
Collectors.toCollection(null); // controls type of output
Collectors.toMap(null, null); // convert into Map()
Collectors.collectingAndThen(null, null); // performs operation on result after collecting into collection
Collectors.counting(); // counts the number of input elements and returns a collector // used with groupingBy()
Collectors.groupingBy(null); // groups duplicates into indexes // returns Map<String, List>
Collectors.joining(null); // concatenates the input elements into a string using delimiter // optional prefix and suffix
Collectors.mapping(null, null); // maps function to provided collection
Collectors.partitioningBy(null); // partitions the elements based on the predicate into list of true and false
Collectors.averagingDouble(null); // average of the input elements of type Double
Collectors.minBy(null); // gives minimal element
}
public static void comparator() {
Comparator<Integer> c = (a, b) -> a-b; // -1 less then, 0 equal, 1 greater then
System.out.println(c.compare(21, 32)); // -11
System.out.println(c.compare(13, 6)); // 7
System.out.println(c.compare(7, 7)); // 0
}
}