SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

特集記事

Boost.Containerのフツーじゃないコンテナたち

  • このエントリーをはてなブックマークに追加

 標準C++ライブラリが提供するコンテナは可変長配列、双方向リスト、二進木、ハッシュ表など。これだけの品揃えならあらかたのシチュエーションでそれぞれに適したコンテナを選択できることでしょう。加えてそれだけでは満足できない御仁のための有用なコンポーネントの集合体:Boostには、標準ライブラリには含まれていない便利なコンテナが収められています。

  • このエントリーをはてなブックマークに追加

記事中のサンプルコードについて

 このアーティクル(とサンプルコード)は2014年11月時点での最新版:Boost 1.57.0を用いています。Boostサイトから入手したアーカイブを適当なディレクトリに展開し、そのパスを環境変数:BOOSTROOTに設定してください。そのディレクトリ<BOOSTROOT>上でコマンドラインから、

bootstrap
b2 -j8

でライブラリがビルドされ、<BOOSTROOT>/lib/stageに生成されます。b2 -j8 の'8'はビルド時に使用するスレッド数で、大きいほど短時間でビルドが完了します。論理コア数で頭打ちになりますけどね(b2だけだとシングルスレッドでビルドされます)。

boost::container::static_vector

 static_vectorはstd::arrayとstd::vectorのあいのこ。std::array<T,N>は固定長配列 T[N]を標準コンテナ化したもので、要素数:size()は常にNを返しますし、要素の挿入/削除ができません。対してstatic_vector<T,N>は要素数N個"以下"の可変長配列としてふるまいます。最大N個の要素を格納する領域は動的に取得/解放されることはなく、(std::array<T,N>と同様)インスタンス内部に"静的"に確保されます(static_vectorの名はそのことに由来します)。

 static_vector<T,N>にN個を超える要素を挿入しようとするとstd::bad_alloc例外がthrowされます。また、最大要素数の異なるstatic_vector<T,M>とstatic_vector<T,N>との間でのコピーもできますが、コピー先(左辺)のcapacity()がコピー元(右辺)のsize()より小さいと、同様にstd::bad_alloc例外です。オーバーフローを起こさない、より安全なバッファとして使えますね。

list01 static_vector.cpp
#include <iostream>
#include <boost/container/static_vector.hpp>

using namespace std;

int main() {

  const int N = 10;

  cout << "static_vector<short," << N   << ">\t: " << sizeof(boost::container::static_vector<short,N>) << endl;
  cout << "static_vector<int,"   << N   << ">\t: " << sizeof(boost::container::static_vector<int,N>)   << endl;
  cout << "static_vector<int,"   << N*2 << ">\t: " << sizeof(boost::container::static_vector<int,N*2>) << endl;
  cout << endl;

  boost::container::static_vector<int,N> sv { -3, -2, -1 }; 

  try {
    for ( int i = 0; i < N; ++i ) {
      sv.emplace_back(i);
    }
  } catch ( std::exception& ex) {
    cout << ex.what() << endl;
    cout << "CAN'T INSERT ITEMS ANY MORE!\n" << endl;
  }

  for ( int item : sv ) {
    cout << item << endl;
  }

}

会員登録無料すると、続きをお読みいただけます

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

次のページ
boost::container::stable_vector

この記事は参考になりましたか?

  • このエントリーをはてなブックマークに追加
特集記事連載記事一覧

もっと読む

この記事の著者

επιστημη(エピステーメー)

C++に首まで浸かったプログラマ。Microsoft MVP, Visual C++ (2004.01~2018.06) "だった"りわんくま同盟でたまにセッションスピーカやったり中国茶淹れてにわか茶...

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/8259 2014/12/05 14:00

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング