当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Elixir Time.new用法及代码示例


Elixir语言中 Time.new 相关用法介绍如下。

用法:

new(hour, minute, second, microsecond \\ {0, 0}, calendar \\ Calendar.ISO)
@spec new(
  Calendar.hour(),
  Calendar.minute(),
  Calendar.second(),
  Calendar.microsecond() | non_neg_integer(),
  Calendar.calendar()
) :: {:ok, t()} | {:error, atom()}

开创一个新时代。

期望所有值都是整数。如果每个条目都符合其适当的范围,则返回{:ok, time},否则返回{:error, reason}

微秒也可以指定精度,它必须是 0 到 6 之间的整数。

内置日历不支持闰秒。

例子

iex> Time.new(0, 0, 0, 0)
{:ok, ~T[00:00:00.000000]}
iex> Time.new(23, 59, 59, 999_999)
{:ok, ~T[23:59:59.999999]}

iex> Time.new(24, 59, 59, 999_999)
{:error, :invalid_time}
iex> Time.new(23, 60, 59, 999_999)
{:error, :invalid_time}
iex> Time.new(23, 59, 60, 999_999)
{:error, :invalid_time}
iex> Time.new(23, 59, 59, 1_000_000)
{:error, :invalid_time}

# Invalid precision
Time.new(23, 59, 59, {999_999, 10})
{:error, :invalid_time}

相关用法


注:本文由纯净天空筛选整理自elixir-lang.org大神的英文原创作品 Time.new(hour, minute, second, microsecond \\ {0, 0}, calendar \\ Calendar.ISO)。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。