動機付けの例:
ジョブのリストをソートするさまざまなスケジューリング「戦略」を実装します。
type Job struct {
weight int
length int
}
// Given a slice of Jobs, re-order them.
type Strategy func([]Job) []Job
func Schedule(jobs []Job, strat Strategy) []Job {
return strat(jobs)
}
非常に単純な戦略の 1 つは、最短のジョブを最初に実行することです (重みや優先度を無視します)。
func MinCompletionTimes(job []Job) []Job {
// Hmm...
}
さて、この戦略は job.length の並べ替えに過ぎないので、並べ替えパッケージを使用しましょう。カスタム型を定義し、sort.Interface... を実装します。
type JobSlice []Job // Should probably be called MinCompletionTimesJobSlice
func (js JobSlice) Len() {
return len(js)
}
func (js JobSlice) Less(i, j int) bool {
return js[i].length < js[j].length
}
func (js JobSlice) Swap(i, j int) {
js[i], js[j] = js[j], js[i]
}
万歳、では簡単な戦略に戻りましょう...
func MinCompletionTimes(jobs []Job) []Job {
sort.Sort([]JobSlice(jobs)) // cannot convert jobs (type []Job) to type []JobSlice
return jobs
}
ええと...