位運算的簡單應用-許可權管理

来源:https://www.cnblogs.com/milovetingting/archive/2020/01/16/12203767.html
-Advertisement-
Play Games

個人博客 "http://www.milovetingting.cn" 位運算的簡單應用 許可權管理 位運算在實際的開發中,有很多巧妙的應用場景。如: 1. 一個存放正整數的數組,裡面有一個數字只出現一次,其它數字都出現兩次,求只出現一次的數字。 2. 不用臨時變數,交換兩個數字的值。 3. Andr ...


個人博客

http://www.milovetingting.cn

位運算的簡單應用-許可權管理

位運算在實際的開發中,有很多巧妙的應用場景。如:

  1. 一個存放正整數的數組,裡面有一個數字只出現一次,其它數字都出現兩次,求只出現一次的數字。

  2. 不用臨時變數,交換兩個數字的值。

  3. Android中Window設置Flag

    public void setFlags(int flags, int mask) {
        final WindowManager.LayoutParams attrs = getAttributes();
        attrs.flags = (attrs.flags&~mask) | (flags&mask);
        mForcedWindowFlags |= mask;
        dispatchWindowAttributesChanged(attrs);
    }
  1. 產品具有某些Feature,這些Feature可以利用位運算來存儲。

下麵利用位運算來簡單模擬許可權管理

許可權管理類

public class PermissionManager {

    public static final int PERMISSION_NONE = 1;

    public static final int PERMISSION_A = 1 << 1;

    public static final int PERMISSION_B = 1 << 2;

    public static final int PERMISSION_C = 1 << 3;

    public static final int PERMISSION_D = 1 << 4;

    private int mPermission = PERMISSION_NONE;

    private static class PermissionManagerHolder {
        static PermissionManager sPermissionManager = new PermissionManager();
    }

    private PermissionManager() {

    }

    public static PermissionManager getInstance() {
        return PermissionManagerHolder.sPermissionManager;
    }

    /**
     * 添加許可權
     * @param permission
     */
    public void addPermission(int permission) {
        if (hasPermission(permission)) {
            return;
        }
        mPermission |= permission;
    }

    /**
     * 移除許可權
     * @param permission
     */
    public void removePermission(int permission) {
        if (!hasPermission(permission)) {
            return;
        }
        mPermission &= ~permission;
    }

    /**
     * 判斷是否有許可權
     * @param permission
     * @return
     */
    public boolean hasPermission(int permission) {
        return (mPermission & permission) != 0;
    }

}

使用

public static void main(String[] args) {
        System.out.println("沒有添加任何許可權----------");
        PermissionManager permissionManager = PermissionManager.getInstance();
        checkPermission(permissionManager);
        System.out.println("添加許可權A----------");
        System.out.println("添加許可權B----------");
        System.out.println("添加許可權C----------");
        permissionManager.addPermission(PermissionManager.PERMISSION_A);
        permissionManager.addPermission(PermissionManager.PERMISSION_B);
        permissionManager.addPermission(PermissionManager.PERMISSION_C);
        checkPermission(permissionManager);
        System.out.println("刪除許可權C----------");
        permissionManager.removePermission(PermissionManager.PERMISSION_C);
        checkPermission(permissionManager);
    }

    public static void checkPermission(PermissionManager permissionManager) {
        System.out.println("PERMISSION_A exist:" + permissionManager.hasPermission(PermissionManager.PERMISSION_A));
        System.out.println("PERMISSION_B exist:" + permissionManager.hasPermission(PermissionManager.PERMISSION_B));
        System.out.println("PERMISSION_C exist:" + permissionManager.hasPermission(PermissionManager.PERMISSION_C));
        System.out.println("PERMISSION_D exist:" + permissionManager.hasPermission(PermissionManager.PERMISSION_D));
    }

輸出結果:

沒有添加任何許可權----------
PERMISSION_A exist:false
PERMISSION_B exist:false
PERMISSION_C exist:false
PERMISSION_D exist:false
添加許可權A----------
添加許可權B----------
添加許可權C----------
PERMISSION_A exist:true
PERMISSION_B exist:true
PERMISSION_C exist:true
PERMISSION_D exist:false
刪除許可權C----------
PERMISSION_A exist:true
PERMISSION_B exist:true
PERMISSION_C exist:false
PERMISSION_D exist:false

