主頁 >  其他 > 記,在公司內部做的關于MySQL索引的分享

記,在公司內部做的關于MySQL索引的分享

2020-10-23 02:16:46 其他

這一篇是講解Mysql中做使用到的「索引的種類」「索引正確使用的原則」「怎么優化索引」「以及兩種存盤引擎InnoDB和MyISAM索引的資料布局原理」
索引種類

在說索引之前,我們先來說一說什么是索引呢?對于索引個人的理解就是,索引是一種加快查詢資料的資料結構,

所以,索引就是一種資料結構,作用就是發揮這種資料結構的作用,加快查詢的效率,例如:InnoDB存盤引擎中使用的是就是B+tree這種資料結構來組織索引,

Mysql中索引的種類也不是很多,不同型別的索引有不同的作用,索引的作用相互之間也存在交叉關系,Mysql中索引主要分為以下幾類:

  1. 「主鍵索引」(PRIMARY KEY):主鍵索引一般都是在創建表的時候指定,「一個表只有一個主鍵索引」,特點是「唯一、非空」
  2. 「唯一索引」(UNIQUE):唯一索引具有的特點就是唯一性,可以在創建表的時候指定,也可以在創建表后創建,
  3. 「普通索引」(INDEX):普通索引唯一的作用就是加快查詢,
  4. 「組合索引」( INDEX):組合索引是創建一個「多個欄位的索引」,這個概念是相對于上上面的單列索引而言,組合索引查詢遵循「最左前綴原則」
  5. 「全文索引」(FULLTEXT):全文索引是針對一些大的「文本欄位」創建的索引,也稱為「全文檢索」
  6. 「聚簇索引」「非聚簇索引」:聚簇索引和非聚簇索引的概念比上面的概念要大,屬于包含和被包含的關系,例如:InnoDB中主鍵索引使用的就是聚簇索引,

若是你想查看一個表的所有索引,可以執行下面的sql來查看:

show index from 表名

例如,查看我自己的測驗表里面的索引,如下圖所示,Key_name表示索引的名字,Column_name表示索引的欄位,

在公司內部做的關于MySQL索引的分享,總監說我是專家級的…

上面大概的說了主要索引的概念,下面詳細的介紹一下這幾大索引的特點和使用,

主鍵索引

主鍵索引在InnoDB存盤引擎中是最常見的索引型別,一個表都會有一個主鍵索引,它索引的欄位不允許為空值,并且唯一,

一般是在創建表的時候,可以通過RIMARY KEY指定主鍵索引,在InnoDB存盤引擎中,若是創建表的時候沒有主觀創建主鍵索引,Mysql就會看表中是否有唯一索引,有,就會指定「非空的唯一索引」為主鍵索引;

沒有,就會默認生成一個6byte空間的自動增長主鍵作為主鍵索引,可以通過select _rowid from 表名查詢的是對應的主鍵值.,

MyISAM儲存引擎是可以不存在主鍵索引,MyISAM和InnoDB儲存資料的結構方式還是有明顯的區別,這個后面篇章會詳細講解,

唯一索引

唯一索引與主鍵索引的區別就是,唯一索引允許為空,若是在組合索引中,只要創建的列值是唯一的

唯一索引在實際中更多的是用來保證資料的唯一性,假如你僅僅要資料能夠快速查詢,你也可以使用普通索引,所以唯一索引重在體現它的唯一性,

實際的業務場景,有些目標欄位要求唯一,就可以使用唯一索引,創建唯一索引的方式有三種,

(1)一個是在創建表的時候指定,如下sql:

CREATE TABLE user( 
 id INT PRIMARY KEY NOT NULL, 
 name VARCHAR(16) NOT NULL, 
 UNIQUE unique_name (name(10)) 
);

(2)也可以在表創建后創建,如下sql:

CREATE UNIQUE INDEX unique_name ON user(name(10));

(3)通過修改表結構創建,如下sql:

ALTER user ADD UNIQUE unique_name ON (name(10))

這里有一個細節要注意的是創建的name欄位,指定的長度是16字符,而創建的索引的長度指定的是10字符,因為也沒有人的名字長度會超過10個字符,所以減少索引長度,能夠減少索引所占的空間的大小,

普通索引

普通索引的唯一作用就是加快資料的查詢,一般對查詢陳述句WHERE和ORDER BY后面的欄位創建普通索引,

創建普通索引的方式也有三種,基本和創建唯一索引的方式一樣,只是把關鍵字UNIQUE換成INDEX,如下所示:

// 創建表的時候創建
CREATE TABLE user( 
 id INT PRIMARY KEY NOT NULL, 
 name VARCHAR(16) NOT NULL, 
 INDEX index_name (name(10)) 
);
// 創建表后創建
CREATE INDEX INDEX index_name ON user(name(10));
// 修改表結構創建
ALTER user ADD INDEX index_name ON (name(10))

若是想洗掉索引,可以通過執行下面的sql進行洗掉索引:

DROP INDEX index_name ON user;

組合索引

組合索引即用多個欄位創建一個索引,組合索引能夠避免「回表查詢」,相對于多欄位的單列索引,組合索引的查詢效率更高,

創建組合索引(聯合索引)的方式和上面創建普通索引的方式一樣,只不過欄位的數目多了,如下sql創建:

// 其它方式和上面的一樣,這里就只列舉修改表結構的方式創建
ALTER TABLE employee ADD INDEX name_age_sex (name(10),age,sex);

回表查詢

什么是回表查詢呢?回表查詢簡單來說「通過二級索引查詢資料,得不到完整的資料行,需要再次查詢主鍵索引來獲得資料行」

InnoDB存盤引擎中,索引分為 「聚簇索引」「二級索引」,主鍵索引就是聚簇索引,其它的索引為二級索引,

聚簇索引中的葉子節點保存著完整的資料行,而二級索引的葉子節點并不是保存完整的資料行,

上面提到InnoDB表是一定要有主鍵索引的,雖然索引占據空間,但是索引符合二分查找的演算法,查找資料非常的快,

假設還是上面的employee表,里面有主鍵索引id,和普通的索引name,那么在InnoDB中就會存在兩棵B+Tree,一棵是主鍵索引樹:

在公司內部做的關于MySQL索引的分享,總監說我是專家級的…

主鍵索引樹

在主鍵索引樹中的葉子節點存盤的是完整的資料行,另外一棵是name欄位的二級索引樹,如下圖所示:

在公司內部做的關于MySQL索引的分享,總監說我是專家級的…

倘若你執行這條sql:select name, age, sex from employee where id ='as';就會先執行二級索引的查詢,當查詢name='as'時,得到主鍵為50,再根據主鍵查詢主鍵索引樹,得到完整的資料行,具體的執行流程如下:

在公司內部做的關于MySQL索引的分享,總監說我是專家級的…

回表原理圖

這個就是回表查詢,回表查詢會查詢兩次,這樣就會降低查詢的效率,為了避免回表查詢,只查詢一次就能得到完整的資料呢?

索引覆寫

常見的方式就是「建立組合索引(聯合索引)「進行」索引覆寫」,什么是索引覆寫呢?索引覆寫就是「索引的葉子節點已經包含了查詢的資料,沒必要再回表進行查詢,」

假如我還是執行如下sql:select name, age, sex from employee where name ='as';因為普通索引只有name欄位才建立了索引,這必然會導致回表查詢,

為了提高查詢效率,就(name)「單列索引升級為聯合索引」(name, age, sex)就不同了,

因為建立的聯合索引,在二級節點的葉子階段就會同時存在name, age, sex三個的值,一次性就會獲得所需要的資料,這樣就避免了回表,但是所有的方案都不是完美的,

若是這個聯合索引哪一天某一個資料行的name值改變了或者age改變了,我就需要同時維護主鍵索引和聯合索引兩棵樹,這樣的維護成本就高了,性能開銷也大了,

相比之前資料的改變,我只需要維護主鍵索引即可,聯合索引的創建就導致了需要同時維護兩棵樹,這樣就會影響插入、更新資料的操作,所以并沒有哪種方案是完美的,

最左前綴原則

我們知道單列索引是按照索引列有序性的進行組織B+Tree結構的,聯合索引又是怎么組織B+Tree呢?

聯合索引其實也是按照創建索引的時候,最左邊的進行最開始的排序,也就是「最左前綴原則」,比如一個表中有如下資料:

nameagesexad23男bc21男bc24女bc25男de21女

如上圖所示,對于聯合索引中name欄位是放在最前面的,所以name是完全有序的,但是age欄位就不是有序的,只有當name相同,例如:name='bc'此時age欄位的索引排序才是完全有序的,

所以你會發現,在聯合索引中你只有使用以下的規則的方式查詢才會使用到索引:

  1. name,age,sex
  2. name,age
  3. name

因為Mysql的底層有查詢優化器,會判斷sql執行的時候若是使用全表掃描的效率比使用索引的效率更高,就會使用全表掃描,

假如,我查詢的時候使用age>=23,sex='男';兩個欄位作為查詢條件,但是沒有使用name欄位,因為在name不知情的條件下,對于age是無序的,

對于age>=23條件可能在很多的name不同中都有符合條件的出現,所以就沒有辦法使用索引,這也是索引實作的原因,一定要遵循「查找有序,充分的利用索引的有序性」

假如你是分別在name,age,sex三個欄位中分別建立三個單列索引,就相當于建立三顆索引樹,那么它的查詢效率,比我們使用一棵索引樹查詢效率就可想而知了,

有一種情況即使使用到了最左邊的name欄位也不會使用索引,例如:WHERE name like '%d%';這種like條件的模糊查詢是會使索引失效,

我們可以這樣理解,「查詢字串也是遵循最左前綴原則的」,字串的查詢是對字串里面的字符一個一個的匹配,「若是字串最左邊為%表示一個不確定的字串,那么是沒辦法利用到索引的有序性」

但是若是修改為 :WHERE name like 'd%';就可以使用索引,因為最左邊的字串是確定的,這種稱為「匹配列前綴」

實際業務場景中聯合索引的創建,「我們應該把識別度比較高的欄位放在前面,提高索引的命中率,充分的利用索引」

索引下推

Mysql5.6版本提出了索引下推的原則,「用于查詢優化,主要是用于like關鍵字的查詢的優化」,什么是索引下推呢?

下面通過演示來說明一下它的概念,還是利用原來的employee測驗表,假如我要執行下面的sql進行查詢:SELECT * from user where name like '張%' and age=40;

假如沒有索引下推,執行的程序如下圖所示:

在公司內部做的關于MySQL索引的分享,總監說我是專家級的…

查詢會直接忽略age欄位,將name查詢的張開頭的id=5、id=7的結果回傳給Mysql服務器,再執行兩次的回表查詢,

若是上面的查詢操作使用了索引下推,執行的程序如下:

在公司內部做的關于MySQL索引的分享,總監說我是專家級的…

Mysql會將查詢條件age=40的查詢條件傳遞給存盤引擎,再次過濾掉age=50的資料行,這樣回表的次數就變為了一次,提高了查詢效率,

總結起來索引下推就是在執行sql查詢的時候,會將一部分的索引列的判斷條件傳遞給存盤引擎,由存盤引擎通過判斷是否符合條件,只有符合條件的資料才會回傳給Mysql服務器,

全文索引

全文索引也稱為全文檢索,可以通過以下sql建立全文索引:ALTER TABLE employee ADD FULLTEXT fulltext_name(name);或者CREATE INDEX的方式創建,

全文索引主要是針對CHAR、VARCHAR或TEXT這種文本類的欄位有效,有人說不也可以使用like關鍵字來查詢文本嗎,

普通索引(單列索引)的查詢只能加快欄位內容中最前面的字串的檢索,若是對于多個單詞組成文本的查詢普通索引就無能為力了,

索引一經創建就沒有辦法修改,若是想要修改索引,必須重建,可以使用以下sql來洗掉索引:DROP INDEX fulltext_name ON employee;

聚簇索引和非聚簇索引

聚簇索引和非聚簇索引是相對于存盤引擎的概念,范圍比較大,包含上面所提到的索引型別,

「聚簇索引就是葉子節點中存盤的就是完整的行資料,索引和資料存盤在一起;而非聚簇索引的索引檔案和資料檔案是分開的,所以查詢資料會多一次查詢」

因此聚簇索引的查詢速度會快于非聚簇索引的查詢速度,在Mysql的存盤引擎中,「InnoDB支持聚簇索引,MyISAM不支持聚簇索引,MyISAM支持非聚簇索引」

聚簇索引

