Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > OOP
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Coloboración Paypal con ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-09-2008
dionisiopz dionisiopz is offline
Registrado
 
Registrado: jul 2006
Posts: 5
Poder: 0
dionisiopz Va por buen camino
No comprendo la línea "SL.CustomSort(CompareNumbers);"
Debido a que la función CompareNumbers está declarada como:
"function CompareNumbers(List: TStringList; Index1, Index2: Integer): Integer;" y debería recibir los parámentros declarados, o sea, ¿no hace falta especificar esos parámetros? por ejemplo: "SL.CustomSort(CompareNumbers(List, Index1, Index2));"

Expliquemen por favor. Gracias.
Responder Con Cita
  #2  
Antiguo 26-09-2008
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Para entender esto, pimero hay que ver la declaración del método CustomSort:

Código Delphi [-]
procedure CustomSort(Compare: TStringListSortCompare);

El parámetro es de tipo TStringListSortCompare, que está declarado así:

Código Delphi [-]
type
  TStringListSortCompare = function(List: TStringList; Index1, Index2: Integer): Integer;

Es decir, el parámetro que se pasa a CustomSort es una función. Esto hay que leerlo bien antes de digerirlo. No se le pasa el valor que devuelve la función (que sería un entero), se le pasa toda la función como parámetro.

Si bien esto puede sonar raro, quizá se te aclare si meditas en para qué se necesita tal cosa.

El origen del problema en este hilo, es que el orden natural de los elementos de un ListBox es textual, no numérico; son dos tipos distintos de ordenamiento:

1, 2, 3, 4, 5, 6 , 7, 8, 9, 10 (numérico)
1, 10, 2, 3, 4, 5, 6, 7, 8, 9 (textual)

En un orden numérico, 2 es menor que 10, pero en un orden textual, 10 es menor que 2 (puesto que al comparar el primer caracter, 1 es menor que 2).

Lo que se ve entonces, es que una lista de elementos siempre será susceptible de ordenarse según diferentes criterios. Un algoritmo de ordenación (tal como QuickSort) puede trabajar con cualquier tipo de elementos (números, cadenas, objetos, etc.) pues lo único que requieren para funcionar es saber cuando un elemento es menor que otro, es decir, sólo necesitan saber cómo comparar dos elementos.

Esto es lo que sucede con CustomSort. A este método, le pasamos una función que compara dos elementos. Internamente, CustomSort tendrá que llevar a cabo muchas comparaciones dos a dos, y tal comparación la hará utilizando la función que le pasamos.

Espero que te haya aclarado algo.

// Saludos
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
problema moviendo en el listbox ramphi Varios 2 10-12-2007 23:39:31
Problema con ListBox Jaiha OOP 2 04-07-2007 17:35:35
Problema con ListBox en Delphi7 jmlifi Varios 5 30-11-2006 00:48:20
problema en listbox ramphi Varios 6 24-08-2006 15:40:46
Problema con ListBox Delphos Varios 3 10-02-2004 17:18:39


La franja horaria es GMT +2. Ahora son las 19:22:31.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi