循环中的免费 strdup 输出
free strdup output in a loop
我有一个循环试图从 qml 列表对象中读取数据,这是我的循环
char * argvarry[(gcps.size() * 5) + 8];
argvarry[0] = "-of";
argvarry[1] = "GTiff";
argvarry[2] = "-a_nodata";
argvarry[3] = "'0 0 0'";
argvarry[4] = "-a_srs";
argvarry[5] = a_srs;
int argc = 6;
for (int i = 0;i < gcps.size(); i++) {
argvarry[argc] = "-gcp";argc++;//gcp_values
gcppoint_ *a = qobject_cast<gcppoint_ *>(gcps.at(i).value<QObject *>());
argvarry[argc]= strdup( const_cast<char*>(QString::number(a->row()).toStdString().c_str())); argc++;
argvarry[argc] = strdup(const_cast<char*>(QString::number(a->column()).toStdString().c_str())); argc++;
argvarry[argc] = strdup(const_cast<char*>(QString::number(a->lon()).toStdString().c_str())); argc++;
argvarry[argc] =strdup( const_cast<char*>(QString::number(a->lat()).toStdString().c_str())); argc++;
}
好吧,我尝试了一些方法使上面的代码工作,但 none 工作,
例如,如果我使用 strdup
它会工作但它需要被释放,我试图将 strdup
的输出保存在一个变量中然后在循环中释放它,但它释放了所有变量。这是我的尝试
for(int i=0;i<vl.size();i++) {
gcppoint_ *a = qobject_cast<gcppoint_ *>(vl.at(i).value<QObject *>());
char* srcX =strdup(const_cast<char*>(QString::number(a->row()).toStdString().c_str()));
char* srcY = strdup(const_cast<char*>(QString::number(a->column()).toStdString().c_str()));
char* dstX =strdup( const_cast<char*>(QString::number(a->lon()).toStdString().c_str()));
char* dstY = strdup(const_cast<char*>(QString::number(a->lat()).toStdString().c_str()));
qDebug() <<srcX<<" " <<srcY << " " <<dstX<< " " <<dstY;
argvarry[i]=srcX;
if(srcX)
free(srcX) //does not work it frees argvarry[i] too
}
//...do some thing with argvarry
free????
我注意到所有 argvarry[i]
也将被释放,所以我不能再使用它们了。好吧,我怎样才能让它工作,我有太多空闲 strdup
但我无法处理它。我如何更改此循环以及当我使用 argvarry
时释放 strup
结果?
如果我将上面的代码改成类似的东西会怎样
char * srcX;
char * srcY;
char * dstX;
char * dstY;
for (int i = 0;i < gcps.size(); i++) {
argvarry[argc] = "-gcp";argc++;//gcp_values
gcppoint_ *a = qobject_cast<gcppoint_ *>(gcps.at(i).value<QObject *>());
srcX= strdup( const_cast<char*>(QString::number(a->row()).toStdString().c_str()));
srcY = strdup(const_cast<char*>(QString::number(a->column()).toStdString().c_str()));
dstX = strdup(const_cast<char*>(QString::number(a->lon()).toStdString().c_str()));
dstY =strdup( const_cast<char*>(QString::number(a->lat()).toStdString().c_str()));
argvarry[argc]=srcX;argc++;
argvarry[argc]=srcY;argc++;
argvarry[argc]=dstX;argc++;
argvarry[argc]=dstY;argc++;
}
///do things
//free(srcX);free(srcY)
char* srcX = const_cast<char*>(QString::number(a->row()).toStdString().c_str());
上面的问题是 toStdString() returns 一个临时的 QString 对象,并且由于 QString 对象是临时的,它在行尾被销毁。这意味着当您稍后尝试使用它时,srcX 是一个悬挂指针。
如果您确实需要一个 char *
指针数组,则需要确保它们指向的数据在数组的生命周期内保持有效。 strdup()
是一种方法,但正如您所指出的,它有其自身的困难,特别是您需要在完成字符串后手动调用 free() ,否则您将内存泄漏。
另一种方法是先建立 std::string 个对象的列表,如下所示:
// Build up a list of std::strings
std::vector<std::string> strsList;
strsList.push_back("-of");
strsList.push_back("GTiff");
strsList.push_back("-a_nodata");
strsList.push_back("'0 0 0'");
strsList.push_back("-a_srs");
strsList.push_back("a_srs");
for (int i = 0;i < gcps.size(); i++) {
strsList.push_back("-gcp");
strsList.push_back(QString::number(a->row()).toStdString());
strsList.push_back(QString::number(a->column()).toStdString());
strsList.push_back(QString::number(a->lon()).toStdString());
strsList.push_back(QString::number(a->lat()).toStdString());
}
// Now create an array of pointers to the data in those std::strings
// This array will remain valid for as long as strsList remains valid and unmodified
char * argvarray[strsList.size()];
for (size_t i=0; i<strsList.size(); i++) argvarray[i] = const_cast<char *>(strsList[i].c_str());
我有一个循环试图从 qml 列表对象中读取数据,这是我的循环
char * argvarry[(gcps.size() * 5) + 8];
argvarry[0] = "-of";
argvarry[1] = "GTiff";
argvarry[2] = "-a_nodata";
argvarry[3] = "'0 0 0'";
argvarry[4] = "-a_srs";
argvarry[5] = a_srs;
int argc = 6;
for (int i = 0;i < gcps.size(); i++) {
argvarry[argc] = "-gcp";argc++;//gcp_values
gcppoint_ *a = qobject_cast<gcppoint_ *>(gcps.at(i).value<QObject *>());
argvarry[argc]= strdup( const_cast<char*>(QString::number(a->row()).toStdString().c_str())); argc++;
argvarry[argc] = strdup(const_cast<char*>(QString::number(a->column()).toStdString().c_str())); argc++;
argvarry[argc] = strdup(const_cast<char*>(QString::number(a->lon()).toStdString().c_str())); argc++;
argvarry[argc] =strdup( const_cast<char*>(QString::number(a->lat()).toStdString().c_str())); argc++;
}
好吧,我尝试了一些方法使上面的代码工作,但 none 工作,
例如,如果我使用 strdup
它会工作但它需要被释放,我试图将 strdup
的输出保存在一个变量中然后在循环中释放它,但它释放了所有变量。这是我的尝试
for(int i=0;i<vl.size();i++) {
gcppoint_ *a = qobject_cast<gcppoint_ *>(vl.at(i).value<QObject *>());
char* srcX =strdup(const_cast<char*>(QString::number(a->row()).toStdString().c_str()));
char* srcY = strdup(const_cast<char*>(QString::number(a->column()).toStdString().c_str()));
char* dstX =strdup( const_cast<char*>(QString::number(a->lon()).toStdString().c_str()));
char* dstY = strdup(const_cast<char*>(QString::number(a->lat()).toStdString().c_str()));
qDebug() <<srcX<<" " <<srcY << " " <<dstX<< " " <<dstY;
argvarry[i]=srcX;
if(srcX)
free(srcX) //does not work it frees argvarry[i] too
}
//...do some thing with argvarry
free????
我注意到所有 argvarry[i]
也将被释放,所以我不能再使用它们了。好吧,我怎样才能让它工作,我有太多空闲 strdup
但我无法处理它。我如何更改此循环以及当我使用 argvarry
时释放 strup
结果?
如果我将上面的代码改成类似的东西会怎样
char * srcX;
char * srcY;
char * dstX;
char * dstY;
for (int i = 0;i < gcps.size(); i++) {
argvarry[argc] = "-gcp";argc++;//gcp_values
gcppoint_ *a = qobject_cast<gcppoint_ *>(gcps.at(i).value<QObject *>());
srcX= strdup( const_cast<char*>(QString::number(a->row()).toStdString().c_str()));
srcY = strdup(const_cast<char*>(QString::number(a->column()).toStdString().c_str()));
dstX = strdup(const_cast<char*>(QString::number(a->lon()).toStdString().c_str()));
dstY =strdup( const_cast<char*>(QString::number(a->lat()).toStdString().c_str()));
argvarry[argc]=srcX;argc++;
argvarry[argc]=srcY;argc++;
argvarry[argc]=dstX;argc++;
argvarry[argc]=dstY;argc++;
}
///do things
//free(srcX);free(srcY)
char* srcX = const_cast<char*>(QString::number(a->row()).toStdString().c_str());
上面的问题是 toStdString() returns 一个临时的 QString 对象,并且由于 QString 对象是临时的,它在行尾被销毁。这意味着当您稍后尝试使用它时,srcX 是一个悬挂指针。
如果您确实需要一个 char *
指针数组,则需要确保它们指向的数据在数组的生命周期内保持有效。 strdup()
是一种方法,但正如您所指出的,它有其自身的困难,特别是您需要在完成字符串后手动调用 free() ,否则您将内存泄漏。
另一种方法是先建立 std::string 个对象的列表,如下所示:
// Build up a list of std::strings
std::vector<std::string> strsList;
strsList.push_back("-of");
strsList.push_back("GTiff");
strsList.push_back("-a_nodata");
strsList.push_back("'0 0 0'");
strsList.push_back("-a_srs");
strsList.push_back("a_srs");
for (int i = 0;i < gcps.size(); i++) {
strsList.push_back("-gcp");
strsList.push_back(QString::number(a->row()).toStdString());
strsList.push_back(QString::number(a->column()).toStdString());
strsList.push_back(QString::number(a->lon()).toStdString());
strsList.push_back(QString::number(a->lat()).toStdString());
}
// Now create an array of pointers to the data in those std::strings
// This array will remain valid for as long as strsList remains valid and unmodified
char * argvarray[strsList.size()];
for (size_t i=0; i<strsList.size(); i++) argvarray[i] = const_cast<char *>(strsList[i].c_str());