C++11 では、このための独自の検索関数を簡単に作成できます。
template<class iter1, class iter2>
iter1 search(iter1 stackbegin, iter1 stackend, iter2 needlebegin, iter2 needleend)
{return std::search(stackbegin, stackend, needlebegin, needleend);}
template<class iter1, class needlecontainer>
iter1 search(iter1 stackbegin, iter1 stackend, const needlecontainer& needle)
{return std::search(stackbegin, stackend, std::begin(needle), std::end(needle));}
template<class stackcontainer, class needlecontainer>
decltype(std::begin(std::declval<stackcontainer>()))
search(const stackcontainer& stack, const needlecontainer& needle)
{return std::search(std::begin(stack), std::end(stack), std::begin(needle), std::end(needle));}
template<class stackcontainer, class needlecontainer>
decltype(std::begin(std::declval<stackcontainer>()))
search(stackcontainer& stack, const needlecontainer& needle)
{return std::search(std::begin(stack), std::end(stack), std::begin(needle), std::end(needle));}
そしてそれらを使用します:
int main() {
std::vector<char> str1;
auto it = search(str1, "Look for this");
}
コンパイルの証明: http://ideone.com/cO1rz (このバージョンの gcc にはなかったのでstd::begin
、std::end
自分で定義する必要がありました) および C++03 バージョン: http://ideone.com/gt1Do
本当に本当に短いマクロが必要で、リテラルが同じスペースを共有することを保証できる場合:
template<int N>
const char* end(const char(&s)[N]) {return s+N;}
#define STR_ITERATORS(X) X, end(X) //BE WARNED, HIGHLY UNSAFE, NOT PORTABLE