Function functional interface in Java 8

Posted by André D on Fri, 24 Dec 2021 09:49:10 +0100

If is often used in the development process else... Judge, throw exceptions, branch handling, etc. These if else... Flooding in the code seriously affects the beauty of the code. At this time, we can use the Function interface of Java 8 to eliminate if else....

if (...){
    throw new RuntimeException("Something's wrong");
} 

if (...){
    doSomething();
} else {
    doOther();
}

Function al interface

The interface identified with the annotation @ functional interface and containing only one abstract method is a functional interface. Functional interfaces are mainly divided into Supplier supply functions, Consumer consumption functions, Runnable parameterless and returnless functions and Function parameterless and returnable functions.

Function can be regarded as a conversion function

Supplier supply function

The Supplier is expressed as not accepting parameters and only returning data

Consumer consumer function

The consumer function is the opposite of the Supplier function. Consumer receives a parameter with no return value

Runnable parameterless and returnless function

The expression of Runnable is that there are no parameters and no return value

The Function function takes a parameter and returns a value. Supplier, Consumer and Runnable can be regarded as a special form of Function

Use tips

Handle if that throws an exception

  1. Define function

Define a functional interface in the form of throwing exceptions. This interface has only parameters and no return value. It is a consumer interface

/**
 * Throw exception interface
 **/
@FunctionalInterface
public interface ThrowExceptionFunction {

    /**
     * Throw exception information
     *
     * @param message Abnormal information
     * @return void
     **/
    void throwMessage(String message);
}

  1. Write judgment method

Create the tool class VUtils and create an isTure method. The return value of the method is the functional interface ThrowExceptionFunction just defined. The interface implementation logic of ThrowExceptionFunction is to throw an exception when parameter b is true

/**
 *  If the parameter is true, an exception is thrown
 * 
 * @param b 
 * @return com.example.demo.func.ThrowExceptionFunction
 **/
public static ThrowExceptionFunction isTure(boolean b){

    return (errorMessage) -> {
        if (b){
            throw new RuntimeException(errorMessage);
        }
    };
}

  1. Mode of use

After calling the parameter parameters of the tool class, the throwMessage method of the functional interface is called to import the exception information. It is executed normally when the input and output parameters are false

An exception is thrown when the incoming and outgoing parameters are true

Handle if branch operations

  1. Define functional interfaces

Create a functional interface named BranchHandle, and the parameters of the interface are two Runnable interfaces. These two Runnable interfaces respectively represent the operations to be performed when it is true or false

/**
 * Branch processing interface
 **/
@FunctionalInterface
public interface BranchHandle {

    /**
     * Branch operation
     *
     * @param trueHandle Action to be taken when is true
     * @param falseHandle What to do when it is false
     * @return void
     **/
    void trueOrFalseHandle(Runnable trueHandle, Runnable falseHandle);

}

  1. Write judgment method

Create a method named isTureOrFalse, and the return value of the method is the functional interface BranchHandle just defined.

/**
 * When the parameter is true or false, different operations are performed respectively 
 * 
 * @param b 
 * @return com.example.demo.func.BranchHandle     
 **/
public static BranchHandle isTureOrFalse(boolean b){
    
    return (trueHandle, falseHandle) -> {
        if (b){
            trueHandle.run();
        } else {
            falseHandle.run();
        }
    };
}

  1. Mode of use

When the parameter is true, execute trueHandle

When the parameter is false, execute false handle

If a value exists, perform the consumption operation; otherwise, perform the null based operation

  1. Define function

Create a functional interface named presentorsehandler, and the parameter of the interface is the Consumer interface. One is Runnable, which respectively represents the consumption operation when the value is not empty and other operations when the value is empty

/**
 * Null and non null branch processing
 */
public interface PresentOrElseHandler<T extends Object> {

    /**
     * The consumption operation is executed when the value is not empty
     * Perform other operations when the value is empty
     * 
     * @param action When the value is not empty, the consumption operation to be performed
     * @param emptyAction Action to be performed when the value is null
     * @return void    
     **/
   void presentOrElseHandle(Consumer<? super T> action, Runnable emptyAction);
   
}

  1. Write judgment method

Create a method named isBlankOrNoBlank, and the return value of the method is the functional interface just defined - presentorsehandler.

/**
 * When the parameter is true or false, different operations are performed respectively
 *
 * @param b
 * @return com.example.demo.func.BranchHandle
 **/
public static PresentOrElseHandler<?> isBlankOrNoBlank(String str){

    return (consumer, runnable) -> {
        if (str == null || str.length() == 0){
            runnable.run();
        } else {
            consumer.accept(str);
        }
    };
}

  1. Mode of use

After calling the parameter parameters of the tool class, the presentOrElseHandle method calling the functional interface brings in a Consumer and Runnable.

When the parameter is not empty, print the parameter

When the parameter is not empty

ending

Function function interface is a very important feature of java 8. Making good use of function function can greatly simplify the code.

Topics: Java Back-end