下面我們來看看InnoDB中的聚簇索引,前面說到InnoDB都會有一個主鍵,該主鍵就是用于支持聚簇索引,聚簇索引結構圖,大致如下圖所示:

在公司內部做的關于MySQL索引的分享,總監說我是專家級的…

InnoDB中適用于最好的主鍵選擇就是給出一個AUTO_INCREMENT的列作為自增的主鍵,有的人可能會使用UUID作為隨機主鍵,

因為索引要維持有序性,若是使用隨機的主鍵,主鍵的插入需要尋找合適的位置進行放置,這樣維護主鍵索引樹的成本就會變得更高,

相反的,自增主鍵,主鍵都是自增變大,在維護主鍵索引樹的成本就會變得更小,所以應該盡量避免隨機主鍵,

非聚簇索引

MyISAM使用的是非聚簇索引,新插入資料的時候,會按順序的寫入的磁盤中,并且給每一行資料標記一個行號,從小逐漸增大,

在公司內部做的關于MySQL索引的分享,總監說我是專家級的…

當MyISAM創建主鍵索引的時候,形成的主鍵索引樹的結構圖如下圖所示:

在公司內部做的關于MySQL索引的分享,總監說我是專家級的…

在主鍵索引中,資料也是非空且唯一,主鍵索引樹中存盤的是資料行的行號,當查詢資料的時候使用主鍵索引查詢需要查詢到行號,然后通過行號獲取資料,

非主鍵索引和主鍵索引一樣葉子節點也是存盤著行號,唯一的區別就是非主鍵索引不要求非空、唯一,

我們可以通對比圖來對比一下「InnoDB(聚簇索引)」「MyISAM(非聚簇索引)」 的索引資料布局,如下圖所示:

在公司內部做的關于MySQL索引的分享,總監說我是專家級的…

說到這里相信應該大家對于「InnoDB(聚簇索引)」「MyISAM(非聚簇索引)」 有了非常清晰的認識和理解,下面是來說一說索引的優化,這個也是和我們日常開發最密切相關的,

索引原則和優化

要正確的使用索引,就要正確的創建索引,用索引正確的查詢,不要使索引失效,因此索引的設計和優化的原則應該遵循下面的幾個原則:

  1. 索引列不要在運算式中出現,這樣會導致索引失效,如:「SELECT ...... WHERE id+1=5」;
  2. 索引列不要作為函式的引數使用,
  3. 索引列盡量不要使用like關鍵字,如:「SELECT ...... WHERE name like '%d%'」;
  4. 數字型的索引列不要當作字串型別進行條件查詢,如:「SELECT ...... WHERE id = '35'」;
  5. 盡量不要在條件NOT IN、<>、!= 中使用索引,
  6. 在索引列的欄位中不要出現NULL值,NULL值會使索引失效,可以用特殊的字符比如空字串' '或者0來代替NULL值,
  7. 聯合索引的查詢應該遵循最左前綴原則,
  8. 一般對于區別性比較大的欄位建立索引,在聯合索引中區別性比較大(識別度比較高)放在最前面,提高索引的命中率,
  9. 索引的大小要適度,不宜過大,避免索引的冗余,

總結

索引是我們作業經常會使用到的資料查詢方式,正確的使用索引可以大大提高查詢的效率,

  1. 一方面索引減少了索引服務器需要掃描的資料行的數量,將原來的全表掃描,使用特定的資料結構,能夠快速的定位資料行,
  2. 另一方面使用有序的索引,避免了排序,將原來的隨機的IO操作,變成了順序的IO操作,執行有序,

但是索引也不是十全十美的,也有自己的缺點,不正確的使用索引,將會導致索引大量的占據空間,索引并非是越多越好,索引檔案會越發的膨脹,這樣嚴重的影響查詢的性能,

對于插入、更新 、洗掉資料,除了維護資料以外,還要維護索引檔案,這樣也會影響這些操作的性能,但是對于查詢的頻率遠高于更新和插入資料的業務場景,索引是再適合不過了,

以下文章來源于非科班的科班 ,作者黎杜

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/186510.html

標籤:其他

上一篇:請問一下大家怎么對資料框中的元素做切片?

下一篇:《Oracle 入門教程》第 01 篇 專欄介紹

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more