亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java實現(xiàn)Treap樹的示例代碼

 更新時間:2022年06月29日 10:27:55   作者:lolxxs  
本文主要介紹了Java實現(xiàn)Treap樹的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

Treap樹

Treap樹是平衡二叉搜索樹的一種實現(xiàn)方式,但它不是完全平衡的。平衡二叉搜索樹的實現(xiàn)方式還有AVL樹、紅黑樹、替罪羊樹、伸展樹

數(shù)據(jù)結(jié)構(gòu)

Treap樹的節(jié)點除了有二叉搜索樹的必須有的值,還有一個隨機生成的優(yōu)先級priority,供構(gòu)造小頂堆使用,小頂堆的特性就是父節(jié)點、左右子結(jié)點中永遠是父節(jié)點的優(yōu)先級最小,最多和子結(jié)點的相等。而大頂堆則是父節(jié)點的最大。堆中左右子結(jié)點的優(yōu)先級并沒有特定要求

class TreeNode {
? ? int value;
? ? int priority;
? ? TreeNode left;
? ? TreeNode right;

? ? public TreeNode(int value, int priority) {
? ? ? ? this.value = value;
? ? ? ? this.priority = priority;
? ? }
}

遍歷

Treap樹雖然是不完全平衡樹,但是其完全滿足二叉搜索樹的特征,即中序遍歷得到的是有序數(shù)組

public void printTree(TreeNode root) {
   if (root != null) {
        printTree(root.left);
        System.out.println(root.value);
        printTree(root.right);
    }
}  

查詢

Treap樹滿足二叉搜索樹的特征,則直接根據(jù)其特征查詢

// 查詢
// 根據(jù)二叉搜索樹性質(zhì)查詢
public TreeNode query(TreeNode root, int value) {
    //這里的root才是真root,上面的方法只是局部變量
    //所以不能在查詢中改變根節(jié)點
    TreeNode temp = root;
    while (temp != null) {
        if (temp.value > value) {
            temp = temp.left;
        } else if (temp.value < value) {
            temp = temp.right;
        } else {
            return temp;
        }
    }
    return null;
}

增加

步驟

  • 按照二叉搜索樹的插入方式,將節(jié)點插入到葉子節(jié)點,如果在查找的過程找到要插入的值,則不會進行插入,具有去重效果
  • 插入節(jié)點后,根據(jù)隨機生成的priority優(yōu)先級,按照小頂堆,即priority較小的成為父節(jié)點,來進行左旋右旋
//增加
// ?1.按照二叉查找樹的插入方式,將節(jié)點插入到樹葉中
// ?2.再根據(jù)priority優(yōu)先級的小頂堆性質(zhì)進行左旋右旋
public TreeNode insert(int value, TreeNode root) {
? ? ?// 如果父節(jié)點為空,則創(chuàng)建一個父節(jié)點并返回
? ? ?// 第一次父節(jié)點為根節(jié)點
? ? ?if (root == null) {
? ? ? ? ?return new TreeNode(value, random.nextInt());
? ? ?}

? ? ?// 如果要根節(jié)點的值大于要插入結(jié)點的值,則應(yīng)該插入到根節(jié)點的左邊
? ? ?if (root.value > value) {
? ? ? ? ?// 遞歸進行插入,一直遞歸到葉子節(jié)點才會插入
? ? ? ? ?// 如果遞歸到一個相等的節(jié)點,則不會創(chuàng)建一個新節(jié)點,會直接返回
? ? ? ? ?root.left = insert(value, root.left);

? ? ? ? ?// 插入完成后,根據(jù)堆的優(yōu)先級進行旋轉(zhuǎn)操作
? ? ? ? ?// 左子結(jié)點的優(yōu)先級值小于根結(jié)點的優(yōu)先級,
? ? ? ? ?// 根據(jù)小頂堆的規(guī)則,需要進行右旋操作
? ? ? ? ?if (root.left.priority < root.priority) {
? ? ? ? ? ? ?// 傳入root根結(jié)點,返回的是左子結(jié)點,
? ? ? ? ? ? ?// 但此時左子結(jié)點已經(jīng)旋轉(zhuǎn)成為根結(jié)點所以賦值給根結(jié)點
? ? ? ? ? ? ?root = rightRotate(root);
? ? ? ? ?}
? ? ?}
? ? ?// 如果根節(jié)點的值小于要插入結(jié)點的值大于,則應(yīng)該插入到根節(jié)點的右邊
? ? ?else if (root.value < value) {
? ? ? ? ?// 遞歸插入
? ? ? ? ?root.right = insert(value, root.right);
? ? ? ? ?// 右子結(jié)點的優(yōu)先級值小于根結(jié)點的優(yōu)先級,
? ? ? ? ?// 根據(jù)小頂堆的規(guī)則,需要進行左旋操作
? ? ? ? ?if (root.right.priority < root.priority) {
? ? ? ? ? ? ?root = leftRotate(root);
? ? ? ? ?}
? ? ?}
? ? ?// 如果已經(jīng)有該值,則無須插入,什么都不動
? ? ?else {

? ? ?}
? ? ?// 返回根結(jié)點
? ? ?return root;
?}

刪除

步驟

  • 按照二叉搜索樹的特點,先找到對應(yīng)的節(jié)點
  • 若該結(jié)點為葉子結(jié)點,則直接刪除,若該結(jié)點為非葉子節(jié)點, 則進行相應(yīng)的旋轉(zhuǎn),直到該結(jié)點為葉子節(jié)點,然后進行刪除
?//刪除、
// ? ? 1.根據(jù)二叉搜索樹的性質(zhì)找到相應(yīng)的結(jié)點
// ? ? 2.若該結(jié)點為葉子結(jié)點,則直接刪除,若該結(jié)點為非葉子節(jié)點,
// ? ? ? 則進行相應(yīng)的旋轉(zhuǎn),直到該結(jié)點為葉子節(jié)點,然后進行刪除。
public TreeNode delete(int value, TreeNode root) {
? ? // 當(dāng)樹不為空才進行刪除
? ? if (root != null) {
? ? ? ? // 先進行查找
? ? ? ? // 往左找
? ? ? ? if (root.value > value) {
? ? ? ? ? ? // 因為可能找到了后會進行左旋右旋,
? ? ? ? ? ? // 所以其實左子結(jié)點會改變
? ? ? ? ? ? root.left = delete(value, root.left);
? ? ? ? }
? ? ? ? // 往右找
? ? ? ? else if (root.value < value) {
? ? ? ? ? ? root.right = delete(value, root.right);
? ? ? ? }
? ? ? ? //找到了
? ? ? ? else {
? ? ? ? ? ? // 首先找到這里,root已經(jīng)變?yōu)槟繕?biāo)結(jié)點,如果root是葉子結(jié)點刪去即可
? ? ? ? ? ? if (root.left == null && root.right == null) {
? ? ? ? ? ? ? ? // 返回當(dāng)前節(jié)點,即刪除后的樣子 null
? ? ? ? ? ? ? ? // 會遞歸到其父節(jié)點的root.right = delete(value, root.right);
? ? ? ? ? ? ? ? // 即指向了root.right = null 或 root.left = null,即刪除了我們要刪除的節(jié)點
? ? ? ? ? ? ? ? return null;
? ? ? ? ? ? } else if (root.left != null && root.right != null) {
? ? ? ? ? ? ? ? // 如果root左右子結(jié)點健在
? ? ? ? ? ? ? ? // 此時就是想把目標(biāo)結(jié)點旋轉(zhuǎn)到底層去,
? ? ? ? ? ? ? ? // 然后需要選擇一個優(yōu)先級值比較小的結(jié)點放在目標(biāo)結(jié)點位置
? ? ? ? ? ? ? ? // 如果左子結(jié)點優(yōu)先級較小
? ? ? ? ? ? ? ? if (root.left.priority < root.right. priority) {
? ? ? ? ? ? ? ? ? ? // 旋轉(zhuǎn)root已經(jīng)變?yōu)樽笞咏Y(jié)點,原來的根結(jié)點變?yōu)橛易庸?jié)點
? ? ? ? ? ? ? ? ? ? root = rightRotate(root);
? ? ? ? ? ? ? ? ? ? // 去找那被換下去的節(jié)點,將它刪除掉
? ? ? ? ? ? ? ? ? ? root.right = delete(value, root.right);
? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? root = leftRotate(root);
? ? ? ? ? ? ? ? ? ? // 去找那被換下去的節(jié)點,將它刪除掉
? ? ? ? ? ? ? ? ? ? root.left = delete(value, root.left);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? ? ?else if (root.left != null) {
? ? ? ? ? ? ? ? // 沒有右子節(jié)點,只能右旋了
? ? ? ? ? ? ? ? root = rightRotate(root);
? ? ? ? ? ? ? ? // 去找那被換下去的節(jié)點,將它刪除掉
? ? ? ? ? ? ? ? root.right = delete(value, root.right);
? ? ? ? ? ? }

? ? ? ? ? ? else if (root.right != null) {
? ? ? ? ? ? ? ? // 沒有左子節(jié)點,只能左旋了
? ? ? ? ? ? ? ? root = leftRotate(root);
? ? ? ? ? ? ? ? // 去找那被換下去的節(jié)點,將它刪除掉
? ? ? ? ? ? ? ? root.left = delete(value, root.left);
? ? ? ? ? ? }
? ? ? ? }
? ? }

? ? return root;
}

完整代碼

public class Treap {
? ? // 優(yōu)先級隨機數(shù)發(fā)生器
? ? private static final Random random = new Random();

? ? //增加
// ?1.按照二叉查找樹的插入方式,將節(jié)點插入到樹葉中
// ?2.再根據(jù)priority優(yōu)先級的小頂堆性質(zhì)進行左旋右旋
? ? public TreeNode insert(int value, TreeNode root) {
? ? ? ? // 如果父節(jié)點為空,則創(chuàng)建一個父節(jié)點并返回
? ? ? ? // 第一次父節(jié)點為根節(jié)點
? ? ? ? if (root == null) {
? ? ? ? ? ? return new TreeNode(value, random.nextInt());
? ? ? ? }

? ? ? ? // 如果要根節(jié)點的值大于要插入結(jié)點的值,則應(yīng)該插入到根節(jié)點的左邊
? ? ? ? if (root.value > value) {
? ? ? ? ? ? // 遞歸進行插入,一直遞歸到葉子節(jié)點才會插入
? ? ? ? ? ? // 如果遞歸到一個相等的節(jié)點,則不會創(chuàng)建一個新節(jié)點,會直接返回
? ? ? ? ? ? root.left = insert(value, root.left);

? ? ? ? ? ? // 插入完成后,根據(jù)堆的優(yōu)先級進行旋轉(zhuǎn)操作
? ? ? ? ? ? // 左子結(jié)點的優(yōu)先級值小于根結(jié)點的優(yōu)先級,
? ? ? ? ? ? // 根據(jù)小頂堆的規(guī)則,需要進行右旋操作
? ? ? ? ? ? if (root.left.priority < root.priority) {
? ? ? ? ? ? ? ? // 傳入root根結(jié)點,返回的是左子結(jié)點,
? ? ? ? ? ? ? ? // 但此時左子結(jié)點已經(jīng)旋轉(zhuǎn)成為根結(jié)點所以賦值給根結(jié)點
? ? ? ? ? ? ? ? root = rightRotate(root);
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? // 如果根節(jié)點的值小于要插入結(jié)點的值大于,則應(yīng)該插入到根節(jié)點的右邊
? ? ? ? else if (root.value < value) {
? ? ? ? ? ? // 遞歸插入
? ? ? ? ? ? root.right = insert(value, root.right);
? ? ? ? ? ? // 右子結(jié)點的優(yōu)先級值小于根結(jié)點的優(yōu)先級,
? ? ? ? ? ? // 根據(jù)小頂堆的規(guī)則,需要進行左旋操作
? ? ? ? ? ? if (root.right.priority < root.priority) {
? ? ? ? ? ? ? ? root = leftRotate(root);
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? // 如果已經(jīng)有該值,則無須插入,什么都不動
? ? ? ? else {

? ? ? ? }
? ? ? ? // 返回根結(jié)點
? ? ? ? return root;
? ? }

? ? //刪除、
// ? ? 1.根據(jù)二叉搜索樹的性質(zhì)找到相應(yīng)的結(jié)點
// ? ? 2.若該結(jié)點為葉子結(jié)點,則直接刪除,若該結(jié)點為非葉子節(jié)點,
// ? ? ? 則進行相應(yīng)的旋轉(zhuǎn),直到該結(jié)點為葉子節(jié)點,然后進行刪除。
? ? public TreeNode delete(int value, TreeNode root) {
? ? ? ? // 當(dāng)樹不為空才進行刪除
? ? ? ? if (root != null) {
? ? ? ? ? ? // 先進行查找
? ? ? ? ? ? // 往左找
? ? ? ? ? ? if (root.value > value) {
? ? ? ? ? ? ? ? // 因為可能找到了后會進行左旋右旋,
? ? ? ? ? ? ? ? // 所以其實左子結(jié)點會改變
? ? ? ? ? ? ? ? root.left = delete(value, root.left);
? ? ? ? ? ? }
? ? ? ? ? ? // 往右找
? ? ? ? ? ? else if (root.value < value) {
? ? ? ? ? ? ? ? root.right = delete(value, root.right);
? ? ? ? ? ? }
? ? ? ? ? ? //找到了
? ? ? ? ? ? else {
? ? ? ? ? ? ? ? // 首先找到這里,root已經(jīng)變?yōu)槟繕?biāo)結(jié)點,如果root是葉子結(jié)點刪去即可
? ? ? ? ? ? ? ? if (root.left == null && root.right == null) {
? ? ? ? ? ? ? ? ? ? // 返回當(dāng)前節(jié)點,即刪除后的樣子 null
? ? ? ? ? ? ? ? ? ? // 會遞歸到其父節(jié)點的root.right = delete(value, root.right);
? ? ? ? ? ? ? ? ? ? // 即指向了root.right = null 或 root.left = null,即刪除了我們要刪除的節(jié)點
? ? ? ? ? ? ? ? ? ? return null;
? ? ? ? ? ? ? ? } else if (root.left != null && root.right != null) {
? ? ? ? ? ? ? ? ? ? // 如果root左右子結(jié)點健在
? ? ? ? ? ? ? ? ? ? // 此時就是想把目標(biāo)結(jié)點旋轉(zhuǎn)到底層去,
? ? ? ? ? ? ? ? ? ? // 然后需要選擇一個優(yōu)先級值比較小的結(jié)點放在目標(biāo)結(jié)點位置
? ? ? ? ? ? ? ? ? ? // 如果左子結(jié)點優(yōu)先級較小
? ? ? ? ? ? ? ? ? ? if (root.left.priority < root.right. priority) {
? ? ? ? ? ? ? ? ? ? ? ? // 旋轉(zhuǎn)root已經(jīng)變?yōu)樽笞咏Y(jié)點,原來的根結(jié)點變?yōu)橛易庸?jié)點
? ? ? ? ? ? ? ? ? ? ? ? root = rightRotate(root);
? ? ? ? ? ? ? ? ? ? ? ? // 去找那被換下去的節(jié)點,將它刪除掉
? ? ? ? ? ? ? ? ? ? ? ? root.right = delete(value, root.right);
? ? ? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? ? ? root = leftRotate(root);
? ? ? ? ? ? ? ? ? ? ? ? // 去找那被換下去的節(jié)點,將它刪除掉
? ? ? ? ? ? ? ? ? ? ? ? root.left = delete(value, root.left);
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ?else if (root.left != null) {
? ? ? ? ? ? ? ? ? ? // 沒有右子節(jié)點,只能右旋了
? ? ? ? ? ? ? ? ? ? root = rightRotate(root);
? ? ? ? ? ? ? ? ? ? // 去找那被換下去的節(jié)點,將它刪除掉
? ? ? ? ? ? ? ? ? ? root.right = delete(value, root.right);
? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? else if (root.right != null) {
? ? ? ? ? ? ? ? ? ? // 沒有左子節(jié)點,只能左旋了
? ? ? ? ? ? ? ? ? ? root = leftRotate(root);
? ? ? ? ? ? ? ? ? ? // 去找那被換下去的節(jié)點,將它刪除掉
? ? ? ? ? ? ? ? ? ? root.left = delete(value, root.left);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? }

? ? ? ? return root;
? ? }

? ? // 查詢
? ? // 根據(jù)二叉搜索樹性質(zhì)查詢
? ? public TreeNode query(TreeNode root, int value) {
? ? ? ? //這里的root才是真root,上面的方法只是局部變量
? ? ? ? //所以不能在查詢中改變根節(jié)點
? ? ? ? TreeNode temp = root;
? ? ? ? while (temp != null) {
? ? ? ? ? ? if (temp.value > value) {
? ? ? ? ? ? ? ? temp = temp.left;
? ? ? ? ? ? } else if (temp.value < value) {
? ? ? ? ? ? ? ? temp = temp.right;
? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? return temp;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? return null;
? ? }

? ? // 右旋,左子節(jié)點右旋
? ? public TreeNode rightRotate(TreeNode treeNode) {
? ? ? ? // temp為左子結(jié)點
? ? ? ? TreeNode temp = treeNode.left;
? ? ? ? //將父結(jié)點的左邊指向 temp的右子結(jié)點
? ? ? ? treeNode.left = temp.right;
? ? ? ? // 將temp結(jié)點的右邊指向父結(jié)點
? ? ? ? temp.right = treeNode;
? ? ? ? // 進行上面兩步操作,在紙上畫一下就找到其右旋成功了,
? ? ? ? // 即左子結(jié)點變?yōu)楦Y(jié)點了

? ? ? ? // 返回此時旋轉(zhuǎn)后的真正根結(jié)點
? ? ? ? return temp;
? ? }

? ? // 左旋,右子結(jié)點左旋
? ? public TreeNode leftRotate(TreeNode treeNode) {
? ? ? ? // temp為右子結(jié)點
? ? ? ? TreeNode temp = treeNode.right;
? ? ? ? //將父結(jié)點的右邊指向 temp的左子結(jié)點
? ? ? ? treeNode.right = temp.left;
? ? ? ? // 將temp結(jié)點的左邊指向父結(jié)點
? ? ? ? temp.left = treeNode;
? ? ? ? // 進行上面兩步操作,在紙上畫一下就找到其左旋成功了,
? ? ? ? // 即右子結(jié)點變?yōu)楦Y(jié)點了

? ? ? ? // 返回此時旋轉(zhuǎn)后的真正根結(jié)點
? ? ? ? return temp;
? ? }

? ? public void printTree(TreeNode root) {
? ? ? ? if (root != null) {
? ? ? ? ? ? printTree(root.left);
? ? ? ? ? ? System.out.println(root.value);
? ? ? ? ? ? printTree(root.right);
? ? ? ? }
? ? }

? ? public static void main(String[] args) {
? ? ? ? Treap treap = new Treap();
? ? ? ? TreeNode root = null;
? ? ? ? root = treap.insert(1, root);
? ? ? ? root = treap.insert(2, root);
? ? ? ? root = treap.insert(3, root);
? ? ? ? root = treap.insert(4, root);
? ? ? ? root = treap.insert(5, root);
? ? ? ? root = treap.insert(6, root);

? ? ? ? //中序遍歷,如果打印的值由小到大,說明滿足二叉搜索樹特征
? ? ? ? treap.printTree(root);

? ? ? ? System.out.println();

? ? ? ? // 測試查詢
? ? ? ? TreeNode query = treap.query(root, 1);
? ? ? ? System.out.println(query.value);
? ? ? ? query = treap.query(root, 2);
? ? ? ? System.out.println(query.value);
? ? ? ? query = treap.query(root, 3);
? ? ? ? System.out.println(query.value);
? ? ? ? query = treap.query(root, 4);
? ? ? ? System.out.println(query.value);
? ? ? ? query = treap.query(root, 5);
? ? ? ? System.out.println(query.value);
? ? ? ? query = treap.query(root, 6);
? ? ? ? System.out.println(query.value);
? ? ? ? query = treap.query(root, 7);
? ? ? ? System.out.println(query);

? ? ? ? System.out.println();
? ? ? ? // 測試刪除
? ? ? ? root = treap.delete(2,root);
? ? ? ? root = treap.delete(3,root);
? ? ? ? root = treap.delete(5,root);
? ? ? ? root = treap.delete(7,root);
? ? ? ? treap.printTree(root);

? ? }
}


class TreeNode {
? ? int value;
? ? int priority;
? ? TreeNode left;
? ? TreeNode right;

? ? public TreeNode(int value, int priority) {
? ? ? ? this.value = value;
? ? ? ? this.priority = priority;
? ? }
}

到此這篇關(guān)于Java實現(xiàn)Treap樹的示例代碼的文章就介紹到這了,更多相關(guān)Java Treap樹內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mybatis foreach遍歷LIST讀到數(shù)據(jù)為null的問題

    mybatis foreach遍歷LIST讀到數(shù)據(jù)為null的問題

    這篇文章主要介紹了mybatis foreach遍歷LIST讀到數(shù)據(jù)為null的問題,具有很好的參考價值,希望對大家有所幫助。
    2022-02-02
  • java實現(xiàn)單鏈表、雙向鏈表

    java實現(xiàn)單鏈表、雙向鏈表

    這篇文章主要為大家詳細介紹了java實現(xiàn)單鏈表、雙向鏈表的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-03-03
  • 詳解SpringMVC使用MultipartFile實現(xiàn)文件的上傳

    詳解SpringMVC使用MultipartFile實現(xiàn)文件的上傳

    本篇文章主要介紹了SpringMVC使用MultipartFile實現(xiàn)文件的上傳,本地的文件上傳到資源服務(wù)器上,比較好的辦法就是通過ftp上傳。這里是結(jié)合SpringMVC+ftp的形式上傳的,有興趣的可以了解一下。
    2016-12-12
  • 解決mybatis批量更新出現(xiàn)SQL報錯問題

    解決mybatis批量更新出現(xiàn)SQL報錯問題

    這篇文章主要介紹了mybatis批量更新出現(xiàn)SQL報錯,解決辦法也很簡單只需要在application.properties配置文中的數(shù)據(jù)源url后面添加一個參數(shù),需要的朋友可以參考下
    2022-02-02
  • Spring中@Transactional用法詳細介紹

    Spring中@Transactional用法詳細介紹

    這篇文章主要介紹了Spring中@Transactional用法詳細介紹的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • Java使用POI實現(xiàn)excel文件的導(dǎo)入和導(dǎo)出

    Java使用POI實現(xiàn)excel文件的導(dǎo)入和導(dǎo)出

    這篇文章主要為大家詳細介紹了Java如何使用POI實現(xiàn)excel文件的導(dǎo)入和導(dǎo)出功能,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • idea更改項目(模塊)JDK版本的操作步驟

    idea更改項目(模塊)JDK版本的操作步驟

    idea很多地方都設(shè)置了jdk版本,不同模塊的jdk版本也可能不一樣,下面這篇文章主要給大家介紹了關(guān)于idea更改項目(模塊)JDK版本的操作步驟,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-11-11
  • java中的AWT事件處理問題

    java中的AWT事件處理問題

    這篇文章主要介紹了java中的AWT事件處理問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 迅速學(xué)會@ConfigurationProperties的使用操作

    迅速學(xué)會@ConfigurationProperties的使用操作

    這篇文章主要介紹了迅速學(xué)會@ConfigurationProperties的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • SpringBoot2.x 整合 AntiSamy防御XSS攻擊的簡單總結(jié)

    SpringBoot2.x 整合 AntiSamy防御XSS攻擊的簡單總結(jié)

    本文主要對SpringBoot2.x集成AntiSamy防御XSS攻擊進行簡單總結(jié),其中SpringBoot使用的2.4.5版本,通過示例代碼給大家介紹的非常詳細,需要的朋友參考下吧
    2021-08-08

最新評論