C ++ qsort里面的函数结构数组

时间:2013-11-15 04:42:21

标签: c++ arrays function qsort

我再次,我正在研究zipType数组的qsort。我写的比较函数看起来像这样:

    int compare(const void *v1, const void *v2){
        const struct zipType *p1 = v1;
        const struct zipType *p2 = v2;
        if (p1->postalCode > p2->postalCode)
            return(+1);
        else if (p1->postalCode < p2->postalCode)
            return(-1);
        else
            return(0);
        }

这是使用它的功能:

   void binRead(zipType *zip, fstream *input){
   int junk;
   int count;
   int end;
   input->seekg(0,ios::end);
   end=input->tellg();
   count=input->tellg()/24;
   input->seekg(0);

   while(input->tellg()!=end){  
    for(int i=0;i<count;i++){
        input->read((char*)( &(zip[i].postalCode) ), sizeof(int    ));
        input->read((char*)( &junk ),                sizeof(int    ));
        input->read((char*)( &(zip[i].longitude)  ), sizeof(double  ));
        input->read((char*)( &(zip[i].latitude)   ), sizeof(double  ));
        cout << "Currently at position" << input->tellg() << endl;
     }
   }

   cout << "Array Created, Please wait while I sort" << endl;
   qsort(zip, count, sizeof(int), compare);
   usleep(3000000);
   cout << "Array Sorted" << endl;

  }

我得到的错误有以下几种:

    invalid conversion from ‘const void*’ to ‘const zipType*’ [-fpermissive]
    const struct zipType *p2 = v2;

其中一个:

     error: cannot convert ‘zipType’ to ‘void*’ for argument ‘1’ to ‘void qsort(void*, size_t, size_t, int (*)(const void*, const void*))’
     qsort(*zip, count, sizeof(int), compare);

我应该做些什么?

2 个答案:

答案 0 :(得分:1)

要修复第一个错误,您需要从比较例程中的void*转换:

auto p1 = static_cast<const struct zipType*>(v1);

要解决第二个错误,我想我们再次需要施放,但这次是void*

qsort(static_cast<void*>(zip), count, sizeof(zipType*), compare)

老实说,我不确定为什么需要这种演员表。如果我正确记住转换规则,zipType*应该可以隐式转换为void*。如果有人知道,发表评论我会编辑答案,或者,如果可以的话,只需编辑答案。

请注意,您希望数组中元素的大小为third parameter,而不是sizeof(int)。您的数组zipType*不是int

由于您使用的是C ++(因为您使用的是std::cout而推断),请尝试std::sort。它更加类型安全,通常可以更好地进行优化。

std::sort(zip, std::advance(zip, count), compare)

此外,由于这是C ++,因此您无需说struct zipType。你可以说zipType

答案 1 :(得分:0)

您应首先阅读qsort。然后您将了解每个参数的含义。

你的qsort应该是这样的: qsort((void*)zip, count, sizeof(struct zipType), compare);

第三个参数size表示数组中elem的大小,应为zipType而不是int