All Downloads are FREE. Search and download functionalities are using the official Maven repository.

javax.money.MonetaryOperator Maven / Gradle / Ivy

Go to download

JSR 354 provides an API for representing, transporting, and performing comprehensive calculations with Money and Currency.

There is a newer version: 1.1
Show newest version
/*
 * CREDIT SUISSE IS WILLING TO LICENSE THIS SPECIFICATION TO YOU ONLY UPON THE
 * CONDITION THAT YOU ACCEPT ALL OF THE TERMS CONTAINED IN THIS AGREEMENT.
 * PLEASE READ THE TERMS AND CONDITIONS OF THIS AGREEMENT CAREFULLY. BY
 * DOWNLOADING THIS SPECIFICATION, YOU ACCEPT THE TERMS AND CONDITIONS OF THE
 * AGREEMENT. IF YOU ARE NOT WILLING TO BE BOUND BY IT, SELECT THE "DECLINE"
 * BUTTON AT THE BOTTOM OF THIS PAGE.
 * 
 * Specification: JSR-354 Money and Currency API ("Specification")
 * 
 * Copyright (c) 2012-2013, Credit Suisse All rights reserved.
 */
package javax.money;

/**
 * Represents an operation on a single {@link MonetaryAmount} that produces a result of type
 * {@link MonetaryAmount}.
 * 

* Examples might be an operator that rounds the amount to the nearest 1000, or * one that performs currency conversion. *

* There are two equivalent ways of using a {@code MonetaryOperator}. The first * is to invoke the method on this interface. The second is to use * {@link MonetaryAmount#with(MonetaryOperator)}: * *

 * // these two lines are equivalent, but the second approach is recommended
 * monetary = thisOperator.apply(monetary);
 * monetary = monetary.with(thisOperator);
 * 
* * It is recommended to use the second approach, {@code with(MonetaryOperator)}, * as it is a lot clearer to read in code. * *

Implementation specification

* The implementation must take the input object and apply it. The * implementation defines the logic of the operator and is responsible for * documenting that logic. It may use any method on {@code MonetaryAmount} to * determine the result. *

* The input object must not be altered. Instead, an altered copy of the * original must be returned. This provides equivalent, safe behavior for * immutable and mutable monetary amounts. *

* This method may be called from multiple threads in parallel. It must be * thread-safe when invoked. * *

* This interface is considered to be adaptable/compatible with * {@code java.util.function.UnaryOperator} as introduced in Java 8. * * @author Werner Keil * @author Anatole Tresch * @author Stephen Colebourne * * @version 0.8.3 */ public interface MonetaryOperator { // extends // java.util.function.UnaryOperator // for Java 8/9 /** * Apply a function to the input argument T, returning the operated instance * of T. * * @param value * the input value * @return the result of the function */ public T apply(T value); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy