引言:ui
枚舉值 它是一個整形(int) 而且,它不參與內存的佔用和釋放,枚舉定義變量便可直接使用,不用初始化.spa
在代碼中使用枚舉的目的只有一個,那就是增長代碼的可讀性..net
使用:blog
枚舉的定義以下:ip
亦能夠以下定義(推薦:結構比較清晰):內存
枚舉的定義還支持位運算的方式定義,以下:get
等於號後面必須等於1string
何時要用到這種方式呢?it
那就是一個枚舉變量可能要表明多個枚舉值的時候. 其實給一個枚舉變量賦予多個枚舉值的時候,原理只是把各個枚舉值加起來罷了.class
當加起來之後,就獲取了一個新的值,那麼爲了保證這個值的惟一性,這個時候就體現了位運算的重要做用.
位運算能夠確保枚舉值組合的惟一性.
由於位運算的計算方式是將二進制轉換成十進制,也就是說,枚舉值裏面存取的是 計算後的十進制值.
打個比方:
經過上面的位運算方式設定好枚舉之後,打印出來的枚舉值分別是: 1 2 4 8 16
這5個數字,不管你如何組合在一塊兒,也不會產生兩個一樣的數字.
手工的去建立位運算枚舉,還有稍微有點花時間的,好在Apple已經爲咱們準備的uint.因此,用下面這種方式來初始化一個位運算枚舉吧:
多枚舉值 賦值方式以下:
判斷枚舉變量是否包含某個固定的枚舉值,使用前須要確保枚舉值以及各個組合的惟一性:
若是 沒有包含,將返回0, 0表示false NO 則進入else
也能夠隨時爲枚舉變量累加某個值,可是要本身控制不要添加已經加入過的枚舉值, 枚舉變量的值不會有變更,但這樣將會誤導閱讀代碼的人
有累加,天然有累減了,若是累減不存在的枚舉值, 那麼本次累減的枚舉值,會自動累加上去.