この問題を解決するオブジェクト指向の方法は、アルバムに関連する4つの情報すべてを含み、4つの配列ではなく単一のアルバムの配列を持つアルバムタイプを定義することです。
次に、必要に応じてアルバムの比較を定義できます。これがC#の例です(Javaでも非常に似ています):
class Program {
static void Main(string[] args) {
Album[] albums = { new Album { artist = "potatotes",
family = "soup",
title = "a",
year=1546 },
new Album { artist = "etc",
family="blabla",
title="blablabla",
year = 1999 }
};
Array.Sort(albums);
}
}
class Album : IComparable<Album> {
public int CompareTo(Album y) {
return family.CompareTo(y.family);
}
public string title { get; set; }
public string artist { get; set; }
public int year { get; set; }
public string family { get; set; }
}
ここでは、アルバムのファミリの観点からIComparableインターフェイスを実装しました。一般的な考え方は、関連するすべての情報をクラスにグループ化することです。次に、そのフィールドの1つに関して、そのクラスのオブジェクトの比較を定義できます。
一部の人が指摘するかもしれませんが、C#でこれを実現するためのより柔軟な方法がありますが、私はこれを可能な限り単純で言語に依存しないようにしたいと思いました。
言語がユーザー定義の構造をサポートしている限り、これを複製することは可能ですが、AutoITがそれをサポートしているかどうかさえわかりません。その場合、4つの配列を保持し、配列の1つを並べ替えて、他の3つすべてに同時にスワップ操作を複製するカスタム並べ替え関数を実装する必要があります。しかし、それはもっと多くの仕事です。