位運算並不限於許可權管理,具有多個狀態的應用場景,都可以用到。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 9.1 計算欄位 存儲在資料庫表中的數據一般不是應用程式所需要的格式。比如: 如果想要在一個欄位中既顯示公司名,又顯示公式的地址,但這兩個信息一般包含在不同的表列中。 城市、州和郵政編碼存儲在不同的列中,但郵件標簽列印程式卻需要把它們作為一個恰當格式的欄位檢索出來。 列數據是大小寫混合的,但報表程式 ...
  • 對於DBA來說,丟失超管用戶root的密碼是致命的, 可以通過添加--ship-grant-tables參數來跳過許可權表。 1、忘記root密碼,進不去資料庫: 這個時候需要強制停庫,先查看MySQL進程號 Kill掉MySQL進程,命令如下: Kill完可以再查看是否還有進程 [root@tse2 ...
  • oracle 12.2 RAC監聽日誌報錯:15-JAN-2020 22:27:53 * (CONNECT_DATA=(COMMAND=VERSION)) * version * 1189TNS-01189: The listener could not authenticate the user ...
  • 引用 https://www.cnblogs.com/qingyunzong/p/8744593.html#_label0 官方文檔 https://cwiki.apache.org/confluence/display/Hive/LanguageManual+UDF 目錄 數學函數 集合函數 類型 ...
  • 環境:SQL 2016; 語句 select * from A where PID=JoID 上述查詢語句中的Where PID=JoID條件中PID的欄位類型為varchar(50)而JoID的欄位類型為uniqueidentifier,該寫法在升級之前的(SQL2012)庫上沒有問題,但在新庫( ...
  • 問題描述:現場一臺測試伺服器,安裝有oracle11g(11.2.0.1),上午還運行正常,結果下午直接訪問不了,提示錯誤:ora-12541 無監聽程式問題。問題排查:按照常規方法,重啟監聽程式以及資料庫、重新配置監聽程式均無作用,後來發現是listener.log日誌文件過大(達到4G,據說這是... ...
  • 利用空閑時間花幾分鐘回顧一下 7.1 檢索數據 為了查詢出資料庫表中的行(數據),使用SELECE語句。 格式: 第一種寫法使用\ 通配符,會把表中行的列全部查詢出來,而不必取一一列出全部列。但是不推薦使用,這跟INSERT語句的規範寫法一樣。 使用\ 通配符,列的順序一般是列在表定義中出現的順序, ...
  • 最近在自學看 資料庫系統概論 這本書,總結一下遇到的問題。 1.廣義笛卡爾積(Extende cartesian product): 屬於 關係代數 裡面的 傳統的集合運算。其他的為union,except,intersection. 詳情不提了,舉個例子就是: create table R(A c ...
一周排行
    -Advertisement-
    Play Games
  • JWT(JSON Web Token)是一種用於在網路應用之間傳遞信息的開放標準(RFC 7519)。它使用 JSON 對象在安全可靠的方式下傳遞信息,通常用於身份驗證和信息交換。 在Web API中,JWT通常用於對用戶進行身份驗證和授權。當用戶登錄成功後,伺服器會生成一個Token並返回給客戶端 ...
  • 老周在幾個世紀前曾寫過樹莓派相關的 iOT 水文,之所以沒寫 Nano Framework 相關的內容,是因為那時候這貨還不成熟,可玩性不高。不過,這貨現在已經相對完善,老周都把它用在項目上了——第一個是自製的智能插座,這個某寶上50多塊可以買到,搜“esp32 插座”就能找到。一種是 86 型盒子 ...
  • 引言 上一篇我們創建了一個Sample.Api項目和Sample.Repository,並且帶大家熟悉了一下Moq的概念,這一章我們來實戰一下在xUnit項目使用依賴註入。 Xunit.DependencyInjection Xunit.DependencyInjection 是一個用於 xUnit ...
  • 在 Avalonia 中,樣式是定義控制項外觀的一種方式,而控制項主題則是一組樣式和資源,用於定義應用程式的整體外觀和感覺。本文將深入探討這些概念,並提供示例代碼以幫助您更好地理解它們。 樣式是什麼? 樣式是一組屬性,用於定義控制項的外觀。它們可以包括背景色、邊框、字體樣式等。在 Avalonia 中,樣 ...
  • 在處理大型Excel工作簿時,有時候我們需要在工作表中凍結窗格,這樣可以在滾動查看數據的同時保持某些行或列固定不動。凍結窗格可以幫助我們更容易地導航和理解複雜的數據集。相反,當你不需要凍結窗格時,你可能需要解凍它們以獲得完整的視野。 下麵將介紹如何使用免費.NET庫通過C#實現凍結Excel視窗以鎖 ...
  • .NET 部署 IIS 的簡單步驟一: 下載 dotnet-hosting-x.y.z-win.exe ,下載地址:.NET Downloads (Linux, macOS, and Windows) (microsoft.com) .NET 部署 IIS 的簡單步驟二: 選擇對應的版本,點擊進入詳 ...
  • 拓展閱讀 資料庫設計工具-08-概覽 資料庫設計工具-08-powerdesigner 資料庫設計工具-09-mysql workbench 資料庫設計工具-10-dbdesign 資料庫設計工具-11-dbeaver 資料庫設計工具-12-pgmodeler 資料庫設計工具-13-erdplus ...
  • 初識STL STL,(Standard Template Library),即"標準模板庫",由惠普實驗室開發,STL中提供了非常多對信息學奧賽很有用的東西。 vector vetor是STL中的一個容器,可以看作一個不定長的數組,其基本形式為: vector<數據類型> 名字; 如: vector ...
  • 前言 最近自己做了個 Falsk 小項目,在部署上伺服器的時候,發現雖然不乏相關教程,但大多都是將自己項目代碼複製出來,不講核心邏輯,不太簡潔,於是將自己部署的經驗寫成內容分享出來。 uWSGI 簡介 uWSGI: 一種實現了多種協議(包括 uwsgi、http)並能提供伺服器搭建功能的 Pytho ...
  • 1 文本Embedding 將整個文本轉化為實數向量的技術。 Embedding優點是可將離散的詞語或句子轉化為連續的向量,就可用數學方法來處理詞語或句子,捕捉到文本的語義信息,文本和文本的關係信息。 ◉ 優質的Embedding通常會讓語義相似的文本在空間中彼此接近 ◉ 優質的Embedding相 ...