當(dāng)前位置:首頁 > 公眾號精選 > 大魚機器人
[導(dǎo)讀]問題 兩個數(shù)組元素的地址相減得到什么? 我們先看一段代碼: #include int main(void) { int a[]={0,1,2,3,4,5}; printf("&a[0] = %d, &a[2] = %d\n", &a[0], &a[2]); return 0; } 這段代碼以十進(jìn)制

問題

兩個數(shù)組元素的地址相減得到什么?

我們先看一段代碼:

   
  1. #include <stdio.h>



  2. int main(void)

  3. {

  4. int a[]={0,1,2,3,4,5};

  5. printf("&a[0] = %d, &a[2] = %d\n", &a[0], &a[2]);

  6. return 0;

  7. }

這段代碼以十進(jìn)制的形式打印出第0號元素的地址和第2號元素的地址,輸出結(jié)果為:

   
  1. &a[0] = 2686760, &a[2] = 2686768

所以, &a[2]-&a[0]的結(jié)果是8?但是,事實不是這樣的?。∽屛覀儼哑浣Y(jié)果打印出來:

竟然是 2!我們把 &a[5]-&a[2]的結(jié)果輸出來看看有什么規(guī)律:

陷阱

事實證明,兩個數(shù)組元素的地址相減,其值并不是等于兩個地址數(shù)值上的差,而是等于這兩個地址之間內(nèi)存單元的個數(shù)。本例中數(shù)組的類型是 int 類型,并且在 32bit 編譯環(huán)境下編譯,因此這里的內(nèi)存單元的大小是4字節(jié)。所以本例中 &a[2]-&a[0]的值為:

   
  1. (2686768 - 2686760)/4

當(dāng)然,若是低號元素地址減去高號元素地址,得到的結(jié)果是負(fù)數(shù):

網(wǎng)上看到了一篇博客也是印證了這一點:

   
  1. https://blog.csdn.net/harvic880925/article/details/8953854

這是個很容易出錯的問題,需要特別注意!

學(xué)以致用

我們的C語言每日一練(004)中的題目是

尋找數(shù)組元素第一次出現(xiàn)的位置

之前已經(jīng)提供了兩種方法,函數(shù)的返回值都是要尋找的元素的下標(biāo)。這里可以稍微修改一下得到第三種方法,我們的第三種方法返回的是尋找的元素的指針:

   
  1. // 函數(shù)返回找到元素的指針

  2. int *serch(int *arr,// 已知數(shù)表的首元指針

  3. int n, // 數(shù)表中元素個數(shù)

  4. int key) // 要尋找的值

  5. {

  6. int *p;

  7. for (p = arr; p < arr+n; p++)

  8. {

  9. if (*p == key)

  10. {

  11. return p; // 返回找到元素的指針

  12. }

  13. }

  14. return NULL; // 未查找到key

  15. }

完整的驗證代碼為

   
  1. /*******************************************************************************************************

  2. ** 題 目: 同一個數(shù)組中兩個元素的地址相減

  3. ********************************************************************************************************/

  4. #include <stdio.h>



  5. // 函數(shù)返回找到元素的指針

  6. int *serch(int *arr,// 已知數(shù)表的首元指針

  7. int n, // 數(shù)表中元素個數(shù)

  8. int key) // 要尋找的值

  9. {

  10. int *p;

  11. for (p = arr; p < arr+n; p++)

  12. {

  13. if (*p == key)

  14. {

  15. return p; // 返回找到元素的指針

  16. }

  17. }

  18. return NULL; // 未查找到key

  19. }


  20. // 定義一個全局?jǐn)?shù)組

  21. int a[]={5,2,0,13,14,999,666, 55, 66, 88, 1, 5, 9};


  22. // 主函數(shù)

  23. int main(void)

  24. {

  25. int i, key;

  26. int *p_a;


  27. printf("The elements of array a is:\n");

  28. for (i = 0; i < sizeof(a)/sizeof(a[0]); i++)

  29. {

  30. printf(" %d",a[i]);

  31. }

  32. puts("\nPlease input the key number you want to search:");

  33. scanf("%d", &key);

  34. p_a = serch(a, sizeof(a)/sizeof(a[0]), key);

  35. printf("\nThe index of the key number %d in the array is: %d.", key, p_a-a);


  36. return 0;

  37. }


運行結(jié)果:

可見,得到的結(jié)果與我們C語言每日一練(004)中的驗證結(jié)果一樣。

-END-

猜你喜歡

機器人是如何群居生活的?<<戳這里
論嵌入式與單片機,相愛相殺。<<戳這里
做技術(shù)的,聊聊研發(fā)。 <<戳這里

 最 后   
 

若覺得文章不錯,轉(zhuǎn)發(fā)分享,也是我們繼續(xù)更新的動力。
5T資源大放送!包括但不限于:C/C++,Linux,Python,Java,PHP,人工智能,PCB、FPGA、DSP、labview、單片機、等等!
在公眾號內(nèi)回復(fù)「 更多資源 」,即可免費獲取,期待你的關(guān)注~
長按識別圖中二維碼關(guān)注 

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