Moin,
wie gesagt, es geht um Sortierung mit qsort.
Dazu habe ich erstmal ein Array erzeugt, und die Suchfunktion
drüberlaufen lassen, das hat soweit auch funktioniert. Das Array soll 32
Strings mit max. 256 Byte Länge enthalten.
Ich habe mal die Codeausschnitt mal auf die entscheidenden Teile
reduziert.
1 | FileList[32][256];
|
2 |
|
3 | // Füllen mit Strings [...]
|
4 | strcpy(FileList[i], finfo.lfname);
|
5 |
|
6 | qsort((void *)FileList, TotalFileCount, sizeof(fileListString), compare); // Sort the array
|
7 |
|
8 | int compare(const void *a, const void *b)
|
9 | {
|
10 | const char *ia = (const char *)a;
|
11 | const char *ib = (const char *)b;
|
12 | return strcmp(ia, ib);
|
13 | }
|
Das klappt soweit auch. Da das Array aber recht dünn besetzt ist, wollte
ich die Speicherverschwendung vermeiden und allokiere nun den Speicher
dynamisch:
1 | WORD MallocIndex;
|
2 | FileList = malloc(TotalFileCount * sizeof(char *));
|
3 | MallocIndex = 0;
|
4 |
|
5 | // Array füllen [..]
|
6 | FileList[MallocIndex] = malloc(strlen(finfo.lfname) + 1);
|
7 | strcpy(FileList[MallocIndex], finfo.lfname);
|
Soweit so gut, die Elemente landen im Array und ich kann sie ausgeben.
Nun würde ich diese Strings gerne sortieren. Dafür habe ich erst mal die
compare Funktion angepasst:
1 | int compare(const void *a, const void *b)
|
2 | {
|
3 | const char *ia = (const char **)a;
|
4 | const char *ib = (const char **)b;
|
5 | return strcmp(ia, ib);
|
6 | }
|
Jetzt muss ich noch das qsort richtig aufrufen, und das klappt nicht so
recht.
Ich muss ja die Pointer vertauschen, und nicht wie vorher die Strings
selber. Wie mache ich das also mit dynamischer Speicherverwaltung?
1 | qsort((void *)FileList, TotalFileCount, sizeof(fileListString), compare); // GEHT SO LOGISCHERWEISE NICHT
|
Gruß