1

我想要这样的宏

STR_ITERATORS("My string")

产生

 pBegin, pEnd

例如,您可以使用它来搜索向量...

std::vector<char> str1;

std::search(str1.begin(), str1.end(), STR_ITERATORS("Look for this"));

请注意,搜索需要两对迭代器,宏提供第二对。

宏可以写两次——一次用于普通字符,一次用于宽字符。它不必一次性解决所有问题。

注意:我没有使用最新编译器的选项。(这让它有点无聊不是吗?:-)

4

3 回答 3

3

在 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::beginstd::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
于 2012-09-19T00:25:33.980 回答
2

boost range 提供了使用范围的算法重载,并将自动处理大多数类似 STL 的集合。具体来说,字符串也可以自动转换为范围。还有免费的函数开始和结束。

于 2012-09-19T01:04:00.443 回答
-1
template<int N>
int GetLengthOfLiteral(const wchar_t (&literal)[N]) { return N - 1; }

template<int N>
int GetLengthOfLiteral(const char (&literal)[N]) { return N - 1; }

#define LITERAL_ITERATORS(literal) (literal), ((literal) + GetLengthOfLiteral(literal)
于 2012-09-19T00:08:01.420 回答