player_t* getFirstMatch(player_t** sortedPlayers, int playerCount, char* inputString)
{
player_t searchPlayer;
player_t* searchPlayerPointer = &searchPlayer;
searchPlayer.nameLast = inputString;
searchPlayerPointer = (player_t*) bsearch(searchPlayerPointer,
*sortedPlayers, playerCount, sizeof(player_t*),
playerCompareLast);
return searchPlayerPointer;
}
我的程序在使用 bsearch() 的行上出现分段错误。我在这里做错了什么?这是我的比较功能。我在 qsort 中使用了类似的版本,但现在我需要在 bsearch 中使用这个版本:
int playerCompareLast(const void *p1, const void *p2)
{
char* nameLast1;
char* nameLast2;
int result;
nameLast1 = (*(player_t **)p1)->nameLast;
nameLast2 = (*(player_t **)p2)->nameLast;
result = strcmp(nameLast1, nameLast2);
return result;
}
player_t 类型只是一个包含一堆不同成员(如 nameLast、nameFirst 等)的 Struct。我无法弄清楚我的 bsearch() 参数有什么问题!