0

我有一个关于将一个字符数组的变量从一个函数传递到下一个函数的问题。

以下是涉及的代码示例:

int main( int argc, char** argv )
{

int value = 0;

int nCounter = 0;
FILE* fIn = NULL;
char * sLine = new char[MAX_FILENAME_SIZE];
char * sFileName = new char [MAX_FILENAME_SIZE];
char * s = new char [MAX_FILENAME_SIZE];



if ((fIn = fopen(ImgListFileName,"rt"))==NULL)

{
    printf("Failed to open file: %s\n",ImgListFileName);
    return nCounter;
}



while(!feof(fIn)){

//set the variables to 0
memset(sLine,0,MAX_FILENAME_SIZE*sizeof(char));
memset(sFileName,0,MAX_FILENAME_SIZE*sizeof(char));
memset(s,0,MAX_FILENAME_SIZE*sizeof(char));
//read one line (one image filename)
//sLine will contain one line from the text file
fgets(sLine,MAX_FILENAME_SIZE,fIn);
//copy the filename into variable s
strncpy(s, sLine, strlen(sLine)-1);
//put a \0 character at the end of the filename
strcat(sLine,"\0");
//create the filename
strcat(sFileName,s);

nCounter++;


fclose(fIn);
delete sLine;
delete sFileName;
delete s;
    const int size = 60;
    char path[size] = "path";
    strcat(path,sFileName);

    printf (path);
IplImage *img = cvLoadImage(path);
detect_and_draw(img);
cvWaitKey();
cvReleaseImage(&img);
cvDestroyWindow("result");

void detect_and_draw( IplImage* img )
{


More code that isn't involved....


cvSaveImage(sFileName, img);

现在,我尝试了以下方法:

void getFilename(char * sFileName)
{
    printf("The filename is %s\n", sFileName);
    return;
}

然后打电话给

char * S ="string"
getFilename(S);
cvSaveImage(S,img);

但是“字符串”被放入“文件名是:字符串”。

我该怎么做才能在 cvSaveImage(sFileName, img) 中使用 sFileName、char 数组?

在此先感谢您,如果您需要任何进一步的说明,请询问!

4

2 回答 2

2

忽略未定义的行为、不必要的动态分配等,您似乎试图完成的事情归结为以下一般顺序:

std::string path;

while (std::getline(fIn, path)) {
    std::cout << "path: " << path;

    IplImage *img = cvLoadImage(path.c_str());

    detect_and_draw(img, path);
    cvWaitKey();
    cvReleaseImage(&img);

    cvDestroyWindow("result");    
}

void detect_and_draw(IpImage *img, std::string const &path) { 
// ...
    cvSaveImage(path.c_str(), img);
}

不过,我想我会做一些不同的事情——可能从一Image门课开始,比如:

class Image { 
    IpImage *img;
    std::string path;

public:
    Image(std::string const &name) : 
        img(cvLoadImage(name.c_str()), path(name) 
    { }

    ~Image() { cvReleaseImage(&img); }

    void detect_and_draw() { 
         // ...
         cvSaveImage(path);
    }
};

使用它,您的代码看起来更像这样:

while (std::getline(fIn, path)) {
    Image img(path);
    img.detect_and_draw();
    cvWaitKey();
    cvDestroyWindow("result");
}

这并不完全清楚,但cvDestroyWindow听起来很像真正属于析构函数的东西,但我不确定这些部分如何组合在一起以确定什么析构函数 - 也许Image是,更可能是别的东西。

我注意到这detect_and_draw实际上是在尖叫“这段代码忽略了单一责任原则”。它在名称中列出了两个职责,并且似乎至少还有第三个职责(保存文件)。

于 2012-07-24T20:30:56.333 回答
1

如果我理解正确,那么您所拥有的是范围界定问题。你基本上有:

int main(/* */)
{ char sFileName[MAX_FILENAME_SIZE];

  /* code to initialize sFileName to contain a value */

  detect_and_draw(img);
}

void detect_and_draw(IplImage *img)
{ cvSaveImage(sFileName, img);
}

问题是它sFileName是本地的main(),无法在detect_and_draw(). 您可以修改detect_and_draw()以采用第二个参数:

int main()
{ /* stuff */
  detect_and_draw(img, sFileName);
}
void detect_and_draw(IplImage *img, const char* fn)
{ cvSaveImage(fn, img);
}

或者使 sFileName 成为在范围之外声明/定义的全局变量main()- 尽管这通常被认为是一个劣质的解决方案。

于 2012-07-24T20:21:33.457 回答