在 startend 修剪字元

此示例需要標題 <algorithm><locale><utility>

Version >= C++ 11

修剪序列或字串意味著以除去所有的前緣和後元素(或字元)匹配某謂詞。我們首先修剪尾隨元素,因為它不涉及移動任何元素,然後修剪前導元素。請注意,下面的概括適用於所有型別的 std::basic_string(例如 std::stringstd::wstring),偶然也適用於序列容器(例如 std::vectorstd::list)。

template <typename Sequence, // any basic_string, vector, list etc.
          typename Pred>     // a predicate on the element (character) type
Sequence& trim(Sequence& seq, Pred pred) {
    return trim_start(trim_end(seq, pred), pred);
}

修剪尾隨元素包括找到與謂詞不匹配的最後一個元素,並從那裡刪除:

template <typename Sequence, typename Pred>
Sequence& trim_end(Sequence& seq, Pred pred) {
    auto last = std::find_if_not(seq.rbegin(),
                                 seq.rend(),
                                 pred);
    seq.erase(last.base(), seq.end());
    return seq;
}

修剪前導元素包括找到與謂詞不匹配的第一個元素並刪除到那裡:

template <typename Sequence, typename Pred>
Sequence& trim_start(Sequence& seq, Pred pred) {
    auto first = std::find_if_not(seq.begin(),
                                  seq.end(),
                                  pred);
    seq.erase(seq.begin(), first);
    return seq;
}

為了專門修改以上內容來修改 tihuan 中的空白,我們可以使用 std::isspace() 函式作為謂詞:

std::string& trim(std::string& str, const std::locale& loc = std::locale()) {
    return trim(str, [&loc](const char c){ return std::isspace(c, loc); });
}

std::string& trim_start(std::string& str, const std::locale& loc = std::locale()) {
    return trim_start(str, [&loc](const char c){ return std::isspace(c, loc); });
}

std::string& trim_end(std::string& str, const std::locale& loc = std::locale()) {
    return trim_end(str, [&loc](const char c){ return std::isspace(c, loc); });
}

同樣,我們可以將 std::iswspace() 函式用於 std::wstring 等。

如果你希望建立一個修剪過的副本的序列,則可以使用單獨的函式:

template <typename Sequence, typename Pred>
Sequence trim_copy(Sequence seq, Pred pred) { // NOTE: passing seq by value
    trim(seq, pred);
    return seq;
}