Class AbstractDuration
- java.lang.Object
-
- org.joda.time.base.AbstractDuration
-
- All Implemented Interfaces:
java.lang.Comparable<ReadableDuration>,ReadableDuration
- Direct Known Subclasses:
BaseDuration
public abstract class AbstractDuration extends java.lang.Object implements ReadableDuration
AbstractDuration provides the common behaviour for duration classes.This class should generally not be used directly by API users. The
ReadableDurationinterface should be used when different kinds of durations are to be referenced.AbstractDuration subclasses may be mutable and not thread-safe.
- Since:
- 1.0
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intcompareTo(ReadableDuration other)Compares this duration with the specified duration based on length.booleanequals(java.lang.Object duration)Compares this object with the specified object for equality based on the millisecond length.inthashCode()Gets a hash code for the duration that is compatible with the equals method.booleanisEqual(ReadableDuration duration)Is the length of this duration equal to the duration passed in.booleanisLongerThan(ReadableDuration duration)Is the length of this duration longer than the duration passed in.booleanisShorterThan(ReadableDuration duration)Is the length of this duration shorter than the duration passed in.DurationtoDuration()Get this duration as an immutableDurationobject.PeriodtoPeriod()Converts this duration to a Period instance using the standard period type and the ISO chronology.java.lang.StringtoString()Gets the value as a String in the ISO8601 duration format including only seconds and milliseconds.-
Methods inherited from interface org.joda.time.ReadableDuration
getMillis
-
-
-
-
Method Detail
-
toDuration
public Duration toDuration()
Get this duration as an immutableDurationobject.- Specified by:
toDurationin interfaceReadableDuration- Returns:
- a Duration created using the millisecond duration from this instance
-
toPeriod
public Period toPeriod()
Converts this duration to a Period instance using the standard period type and the ISO chronology.Only precise fields in the period type will be used. Thus, only the hour, minute, second and millisecond fields on the period will be used. The year, month, week and day fields will not be populated.
If the duration is small, less than one day, then this method will perform as you might expect and split the fields evenly. If the duration is larger than one day then all the remaining duration will be stored in the largest available field, hours in this case.
For example, a duration effectively equal to (365 + 60 + 5) days will be converted to ((365 + 60 + 5) * 24) hours by this constructor.
For more control over the conversion process, you must pair the duration with an instant, see
Period(ReadableInstant,ReadableDuration).- Specified by:
toPeriodin interfaceReadableDuration- Returns:
- a Period created using the millisecond duration from this instance
-
compareTo
public int compareTo(ReadableDuration other)
Compares this duration with the specified duration based on length.- Specified by:
compareToin interfacejava.lang.Comparable<ReadableDuration>- Parameters:
other- a duration to check against- Returns:
- negative value if this is less, 0 if equal, or positive value if greater
- Throws:
java.lang.NullPointerException- if the object is nulljava.lang.ClassCastException- if the given object is not supported
-
isEqual
public boolean isEqual(ReadableDuration duration)
Is the length of this duration equal to the duration passed in.- Specified by:
isEqualin interfaceReadableDuration- Parameters:
duration- another duration to compare to, null means zero milliseconds- Returns:
- true if this duration is equal to than the duration passed in
-
isLongerThan
public boolean isLongerThan(ReadableDuration duration)
Is the length of this duration longer than the duration passed in.- Specified by:
isLongerThanin interfaceReadableDuration- Parameters:
duration- another duration to compare to, null means zero milliseconds- Returns:
- true if this duration is longer than the duration passed in
-
isShorterThan
public boolean isShorterThan(ReadableDuration duration)
Is the length of this duration shorter than the duration passed in.- Specified by:
isShorterThanin interfaceReadableDuration- Parameters:
duration- another duration to compare to, null means zero milliseconds- Returns:
- true if this duration is shorter than the duration passed in
-
equals
public boolean equals(java.lang.Object duration)
Compares this object with the specified object for equality based on the millisecond length. All ReadableDuration instances are accepted.- Specified by:
equalsin interfaceReadableDuration- Overrides:
equalsin classjava.lang.Object- Parameters:
duration- a readable duration to check against- Returns:
- true if the length of the duration is equal
-
hashCode
public int hashCode()
Gets a hash code for the duration that is compatible with the equals method.- Specified by:
hashCodein interfaceReadableDuration- Overrides:
hashCodein classjava.lang.Object- Returns:
- a hash code
-
toString
public java.lang.String toString()
Gets the value as a String in the ISO8601 duration format including only seconds and milliseconds.For example, "PT72.345S" represents 1 minute, 12 seconds and 345 milliseconds.
For more control over the output, see
PeriodFormatterBuilder.- Specified by:
toStringin interfaceReadableDuration- Overrides:
toStringin classjava.lang.Object- Returns:
- the value as an ISO8601 string
-
-