我在問這個問題,因爲這不是我第一次看到這種編碼習慣,但從來沒有看到任何關於這個原因的評論:我在瀏覽Lua的源文件,看到他們使用'顏色'(白色,黑色)來描述對象的狀態。下面是從頭部lgc.h代碼:使用'顏色'來定義對象的標誌狀態?
/*
** Layout for bit use in `marked' field:
** bit 0 - object is white (type 0)
** bit 1 - object is white (type 1)
** bit 2 - object is black
** bit 3 - for userdata: has been finalized
** bit 3 - for tables: has weak keys
** bit 4 - for tables: has weak values
** bit 5 - object is fixed (should not be collected)
** bit 6 - object is "super" fixed (only the main thread)
*/
#define WHITE0BIT 0
#define WHITE1BIT 1
#define BLACKBIT 2
#define FINALIZEDBIT 3
#define KEYWEAKBIT 3
#define VALUEWEAKBIT 4
#define FIXEDBIT 5
#define SFIXEDBIT 6
#define WHITEBITS bit2mask(WHITE0BIT, WHITE1BIT)
#define iswhite(x) test2bits((x)->gch.marked, WHITE0BIT, WHITE1BIT)
#define isblack(x) testbit((x)->gch.marked, BLACKBIT)
#define isgray(x) (!isblack(x) && !iswhite(x))
#define otherwhite(g) (g->currentwhite^WHITEBITS)
#define isdead(g,v) ((v)->gch.marked & otherwhite(g) & WHITEBITS)
#define changewhite(x) ((x)->gch.marked ^= WHITEBITS)
#define gray2black(x) l_setbit((x)->gch.marked, BLACKBIT)
#define valiswhite(x) (iscollectable(x) && iswhite(gcvalue(x)))
我已經看到了在其他項目類似的東西(它甚至用「紅」),但永遠無法理解(也不關心)什麼是顏色和物體之間的概念連接州。有什麼樣的約定規定'白色'應該表示'好'和'黑','壞'或類似的東西?任何人都知道這種做法的起源是什麼?
您可能在紅黑樹的實現中看到了「紅色」。那裏的顏色並不重要,除了圖表看起來比橙色粉紅色的樹更可敬。 – 2009-08-05 01:22:51