这可能不是最好的想法,但我试图使用D语言的一些内置功能来对关联数组进行排序,以便可以对计算进行前几个或后几个值的切片。
我已经尝试过:
我已经尝试过:
sort!((a,b) {return query[a] < query[b];})(query);
并且:
sort(query);
导致相同的错误:
错误:模板std.algorithm.sort无法从参数类型!()(int[string])推断函数,候选项为: /usr/local/Cellar/dmd/2.066.1/include/d2/std/algorithm.d(9384): std.algorithm.sort(alias less = "a < b", SwapStrategy ss = SwapStrategy.unstable, Range)(Range r) if ((ss == SwapStrategy.unstable && (hasSwappableElements!Range || hasAssignableElements!Range) || ss != SwapStrategy.unstable && hasAssignableElements!Range) && isRandomAccessRange!Range && hasSlicing!Range && hasLength!Range)
这里是整个类:
import std.stdio;
import std.array;
import std.algorithm;
import DataRow;
import LocationMap;
class Database{
this(){ /* intentionally left blank */}
public:
void addRow(DataRow input){ this.db ~= input; }
DataRow[] getDB(){ return this.db; }
DataRow getDBRow(uint i){ return this.db[i]; }
int[string] exportQuery(uint year){
int[string] query;
foreach (DataRow row ; db){
if (row.getYear() == year){
query[row.getCountryName()] = row.getExports;
}
}
//sort!((a,b) {return query[a] < query[b];})(query);
sort(query);
return query;
}
private:
DataRow[] db;
LocationMap locMap;
}