java.lang.Object | |
↳ | org.joda.time.DurationField |
Known Direct Subclasses |
Known Indirect Subclasses |
Defines the calculation engine for duration fields. The interface defines a set of methods that manipulate a millisecond duration with regards to a single field, such as months or seconds.
This design is extensible so, if you wish, you can extract a different field from the millisecond duration. A number of standard implementations are provided to assist.
Public Constructors | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Adds a duration value (which may be negative) to the instant.
| |||||||||||
Adds a duration value (which may be negative) to the instant.
| |||||||||||
Compares this duration field with another duration field for ascending
unit millisecond order.
| |||||||||||
Computes the difference between two instants, as measured in the units
of this field.
| |||||||||||
Computes the difference between two instants, as measured in the units
of this field.
| |||||||||||
Get the millisecond duration of this field from its value relative to an
instant.
| |||||||||||
Get the millisecond duration of this field from its value, which is
approximate if this field is imprecise.
| |||||||||||
Get the millisecond duration of this field from its value relative to an
instant.
| |||||||||||
Get the millisecond duration of this field from its value, which is
approximate if this field is imprecise.
| |||||||||||
Get the name of the field.
| |||||||||||
Get the type of the field.
| |||||||||||
Returns the amount of milliseconds per unit value of this field.
| |||||||||||
Get the value of this field from the milliseconds, which is approximate
if this field is imprecise.
| |||||||||||
Get the value of this field from the milliseconds relative to an
instant.
| |||||||||||
Get the value of this field from the milliseconds, which is approximate
if this field is imprecise.
| |||||||||||
Get the value of this field from the milliseconds relative to an
instant.
| |||||||||||
Is this field precise.
| |||||||||||
Returns true if this field is supported.
| |||||||||||
Subtracts a duration value (which may be negative) from the instant.
| |||||||||||
Subtracts a duration value (which may be negative) from the instant.
| |||||||||||
Get a suitable debug string.
|
[Expand]
Inherited Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
From class
java.lang.Object
| |||||||||||
From interface
java.lang.Comparable
|
Adds a duration value (which may be negative) to the instant.
instant | the milliseconds from 1970-01-01T00:00:00Z to add to |
---|---|
value | the value to add, in the units of the field |
Adds a duration value (which may be negative) to the instant.
instant | the milliseconds from 1970-01-01T00:00:00Z to add to |
---|---|
value | the value to add, in the units of the field |
Compares this duration field with another duration field for ascending unit millisecond order. This ordering is inconsistent with equals, as it ignores name and precision.
durationField | a duration field to check against |
---|
NullPointerException | if the object is null |
---|---|
ClassCastException | if the object type is not supported |
Computes the difference between two instants, as measured in the units of this field. Any fractional units are dropped from the result. Calling getDifference reverses the effect of calling add. In the following code:
long instant = ... int v = ... int age = getDifference(add(instant, v), instant);The value 'age' is the same as the value 'v'.
minuendInstant | the milliseconds from 1970-01-01T00:00:00Z to subtract from |
---|---|
subtrahendInstant | the milliseconds from 1970-01-01T00:00:00Z to subtract off the minuend |
Computes the difference between two instants, as measured in the units of this field. Any fractional units are dropped from the result. Calling getDifference reverses the effect of calling add. In the following code:
long instant = ... long v = ... long age = getDifferenceAsLong(add(instant, v), instant);The value 'age' is the same as the value 'v'.
minuendInstant | the milliseconds from 1970-01-01T00:00:00Z to subtract from |
---|---|
subtrahendInstant | the milliseconds from 1970-01-01T00:00:00Z to subtract off the minuend |
Get the millisecond duration of this field from its value relative to an instant. For precise fields this method produces the same result as for the single argument getMillis method.
If the value is positive, then the instant is treated as a "start instant". If negative, the instant is treated as an "end instant".
value | the value of the field, which may be negative |
---|---|
instant | the instant to calculate relative to |
Get the millisecond duration of this field from its value, which is approximate if this field is imprecise.
value | the value of the field, which may be negative |
---|
Get the millisecond duration of this field from its value relative to an instant. For precise fields this method produces the same result as for the single argument getMillis method.
If the value is positive, then the instant is treated as a "start instant". If negative, the instant is treated as an "end instant".
value | the value of the field, which may be negative |
---|---|
instant | the instant to calculate relative to |
Get the millisecond duration of this field from its value, which is approximate if this field is imprecise.
value | the value of the field, which may be negative |
---|
Get the name of the field.
By convention, names are plural.
Returns the amount of milliseconds per unit value of this field. For example, if this field represents "seconds", then this returns the milliseconds in one second.
For imprecise fields, the unit size is variable, and so this method returns a suitable average value.
Get the value of this field from the milliseconds, which is approximate if this field is imprecise.
duration | the milliseconds to query, which may be negative |
---|
ArithmeticException | if the value is too large for an int |
---|
Get the value of this field from the milliseconds relative to an instant. For precise fields this method produces the same result as for the single argument get method.
If the millisecond duration is positive, then the instant is treated as a "start instant". If negative, the instant is treated as an "end instant".
duration | the milliseconds to query, which may be negative |
---|---|
instant | the start instant to calculate relative to |
ArithmeticException | if the value is too large for an int |
---|
Get the value of this field from the milliseconds, which is approximate if this field is imprecise.
duration | the milliseconds to query, which may be negative |
---|
Get the value of this field from the milliseconds relative to an instant. For precise fields this method produces the same result as for the single argument get method.
If the millisecond duration is positive, then the instant is treated as a "start instant". If negative, the instant is treated as an "end instant".
duration | the milliseconds to query, which may be negative |
---|---|
instant | the start instant to calculate relative to |
Is this field precise. A precise field can calculate its value from milliseconds without needing a reference date. Put another way, a precise field's unit size is not variable.
Returns true if this field is supported.
Subtracts a duration value (which may be negative) from the instant.
instant | the milliseconds from 1970-01-01T00:00:00Z to subtract from |
---|---|
value | the value to subtract, in the units of the field |
Subtracts a duration value (which may be negative) from the instant.
instant | the milliseconds from 1970-01-01T00:00:00Z to subtract from |
---|---|
value | the value to subtract, in the units of the field |