当我按原样运行程序时,它工作正常。但是,当我在 while 循环之后移动该部分直到 cout<<"pp1>"时,我收到两个错误。从“char”到“const char*”的无效转换以及“char* strncpy(char*, const char*, size_t)”的参数 2 的初始化。关于我需要更改什么的任何想法,以便我可以将该代码移动到一个函数中。我无法在网上或我的 C++ 书籍中找到很好的解释来解释解决此问题的方法。我知道错误是说它需要一个文字而不是一个指针,但无法找出解决方法(有吗?)。
这是我的主要内容。
int main(){
char cmd_str[500];
int length=0;
bool cont=true;
while(cont){
// strncpy(cmd_str, infile(), 500 - 1); this line causes the two errors
// cmd_str[500 - 1] = '\0';
mode_t perms=S_IRUSR;
int i=0;
int fd = open("text.txt",O_RDONLY , perms);
char *returnArray;
cout<<fd<<endl;
if(fd<0){
perror( strerror(errno));
} else{
ifstream readFile;
readFile.open("text.txt");
readFile.seekg (0, ios::end);
int length = readFile.tellg();
readFile.seekg (0, ios::beg);
returnArray=new char[i];//memory leak need to solve later
readFile.getline(returnArray,length);
cout<<returnArray<<endl;
strncpy(cmd_str, returnArray, length - 1);
cmd_str[length - 1] = '\0';
}
cout<<"pp1>";
cout<< "test1"<<endl;
// cin.getline(cmd_str,500);
cout<<cmd_str<<endl;
cout<<"test2"<<endl;
length=0;
length= shell(returnArray);
cout<<length<<endl;
if(length>=1)
{
cout<<"2"<<endl;
}
else{
cont=false;
}
}
这是我试过的功能
char infile()
{
mode_t perms=S_IRUSR;
int i=0;
int fd = open("text.txt",O_RDONLY , perms);
char *returnArray;
cout<<fd<<endl;
if(fd<0){
perror( strerror(errno));
}else{
ifstream readFile;
readFile.open("text.txt");
//int length = readFile.tellg();
readFile.seekg (0, ios::end);
int length = readFile.tellg();
readFile.seekg (0, ios::beg);
returnArray=new char[i];//memory leak need to solve later
readFile.read(returnArray,length);
readFile.getline(returnArray,length);
}
return *returnArray;
}
最佳答案
取消引用 returnArray
并尝试返回一个 char
是行不通的,因为:
- 您将只返回字符串的第一个字符。
strncpy
函数不会接受它(这就是您收到这些错误的原因)。- 您需要一种方法来释放
char*
占用的堆分配内存。
将您的函数定义从 char infile()
更改为 const char* infile()
并仅返回指针。理想情况下,这会将填充的数组作为 const char*
(C 风格字符串)返回,您可以成功将其传递给 strncpy
。此外,当您完成它时,您需要对其调用 delete []
(以防止内存泄漏)。
关于c++ - 我很难将我的一些代码从 main 移动到函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10159068/