程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> c說話中數組名a和&a具體引見

c說話中數組名a和&a具體引見

編輯:關於C++

c說話中數組名a和&a具體引見。本站提示廣大學習愛好者:(c說話中數組名a和&a具體引見)文章只能為提供參考,不一定能成為您想要的結果。以下是c說話中數組名a和&a具體引見正文


比來又把進修c說話提上日程下去了~~~先把我盤算看的書都寫上去吧,<C說話深度分析>,<c和指針>系類,<c說話圈套和缺點>

先說說a和&a的差別(有三點,三個偏向):
1.是a和&a的實質,都是甚麼類型的。
2.從2維數組的角度看。
3.從指針運算的角度看。

聲明:固然數組名不是指針,然則用的很像指針,我們暫且把它叫做一個指針吧。

第一個成績:
int a[10];  a ,&a和&a[0] 都是分離是甚麼?先解釋a ,&a和&a[0]三個值是的相等哈。

a叫做數組名,是數組首元素的地址,也就是&a[0]的值。像是一個指針類型,是一個int型的指針類型,int *,先懂得成指針吧。

&a這才是一個真實的指針,是一個數組指針。是數組的地址。

切記:&a不是指向指針的指針,由於&a和a的值相等,然則*&a和*a的值不相等。*&a和a的值一樣,解釋*&a僅僅是對這個數組指針停止了取值,獲得的是數組的值,即數組首元素的地址,而不是對&a這個地址停止了取值。這個應當是c說話中針對數組指針運算的劃定。 

這裡的數組指針&a取值以後,釀成了a,是a,不是*a,釀成了這個數組的數組名,或許說是數組首元素的地址。

我做了以下試驗:

#include<stdio.h>
 int main()
 {
         int a[5]={1,2,3,4,5};
         printf("a=%x\n",a);
         printf("&a=%x\n",&a);
         printf("*(int*)&a=%x\n",(*((int *)(&a))));
         printf("*&a=%x\n",(*(*(&a))));
         printf("&a[0]=%x\n",&a[0]);
         printf("*&a[0]=%x\n",*(&a[0]));
         return 0;
 }



printf("*(int*)&a=%x\n",(*((int *)(&a))));

這句沒有像慣例的一樣對&a停止取值,而是強迫類型轉換了一下,可見這個不是一個指向指針的指針。

第二個成績:
二維數組中的應用指針來遍歷的方法,也不是一個指向指針的指針(2級指針) ,這句printf("%d\n", *(*(a+i) + j));  *(a+i)也就是將數組指針取值取得數組的首元素地址,經常的誤區就是數組指針的取值運算和通俗的指針取值運算紛歧樣。數組指針取值運算相似一個強迫類型轉換的進程。    

留意:二維數組的數組名a,是第一個一維數組的數組指針,*a就是第一個一維數組的數組名。也能夠直接用tpye *強迫類型轉換。

 #include <stdio.h>

 int main(int argc, char* argv[], char* env[])
 {
    int a[3][3] = {{0, 1, 2}, {3, 4, 5}, {6, 7, 8}};
    int i = 0;
    int j = 0;

    for(i=0; i<3; i++)
    {
         for(j=0; j<3; j++)
         {
           //  printf("%d\n", *((int *)(a+i) + j));
                  printf("%d\n", *(*(a+i) + j));
         }
     }

其實這兩個器械挺難懂得的,應當也沒有那末主要,懂得一下好了,重要照樣要多多懂得數組指針的運算。由於我看了很多多少文章都是經由過程對&a和a的運算角度來講明二者不是一個器械的。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved