つい最近知ったのですが。
JavaScript のオブジェクトで for-in は順序固定になっていた。
#!/usr/bin/gjs let text = 'あいうえおかきくけこ'; let ls = {}; for (let s of text) ls[s] = s+s+s; for (let key in ls) print(`Key=${key} Value=${ls[key]}`);
マジだ、ES2020 かららしい。
これができないのが主な理由で ES6(ES2015) で Map が追加された。
Map なんて誰も使わなかったということなのだろうか。
JavaScript その他 – Paepoi
書き換えしなきゃなぁ、どんどん情報が古くなる。
そういえば Python の連想配列も 3.7 から順序固定になっていたんだっけ。
collections.OrderedDict は存在すら知らない人も多いし。
#!/usr/bin/env python3 text = 'あいうえおかきくけこ' ls = {} for s in text: ls[s] = s+s+s for key in ls: print(f'Key={key} Value={ls[key]}')
まったく同じですね、流行なのかな。
まてよ、もしかして GLib なんかも。
#include <glib.h> #include <glib/gprintf.h> void printfunc(gpointer key, gpointer value, gpointer user_data) { g_printf("key=%s value=%s\n", key, value); } int main (int argc, char *argv[]) { GHashTable *table; table = g_hash_table_new(g_str_hash, g_str_equal); g_hash_table_insert(table, "あ", "あああ"); g_hash_table_insert(table, "い", "いいい"); g_hash_table_insert(table, "う", "ううう"); g_hash_table_insert(table, "え", "えええ"); g_hash_table_insert(table, "お", "おおお"); g_hash_table_insert(table, "こ", "こここ"); g_hash_table_insert(table, "け", "けけけ"); g_hash_table_insert(table, "く", "くくく"); g_hash_table_insert(table, "き", "ききき"); g_hash_table_insert(table, "か", "かかか"); // g_hash_table_foreach(table, printfunc, NULL); return 0; }
やっぱり駄目でした、普通はこうなるし。
C を久々に書いてみたけどメンドクセー!