サンプルコード
#include <iostream>
#include <string>
#include <cstring> // strcmp を使用するため
using namespace std;
void Show(const char* str) {
    cout << str << endl;
}
int main() {
    // 初期化
    string str = "my string";
    string str2("my string"); // としても同じです
    // 拡張
    str += ", extended";
    // 長さ
    str.size();
    str.length(); // としても同じです
    // 要素取得
    str[0];
    str.at(0); // としても同じです
    // ヌルターミネータを末尾に付与して
    // const char* を返す
    // (str の非constメンバ関数によって
    //  const char* が指すアドレスが解放されたり
    //  書き換えられたりする可能性があることに注意
    // )
    Show(str.c_str()); //=> my string, extended
    // ヌルターミネータ '\0' を string 自体は必要と
    // しないため、要素の途中に '\0' を含められます
    str[1] = '\0';
    Show(str.c_str()); //=> m
    cout << str.size() << endl; //=> 19
    // ヌルターミネータを末尾に付与することを「保証
    // せず」に const char* を返す (ヌルターミネータを
    // 必要としないことを明記できるため c_str() と使い分けると
    // ソースコードが読み易くなります)
    str.data();
    // 標準入力から取得した値を代入
    cout << "INPUT: " << flush; // 改行しないで書き出す (復習)
    getline(cin, str);
    cout << "YOUR INPUT: " << str << endl; // 改行する。そして書き出す (復習)
    // const char* で同じことをやる場合 (復習)
    char cstr[128];
    cout << "INPUT: " << flush;
    cin.getline(cstr, 128);
    cout << "YOUR INPUT: " << cstr << endl;
    // 文字列の比較
    if (str == "string");
    // const char* で同じことをやる場合 (復習)
    // - #include <cstring> が必要
    // - 等しい場合は 0 を返す
    // - 辞書順で cstr < string ならば -1 を返す
    // - 辞書順で cstr > string ならば +1 を返す
    if (strcmp(cstr, "string") == 0);
    // 右から検索、左から検索
    str = "s*ri*g";
    string::size_type rpos = str.rfind("*");
    string::size_type lpos = str.find("*");
    cout << rpos << endl;       //=> 4
    cout << lpos << endl;       //=> 1
    // 二文字以上での検索
    string::size_type pos = str.rfind("ri");
    cout << pos << endl; //=> 2
    // 検索結果がないかどうかの判定
    if( string::npos == str.find("+") ); //=> true
    // 挿入 (↓検索結果の直前に挿入されます)
    str.insert(pos, "_INSERT_");
    cout << str << endl; //=> s*_INSERT_ri*g
    // 文字列の長さを変更
    str.resize(8);
    cout << str.size() << endl; //=> 8
    cout << str.capacity() << endl; //=> 19
    // メモリ領域を予め「最低でも」 32 要素分確保して
    // resize時などに new やコピーの頻度軽減を狙う
    str.reserve(32);
    cout << str.size() << endl; //=> 8
    cout << str.capacity() << endl; //=> 38
    // 空にする
    str.clear();
    cout << str.size() << endl; //=> 0
    cout << str.capacity() << endl; //=> 38
    // 長さが 0 であれば true
    str.empty();
    // 削除して詰める (i 番目から n 文字)
    str = "string";
    str.erase(1, 3);
    cout << str << endl; //=> sng
    str = "string";
    str.erase(1, string::npos); // 最後まで削除
    cout << str << endl; //=> s
    // 置換 (i 番目から n 文字を s で置換)
    str = "string";
    str.replace(1, 3, "TRI");
    cout << str << endl; //=> sTRIng
    // 部分文字列
    str = "string";
    cout << str.substr(1, 3) << endl;            //=> tri
    cout << str.substr(1, string::npos) << endl; //=> tring
    // 日本語の検索
    // - Unicodeを使用するとバイト数は大きくなるが
    //   検索時の問題は避けられる (推奨)
    // - Shift_JISなど日本語用の文字セットを使用すると
    //   バイト数は小さくなるが、検索時に問題が発生 (非推奨)
    str = "予定表.txt";
    string::size_type mbpos = str.find("表");
    cout << mbpos << endl; //=> 3 (UTF-8で符号化されている場合。Shift_JISではエラー)
    str.insert(mbpos, "_挿入_");
    cout << str << endl; //=> 予定_挿入_表.txt
    return 0;
}
文字列を生成 (stringstream)
#include <iostream>
#include <sstream>
using namespace std;
int main() {
    stringstream ss;
    ss.str("");  // 初期化
    ss << "10 9" << flush; // 改行なしで書き出す
    string str = ss.str();
    cout << str << endl; //=> 10 9
    int a, b;
    ss >> a >> b; // cin っぽく
    if(ss.fail()) {
        // 例えば ss に "10" しか入っていない場合 b には
        // 値が格納できず ss.fail() が true になります。
        cerr << "a or b is not initialized." << endl;
    }
    cout << a << endl; //=> 10
    cout << b << endl; //=> 9
    return 0;
}
0
記事の執筆者にステッカーを贈る
有益な情報に対するお礼として、またはコメント欄における質問への返答に対するお礼として、 記事の読者は、執筆者に有料のステッカーを贈ることができます。
さらに詳しく →Feedbacks
ログインするとコメントを投稿できます。
関連記事
- ダウンキャスト (C++をもう一度)実行時型情報 RTTI #include <iostream> #include <typeinfo> using namespace std; class MyClass { public: virtual ~MyClass() {} // typeid で正しい RTTI // (RunTime Type Information; 実行時型情報) ...
- 競技プログラミングの基本処理チートシート (C++)限られた時間の中で問題を解くために必要となる、競技プログラミングにおける基本的な処理のチートシートです。競プロにおけるメジャー言語 C++ を利用します。その際 C++11 の機能は利用せず C++03 の機能の範囲内で記述します。 頻度高く定期的に開催されるコンテスト AtCoder Codeforces main.cpp #include <iostream>
- 構造体と列挙体 (C++をもう一度)構造体 #include <iostream> using namespace std; struct MyStruct { char charval; int intval; }; void Show(MyStruct* obj) { cout << obj->intval << endl; } int main() { ...
- Valgrind による C/C++ メモリリーク検出JVM メモリリークでは JDK の jstat や jmap で原因を調査できます。C/C++ では valgrind の Memcheck ツールが利用できます。valgrind には複数のツールが含まれており既定のツールが Memcheck です。他のツールを利用する場合は --tool オプションで指定します。 [簡単な利用例](h
- クラスの基本/初期化 (C++をもう一度)構造体のように初期化する (非推奨) #include <iostream> using namespace std; const int MAX_STR = 16; class MyClass { public: int m_integer; char m_str[MAX_STR + 1]; void Show(); }; void MyClass::Show...






