最終更新日時:
が更新

履歴 編集

posix_time::time_duration

Time Duration Documentation

Introduction

boost::posix_time::time_duration クラスは時間の長さを確実に表現できる基底型である。 時間長(duration)は正あるいは負の値を取り得る。

以下に示すように、異なった分解能を調整するために基底の time_duration から継承するいくつかの小さなヘルパークラスがある。 これらのクラスによって、コードを短く、意図をより明確にすることができる。

例:

using namespace boost::gregorian;
using namespace boost::posix_time;

time_duration td = hours(1) + seconds(10); //01:00:01
td = hours(1) + nanosec(5); //01:00:00.000000005

注意:高分解能(たとえばnanosec)が存在するかどうかは、依存するインストールライブラリによって異なる。詳細は、Build-Compiler Informationを参照。

Header

#include "boost/date_time/posix_time/posix_time.hpp" //全ての型とI/Oを含む

もしくは

#include "boost/date_time/posix_time/posix_time_types.hpp" //型のみでI/Oは含まない

Construction

Syntax Description Example
time_duration(hours,minutes,seconds,fractional_seconds) 数値から時間長(duration)を生成する time_duration td(1,2,3,9); //1 hr 2 min 3 sec 9 nanoseconds

Construction By Count

Syntax Description Example
hours(long) 時間単位で生成 time_duration td = hours(3);
minutes(long) 分単位で生成 time_duration td = minutes(3);
seconds(long) 秒単位で生成 time_duration td = seconds(3);
milliseconds(long) ミリ秒単位で生成 time_duration td = milliseconds(3);
microseconds(long) マイクロ秒単位で生成 time_duration td = microseconds(3);
nanoseconds(long) ナノ秒単位で生成 time_duration td = nanoseconds(3);

Construction From String

Syntax Description Example
time_duration duration_from_string(const std::string&) 区切られた文字列から生成 std::string ts("23:59:59.000");
time_duraton td(duration_from_string(ts));

Accessors

Syntax Description Example
long hours() const 時間の部分を取得 time_duration td(1,2,3); td.hours() --> 1
long minutes() const 正規化された分の部分を取得 time_duration td(1,2,3); td.minutes() --> 2
long seconds() const 秒の部分を取得 time_duration td(1,2,3); td.hours() --> 3
long fractional_seconds() const 秒の小数部を取得 time_duration td(1,2,3, 1000); td.fractional_seconds() --> 1000
bool is_negative() const 時間長(duration)が負の時 true time_duration td(-1,0,0); td.is_negative() --> true
time_duration invert_sign() const 符号を反転させた時間長(duration)を新たに生成 time_duration td(-1,0,0); td.invert_sign() --> 01:00:00
static gdtl::time_resolutions resolution() time_duration クラスが表現可能な分解能 time_duration::resolution() --> nano
boost::int64_t ticks() 時間長(duration)型の生の数を返す time_duration td(0,0,0, 1000); td.ticks() --> 1000
static time_duration unit() 時間長(duration)型の扱える最小単位を返す(1ナノ秒) time_duration::unit() --> time_duration(0,0,0,1)

Conversion To String

Syntax Description Example
std::string to_simple_string(time_duration) HH:MM:SS.fffffffff 形式に変換する(fff...部は、秒の小数部が0でないときのみ含まれる) 10:00:01.123456789
std::string to_iso_string(time_duration) HHMMSS,fffffffff 形式に変換する 100001,123456789

Operators

Syntax Description Example
operator==, operator!=,
operator>, operator<
operator>=, operator<=
サポートする比較演算子 dd1 == dd2, etc
time_duration operator+(time_duration) const 時間長(durations)を加算する time_duration td1(hours(1)+minutes(2));
time_duration td2(seconds(10)); time_duration td3 = td1 + td2;
time_duration operator-(time_duration) const 時間長(durations)を減算する time_duration td1(hours(1)+nanosec(2));
time_duration td2 = td1 - minutes(1);

Last modified: Wed Aug 28 17:52:03 MST 2002 by Jeff Garland © 2000-2002

Japanese Translation Copyright (C) 2003 Shoji Shinohara.