指針的加法操作我們見過很多,但是減法操作遇到的好像很少。
有這么一個筆試題:
inta[]={1,2, 3}; int *p1 = &a[0]; int *p2 = &a[2]; printf("%ld ", p2 - p1);一個數組,兩個指針,指針p1指向數組第一個元素,指針p2指向數組第三個元素,問p2-p1的結果是多少?
我覺得答案應該分兩種,8或者2。
結果8是因為一個整數占了4個字節,兩個整數當然是8個字節。
結果2是因為他們相差了兩個元素。
下面還是敲代碼試一下,直接用printf輸出結果,選擇%ld作為輸出格式。
root@Turbo:test# ./test 2 root@Turbo:test#結果是2。
所以相同類型指針做減法操作的時候,結果還是元素的個數。
就好像p1+2加的是8個字節而不是2個字節一樣。
最后,給大家留個問題,如果希望printf輸出的結果是8,那代碼應該怎么修改?
答案:
對指針進行強制類型轉換,可以轉換成整型或者字符型指針。
printf("%lu ", (int)p2 - (int)p1); printf("%lu ", (char *)p2 - (char *)p1);
審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
字符
+關注
關注
0文章
233瀏覽量
25227 -
指針
+關注
關注
1文章
480瀏覽量
70582 -
代碼
+關注
關注
30文章
4803瀏覽量
68750 -
數組
+關注
關注
1文章
417瀏覽量
25980
原文標題:指針減法
文章出處:【微信號:學益得智能硬件,微信公眾號:學益得智能硬件】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
指針變量的基本操作
指針變量也是一個變量,對應一塊內存空間,對應一個內存地址,指針名就是己址。這空內存空間多大?一個機器字長(machine word),32位的CPU和操作系統就是32個位,4個字節,其值域為
發表于 10-26 09:56
?430次閱讀
C語言:指針運算
元素的位置,以此類推。把一個指針減去3使它向左移動3個元素的位置。要注意的是,如果進行完加法或者減法運算后,指針指向的位置不在數組的范圍內,則發生了數組越界。對這個指針執行間接訪問,即
發表于 01-11 15:11
【原創】聊一聊內存指針操作
中,各種處理器都有對內存的不同的尋址方式讀寫內存。在高級語言中,C語言是唯一可以進行內存操作的語言,C語言對內存的操作主要需要通過指針來完成。1、使用指針
發表于 07-28 09:10
C語言入門教程-指向指針的指針
指向指針的指針
創建一個指針,使它指向另一個指針,這是可能的,而且常常也是必要的。這一技術有時被稱為句柄。在某些情況下,操作系統需要有自主
發表于 07-29 12:10
?1099次閱讀
補碼加法,補碼加法計算原理
補碼加法,補碼加法計算原理 負數用補碼表示后,可以和正數一樣來處理。這樣,運算器里只需要一個加法器就可以了,不必為了負數的加法運算,再配一個減
發表于 04-13 11:41
?1.8w次閱讀
為什么使用指針?C++中的“指針”
為什么使用指針?因為在操作大型數據和類時,指針可以通過內存地址直接訪問數據,可避免在程序中復制大量的代碼,因此指針的效率最高。一般來說,指針
加法器原理
加法器是產生數的和的裝置。加數和被加數為輸入,和數與進位為輸出的裝置為半加器。若加數、被加數與低位的進位數為輸入,而和數與進位為輸出則為全加器。常用作計算機算術邏輯部件,執行邏輯操作、移位與指令調用
加法器工作原理_加法器邏輯電路圖
加法器是產生數的和的裝置。加數和被加數為輸入,和數與進位為輸出的裝置為半加器。若加數、被加數與低位的進位數為輸入,而和數與進位為輸出則為全加器。常用作計算機算術邏輯部件,執行邏輯操作、移位與指令調用
發表于 02-18 14:40
?3.3w次閱讀
加法器的原理及采用加法器的原因
有關加法器的知識,加法器是用來做什么的,故名思義,加法器是為了實現加法的,它是一種產生數的和的裝置,那么加法器的工作原理是什么,為什么要采用
串行加法器和并行加法器的區別?
串行加法器和并行加法器是兩種基本的數字電路設計,用于執行二進制數的加法運算。它們在設計哲學、性能特點以及應用場景上有著明顯的區別。
C語言指針運算符詳解
在C語言中,當你有一個指向數組中某個元素的指針時,你可以對該指針執行某些算術運算,例如加法或減法。這些運算可以用來遍歷數組中的元素,如ptr[i]等價于*(ptr + i)。然而,如果你的操作
評論