Поделиться через


Функция Array.sortWith<'T> (F#)

Сортирует элементы массива, используя заданную функцию сравнения по порядку и возвращая новый массив.

Пространство имен/путь к модулю: Microsoft.FSharp.Collections.Array

Сборка: FSharp.Core (в FSharp.Core.dll)

// Signature:
Array.sortWith : ('T -> 'T -> int) -> 'T [] -> 'T []

// Usage:
Array.sortWith comparer array

Параметры

  • comparer
    Тип: 'T -> 'T -> int

    Функция, используемая для сравнения пар элементов массива.

  • array
    Тип: 'T []

    Входной массив.

Возвращаемое значение

Сортируемый массив.

Заметки

Это не стабильная сортировка, то есть исходный порядок равных элементов может не сохраниться. Для обеспечения стабильных результатов сортировки можно использовать Seq.sort.

В скомпилированных сборках имя этой функции — SortWith. При обращении к функции из языка, отличного от F#, или посредством отражения следует использовать это имя.

Пример

В следующем коде показано использование Array.sortWith.

open System

let array1 = [| "<>"; "&"; "&&"; "&&&"; "<"; ">"; "|"; "||"; "|||" |]
printfn "Before sorting: "
array1 |> printfn "%A"
let sortFunction (string1:string) (string2:string) =
    if (string1.Length > string2.Length) then
       1
    else if (string1.Length < string2.Length) then
       -1
    else
        String.Compare(string1, string2)

Array.sortWith sortFunction array1
|> printfn "After sorting: \n%A"

Output

  

Платформы

Windows 7, Windows Vista с пакетом обновления 2 (SP2), Windows XP с пакетом обновления 3 (SP3), Windows XP x64 с пакетом обновления 2 (SP2), Windows Server 2008 R2, Windows Server 2008 с пакетом обновления 2 (SP2), Windows Server 2003 с пакетом обновления 2 (SP2)

Сведения о версии

Среда выполнения F#

Поддерживается в версиях 2.0, 4.0

Silverlight

Поддерживается в версии 3

См. также

Ссылки

Модуль Collections.Array (F#)

Пространство имен Microsoft.FSharp.Collections (F#)

Журнал изменений

Дата

Журнал

Причина

Август 2010

Добавлен пример кода.

Улучшение информации.