我不明白为什么以下不起作用。我从几个来源读到,这是将参数传递给函数的正确方法,并且我已经成功打印了argv
的内容。
这个想法是从命令行调用程序,它将使用上面传递的所有参数5(因此应该忽略应用程序名称+5其他参数)。还有什么问题?
#include <iostream>
#include <vector>
#include <regex>
#include <sstream>
using namespace std;
std::vector<int> createEndBlock(int argc, const char *argv[])
{
std::vector<int> blocks;
for (int i = 6; i < (argc - 6); i++)
{
string str = argv[i];
for (int j = 0; j < str.size(); j++)
{
if (str[j] == '-') {
blocks.push_back(atoi(str.substr(j+1).c_str()));
cout<<blocks[i]<<endl;
}
}
}
return blocks;
}
int main(int argc, char* argv[]) {
std::vector<int> blocks;
blocks = createEndBlock(argc, argv);
for (int i = 6; i < 7; i++)
{
cout<<blocks[i]<<endl;
}
return 0;
}
我收到以下错误:
test.cpp: In function ‘int main(int, char**)’:
test.cpp:38:37: error: invalid conversion from ‘char**’ to ‘const char**’
[-fpermissive]
test.cpp:19:18: error: initializing argument 2 of ‘std::vector<int>
createEndBlock(int, const char**)’ [-fpermissive]
编译: g ++ test.cpp -o test -std = c ++ 11
命令行示例:
./test not not not not not 1-2 4-5 7-10
应该导致:
2 5 10
答案 0 :(得分:2)
您的指数不正确:
for (int i = 6; i < (argc - 6); i++)
读起来是“从最后的6到6开始。将(argc - 6)改为argc。
在main中,你想要读取0到blocks.size() - 1的块。
答案 1 :(得分:0)
问题是你有main char * []
,并将其传递给期望const char * []
的函数。他们不匹配。
您应该从const
createEndBlock
std::vector<int> createEndBlock(int argc, char *argv[])
答案 2 :(得分:0)
您有以下选择:
答案 3 :(得分:0)
您的blocks[i]
语句可能会传递无效索引。再看一下createEndBlock的内部循环。您检查特定条件,如果满足该条件,则仅添加新块。那么,当i = 0时测试失败然后当i = 1时,会发生什么?很简单,然后尝试访问块[ 1 ],但它只有一个元素,块[ 0 ]。结果? BOOM!