返回地址【數據結構】

小問題?
1.我們是如何根據地址值來找到我們對應的數據的?
詳細陳述一下:當我們開辟一個整數類型,取名為a,假設地址空間是從數值為2000進行存儲,并且我們假設整形占用4個字節,那么我們在內存中需要的空間就是2000~2003,共4個字節,同時我們定義一個整形的指針為p,p存儲的地址就是a的地址,我們寫作是int p;p=&a;就相當于是p==2000,這如何來確定地址空間當中所存的具體數值呢?我們用int 2000來進行確定的,我們開始假設的是整形占用4個字節,并且起始地址是從2000開始的,那么我們的計算機從2000開始連續讀取4個字節就會得到我們想要的數據,由此可見,我們的真實數據是有數據類型以及開始的首地址來進行存儲的
2.我們都知道數組名代表了元素的首地址,那么我們來進行數組的使用規則進行理解一下,int[]a={};int
p=a;p==2000;
(p+1)==a[1]
我們來仔細的談一談此時的加1操作,這里就與數據的基類型是有關的,加1就是加一個基類型的字節數,同樣我們返回的值為某個元素的第一個首地址,不會返回整個字節數地址
在這里插入圖片描述
在使用malloc和realloc以及free的時候一定是要有前面的有文件的,也就是<stdlib.h>
也要知道宏定義,Init_size代表的是初始的大小,也就是一開始我們需要開辟的空間大小,這里有一個要求,初始的空間不能太大,也不能太小,太大了會比較浪費,太小了就需要后期的擴充函數,而一旦使用到后期的擴充函數就會涉及到兩個問題,第一就是申請成功,第二就是申請不成功,然后再轉向其他的倉庫進行,會比較浪費時間,最好就是不用后期的擴充函數,一次到位,如果我們能夠找到一種方法,能確定最初所要申請空間的大小,那么我們就不用后期的擴充函數,從而避免了時間的浪費,但是這個問題是否就能夠由我們來解決呢?有待考察,而Increace_size代表的是申請空間的時候每次申請的內存空間我們進行的大小的定義,是由我們自己進行定義的,與系統是沒有關系的,是由relloc進行決定的,
小插曲:
1.Elem就是所有數據類型的一個抽象概括
2.數組當中的數值,開始申請了一個空間大小,使用的函數可以是動態函數malloc函數,
3.int
a就是代表著指針類型的變量起名為a,沒有實際的內存空間,我們必須用函數malIoc來進行空間的開辟,
4.有了指針類型的地址,我們就要聯想到他是否有真正的內存空間,如果沒有,那么我們就要進行malooc函數來進行空間的開辟
在這里插入圖片描述
當我們申請空間的時候,只是申請了一個內存地址,也就是elem*的值被賦予定義,就相當于我們有了一個倉庫,找到了我們接下來做事情的一個地方,但是此時倉庫是空的,也就是數據為0個,沒有元素,而此時的sIze就是指倉庫的大小,Len為存了多少個元素初始值為0,也就是沒有參與元素,而下面的size是倉庫的大小,我們看一下判斷條件,如果地址空間為空,圖上顯示的是為null時,就是開辟空間失敗,是硬件的問題,

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/444110.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/444110.shtml
英文地址,請注明出處:http://en.pswp.cn/news/444110.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【超級詳細的小白教程】Hexo 搭建自己的博客

– 前言 這是一篇有關如何使用 Github Pages 和 Hexo 搭建屬于自己獨立博客的詳盡教程&#xff0c;本人是軟件工程專業本科生&#xff0c;目前只學習了C和C編程語言&#xff0c;對網站開發的有關知識幾乎為零&#xff0c;這也是我搭建好自己的博客之后寫的第一篇博客&#xff…

面向對象思想精華總結

一、三大特性 封裝繼承多態 二、類圖 泛化關系 (Generalization)實現關系 (Realization)聚合關系 (Aggregation)組合關系 (Composition)關聯關系 (Association)依賴關系 (Dependency) 三、設計原則 S.O.L.I.D其他常見原則 參考資料 一、三大特性 封裝 利用抽象數據類型將數據…

數組名與指向數組的指針之間的聯系與區別【數據結構】

我們遇到一個非常棘手的問題&#xff0c;這個問題就是&#xff0c;對于一堆數據來說&#xff0c;我們進行存儲&#xff0c;放到一個指定的倉庫當中&#xff0c;先前我們使用數組加加標的形式進行訪問倉庫當中的元素位置&#xff0c;但是呢&#xff0c;現在我們使用的是一個指針…

Struts2的action中處理JSONP方式提交的中文亂碼問題:

昨天在做公司網站的時候出現了一個中文亂碼問題&#xff0c;讓我郁悶了一晚上和一上午&#xff0c;最后在網友的提示下&#xff0c;我終于解決了&#xff0c;現在寫出來供后來的兄弟們參考&#xff1a; 1.問題是這樣的&#xff0c;就是客戶端是以JSONP的方式提交的數據&#x…

leetcode509. 斐波那契數(矩陣快速冪)

斐波那契數&#xff0c;通常用 F(n) 表示&#xff0c;形成的序列稱為斐波那契數列。該數列由 0 和 1 開始&#xff0c;后面的每一項數字都是前面兩項數字的和。也就是&#xff1a; F(0) 0, F(1) 1 F(N) F(N - 1) F(N - 2), 其中 N > 1. 給定 N&#xff0c;計算 F(N)。…

insert函數的修改,

我們來看一下圖片當中的第2個圓圈&#xff0c;為什么使用size來相加呢&#xff1f;我們知道一開始我們定義的初始空間為init_size;我們想一下啊&#xff0c;如果是第1次進行空間的增加&#xff0c;那么我們使用InIt來進行相加是可以的&#xff0c;但是當第2次想加我們再想開辟空…

