函数中的std :: end和std :: begin(C ++)

时间:2014-01-17 13:13:22

标签: c++ function parameters

我试图获取字符串数组的长度,我已经在main函数中完成了它并且它工作了。之后我需要在函数中执行此操作,但它不会识别出错误的函数:

  

IntelliSense:没有重载函数“begin”的实例与参数列表匹配

代码:

void fun(string arr[])
{
    cout << end(arr) - begin(arr);
}

void main()
{
    string arr[] = {"This is a single string"};
    fun(arr);
}

也是为了结束。

所以我添加了指针符号'*'并且错误消失了,但它返回了数组中第一项的长度。

为什么会出现此错误?如何解决?

2 个答案:

答案 0 :(得分:5)

您可以通过

执行此操作
#include <iostream>
#include <string>

template<size_t N>
void fun(std::string (&arr)[N])
{
    std::cout << std::end(arr) - std::begin(arr);
}

int main (void)
{
    std::string arr[] = {"This is a single string"};
    fun(arr);
}

但在您的示例中,数组会衰减为指针,因此您无法调用sizeofbeginend

答案 1 :(得分:2)

问题是你并没有真正处理一个字符串数组......你正在std::string上使用指针,因为std::string arr[]衰减到std::string*

这意味着只有std::end()std::begin()不适用于指针。

我更喜欢的解决方法是使用std::array<>std::vector<>或在调用函数之前检索begin end:

template <typename iterator>
void fun(iterator begin, iterator end)
{
    std::cout << end - begin; 
}

int main()
{
    std::string arr[] = {"This is a single string"};
    fun(std::begin(arr), std::end(arr));
    return 0;
}

我不喜欢在另一个答案中建议的参数中使用硬编码大小,但这是个人品味的问题。