leetcode520. py解字符串真是太殘暴了

給定一個單詞&#xff0c;你需要判斷單詞的大寫使用是否正確。 我們定義&#xff0c;在以下情況時&#xff0c;單詞的大寫用法是正確的&#xff1a; 全部字母都是大寫&#xff0c;比如"USA"。 單詞中所有字母都不是大寫&#xff0c;比如"leetcode"。 如果…

【數據結構】線性表大咖

循環鏈表的介紹 概念&#xff1a;鏈表的最后一個節點的指針&#xff0c;由原來的 空指針變成指向第1個節點的鏈表。 類比&#xff1a;我們進行串珠子的操作&#xff0c;將首尾通過線進行連接&#xff0c;同樣我們的鏈表就是通過指針指向的方式進行連接&#xff0c;使其成為一…

leetcode551. 學生出勤記錄 I

給定一個字符串來代表一個學生的出勤記錄&#xff0c;這個記錄僅包含以下三個字符&#xff1a; A : Absent&#xff0c;缺勤 L : Late&#xff0c;遲到 P : Present&#xff0c;到場 如果一個學生的出勤記錄中不超過一個A(缺勤)并且不超過兩個連續的L(遲到),那么這個學生會被獎…

一元多項式的表示和相加【數據結構】

一元多項式的表示和相加 運算只是一個定義&#xff0c;一切的一切&#xff0c;到最后都必須歸咎于存儲結構當中&#xff0c;實現物理存儲&#xff0c;一元多項式包括數據對象數據關系以及數據之間的各種操作&#xff0c; 一元多項式的實現&#xff1a;用帶表頭結點的有序鏈表…

線性結構基本概念【數據結構】F

線性表的概念&#xff1a;線性表是一種最簡單的線性結構&#xff0c;線性結構是單個數據元素的有序結合 線性結構的基本特征為&#xff1a; 第一&#xff0c;集合中必存在唯一的一個第1元素&#xff0c; 第二&#xff0c;集合中必存在唯一的一個最后元素&#xff0c; 第三&am…

leetcode589. N叉樹的前序遍歷

給定一個 N 叉樹&#xff0c;返回其節點值的前序遍歷。 例如&#xff0c;給定一個 3叉樹 : 返回其前序遍歷: [1,3,5,6,2,4]。 思路&#xff1a;先放入自己&#xff0c;再依次遍歷孩子。 /* // Definition for a Node. class Node {public int val;public List<Node> c…

ORA-00001 違反唯一約束條件

程序跑出下面的異常&#xff1a;com.ibm.websphere.ce.cm.DuplicateKeyException: ORA-00001: 違反唯一約束條件 (EOMS3.SYS_C0024492)&#xff0c;參考下面的文章了解到我的程序可能是序列的問題。&#xff08;果然是序列產生的最小值設置的太小&#xff0c;將序列值設置大之后…

順序結構實現【數據結構】

雖然在數據結構當中是先出現的線性表&#xff0c;然后出現的是數組 一&#xff1a;線性表的順序存儲結構 順序映象&#xff1a;用一組地址連續的存儲單元依次存放線性表當中的數據元素 線性表的起始地址&#xff1a;線性存儲第一個數據元素的地址&#xff0c;我們也稱作是基地址…

leetcode590. N叉樹的后序遍歷

給定一個 N 叉樹&#xff0c;返回其節點值的后序遍歷。 例如&#xff0c;給定一個 3叉樹 : 思路&#xff1a;先遍歷所有孩子&#xff0c;再放入自己。 /* // Definition for a Node. class Node {public int val;public List<Node> children;public Node() {}public No…

鏈表的形式【F】

數據元素之間的關系在計算機中有兩種表示方法: 順序映象, 非順序映象. 對應兩種存儲結構: 順序存儲結構, 鏈式存儲結構 線性結構就是一種邏輯關系&#xff0c;方便我們對數據進行研究但是不考慮真實的存儲結構 數據是什么&#xff1f; 數據是能夠反應一定內容的一組數據類型的…

leetcode892. 三維形體的表面積

在 N * N 的網格上&#xff0c;我們放置一些 1 * 1 * 1 的立方體。 每個值 v grid[i][j] 表示 v 個正方體疊放在對應單元格 (i, j) 上。 請你返回最終形體的表面積。 示例 1&#xff1a; 輸入&#xff1a;[[2]] 輸出&#xff1a;10 示例 2&#xff1a; 輸入&#xff1a;…

leetcode914. 卡牌分組

給定一副牌&#xff0c;每張牌上都寫著一個整數。 此時&#xff0c;你需要選定一個數字 X&#xff0c;使我們可以將整副牌按下述規則分成 1 組或更多組&#xff1a; 每組都有 X 張牌。 組內所有的牌上都寫著相同的整數。 僅當你可選的 X > 2 時返回 true。 示例 1&#xf…

單鏈表的實現【數據結構】

思考&#xff1a; 1.是否能夠將原來指針的方向改為向前指向呢&#xff1f; 2.是否能夠有兩個指針域的操作呢&#xff1f; 了解&#xff1a; 單鏈表是應用最廣泛的一種形式&#xff0c;還有雙向鏈表以及循環鏈表&#xff0c;這些都是要進行討論的 結構體定義的是什么&#xff1f…

(詳細圖解)VS2017安裝教程

VS 2017 版本同 15 版一樣&#xff0c;細分為三個版本&#xff0c;分別是&#xff1a; 社區版&#xff08;Community&#xff09;&#xff1a;免費提供給單個開發人員&#xff0c;給予初學者及大部分程序員支持&#xff0c;可以無任何經濟負擔、合法地使用。企業版&#xff1a…