C語言之指針的奧秘(二)

一、數組名的理解

int arr[10]={1,2,3,4,5,6,7,8,9,10};
int *p=&arr[0];
這里使用? &arr[0] 的?式拿到了數組第?個元素的地址,但是其實數組名本來就是地址,而且是數組首元素的地址。如下:

?我們發現數組名和數組?元素的地址打印出的結果?模?樣,數組名就是數組?元素(第?個元素)的地址

數組名如果是數組首元素的地址,那下?的代碼怎么理解呢?

#include <stdio.h>
int main()
{int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };printf("%d\n", sizeof(arr));return 0;
}

輸出的結果是:40。?如果arr是數組?元素的地址,那輸出應該的應該是4/8才對。

其實數組名就是數組首元素(第?個元素)的地址是對的,但是有兩個例外:

①sizeof(數組名),sizeof中單獨放數組名,這里的數組名表示整個數組,計算的是整個數組的大小,單位是字節

②&數組名,這里的數組名表示整個數組,取出的是整個數組的地址(整個數組的地址和數組首元素的地址是有區別的)

除此之外,任何地方使用數組名,數組名都表示首元素的地址。

這里我們發現&arr[0]和&arr[0]+1相差4個字節,arr和arr+1 相差4個字節,是因為&arr[0] 和 arr 都是首元素的地址,+1就是跳過一個元素。但是&arr 和 &arr+1相差40個字節,這就是因為&arr是數組的地址,+1 操作是跳過整個數組的。

二、使用指針訪問數組

數組在內存中是連續存放的

指針的加減運算,方便我們獲得每一個元素的地址

#include<stdio.h>
int main()
{int arr[10] = { 0 };//使用指針來訪問數組int sz = sizeof(arr) / sizeof(arr[0]);//輸入10個值int* p = arr;int i = 0;for (i = 0; i < sz; i++){//輸入scanf("%d", p + i);//p+i == &arr[i]}//輸出10個值for (i = 0; i < sz; i++){printf("%d ", *(p + i));}return 0;
}

數組名arr是數組首元素的地址,可以賦值給p,數組名arr和p這里是等價的。

p[i]等價于*(p+i),arr[i]等價于*(arr+i),數組元素在訪問編譯器處理的時候,也是轉換成首元素的地址?+偏移量求出元素的地址,然后解引用來訪問。

1.數組就是數組,是一塊連續的空間(數組的大小和數組元素類型都有關系)

2.指針(變量)就是指針(變量),是一個變量(4/8個字節)

3.數組名是地址,是首元素的地址

4.可以使用指針來訪問數組

拓展:?

三、一維數組傳參的本質

我們之前都是在函數外部計算數組的元素個數,那我們可以把函數傳給一個函數后,函數內部求元素個數嗎?

我們發現在函數內部沒有正確獲得數組的元素個數。?

這就要學習數組傳參的本質了,上篇文章寫道:數組名是數組?元素的地址;那么在數組傳參的時候,傳遞的是數組名,也就是說本質上數組傳參本質上傳遞的是數組首元素的地址。

所以函數形參的部分理論上應該 使用指針變量來接收首元素的地址 。那么在函數內部我們寫
sizeof(arr) 計算的是?個地址的大小(單位字節)而不是數組的大小(單位字節)。正是因為 函數的參數部分是本質是指針 ,所以在函數內部是沒辦法求的數組元素個數的。

1. 數組傳參的本質是傳遞了數組首元素的地址,所以形參訪問的數組和實參的數組是同一個數組。

2.形參的數組是不會單獨再創建數組空間的,所以形參的數組是可以省略數組大小的。

結論:一維數組傳參,形參的部分可以寫成數組的形式,也可以寫成指針的形式。本質上是指針變量?。

四、二級指針?

指針變量是變量,是變量就有地址,那指針變量的地址存放在哪里呢?這就是二級指針

int**就是二級指針:

*pp通過對pp中的地址解引用,這樣找到的是p,*pp其實訪問的就是p;

**pp先通過*pp找到p,然后對p進行解引用操作,找到的就是a。

?

五、指針數組

整型數組是存放整型的數組,字符數組是存放字符的數組,那么,指針數組是存放指針的數組

?

指針數組的每個元素是地址,又可以指向一塊區域。

六、指針數組模擬二維數組

#include<stdio.h>
int main()
{int arr1[] = { 1,2,3,4,5 };int arr2[] = { 2,3,4,5,6 };int arr3[] = { 3,4,5,6,7 };int* parr[3] = { arr1,arr2,arr3 };//打印數組int i = 1;for (i = 0; i < 3; i++){int j = 0;for (j = 0; j < 5; j++){printf("%d ", parr[i][j]);}printf("\n");}return 0;
}

?畫圖演示:

*(arr1+j)==arr1[j]

*(*(arr+i)+j)==arr[i][j]

parr[i]是訪問parr數組的元素,parr[i]找到的數組元素指向了整型?維數組,parr[i][j]就是整型?維數組中的元素。
上述的代碼模擬出二維數組的效果,實際上并非完全是二維數組,因為每一行并非是連續的。

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

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

相關文章

重要文件放u盤還是硬盤?硬盤和u盤哪個適合長期存儲

在數字時代&#xff0c;我們每天都會處理大量的文件。其中&#xff0c;不乏一些對我們而言至關重要的文件&#xff0c;如家庭照片、工作文檔、財務記錄等。面對這些重要文件的存儲問題&#xff0c;我們通常會面臨&#xff1a;“重要文件放U盤還是硬盤”、“硬盤和U盤哪個適合長…

Vue2打包部署后動態修改后端接口地址的解決方法

文章目錄 前言一、背景二、解決方法1.在public文件夾下創建config文件夾&#xff0c;并創建config.js文件2.編寫config.js內容3.在index.html中加載config.js4.在封裝axios工具類的js中修改配置 總結 前言 本篇文章將介紹使用Vue2開發前后端分離項目時&#xff0c;前端打包部署…

系統架構師考點--系統安全

大家好。今天我來總結一下系統安全相關的考點&#xff0c;這類考點每年都會考到&#xff0c;一般是在上午場客觀題&#xff0c;占2-4分。 一、信息安全基礎知識 信息安全包括5個基本要素&#xff1a;機密性、完整性、可用性、可控性與可審查性 (1)機密性&#xff1a;確保信息…

Navicat導入sql文件

文章目錄 Navicat導入SQL文件&#xff0c;使用默認導入&#xff0c;不做任何修改報錯嘗試一修改運行時的選擇 嘗試二修改my.ini的配置文件 Navicat導入SQL文件&#xff0c;使用默認導入&#xff0c;不做任何修改報錯 嘗試一 修改運行時的選擇 取消勾選 ‘每個運行中運行多重查…

C++ 判斷語句的深入解析

C++ 判斷語句的深入解析 C++ 是一種廣泛使用的編程語言,以其高效性和靈活性著稱。在 C++ 中,判斷語句是控制程序流程的關鍵組成部分,它們允許程序根據不同的條件執行不同的代碼路徑。本文將深入探討 C++ 中的判斷語句,包括 if、else if、else 以及 switch 語句,并展示如何…

3,區塊鏈加密(react+區塊鏈實戰)

3&#xff0c;區塊鏈加密&#xff08;react區塊鏈實戰&#xff09; 3.1 哈希3.2 pow-pos-dpos3.3非對稱加密&#xff08;1&#xff09;對稱加密AES&#xff08;2&#xff09;非對稱加密RSA 3.4 拜占庭將軍3.5 P2P網絡3.6 區塊鏈 3.1 哈希 密碼學&#xff0c;區塊鏈的技術名詞 …

在Spring Boot項目中集成單點登錄解決方案

在Spring Boot項目中集成單點登錄解決方案 大家好&#xff0c;我是微賺淘客系統3.0的小編&#xff0c;也是冬天不穿秋褲&#xff0c;天冷也要風度的程序猿&#xff01; 在現代的企業應用中&#xff0c;單點登錄&#xff08;Single Sign-On, SSO&#xff09;解決方案是確保用戶…

【Git的基本操作】版本回退 | 撤銷修改的三種情況 | 刪除文件

目錄 5.版本回退 5.1選項hard&后悔藥 5.2后悔藥&commit id 5.3版本回退的原理 6.撤銷修改 6.1情況一 6.2情況二 6.3情況三 ?7.刪除文件 Git重要能力之一馬&#xff0c;版本回退功能。Git是版本控制系統&#xff0c;能夠管理文件歷史版本。本篇以ReadMe文件為…

神器!3個免費PPT成品網站推薦+3款AIPPT工具盤點!

熬夜加班做PPT卻沒有頭緒&#xff1f;別再自己憋著想了&#xff01;現在凡事主打一個“抄作業”&#xff0c;想做ppt卻沒想法&#xff0c;可以去到ppt成品網站搜集PPT模板&#xff0c;或是使用時下流行的AI生成PPT工具&#xff0c;只需輸入PPT主題&#xff0c;即可快速生成一份…

全網最詳細的CRC講解即計算

CRC 循環冗余碼&#xff08;Cyclic Redundancy Code&#xff0c; CRC&#xff09;是一種用于校驗通信鏈路上數字傳輸準確性的計算方法&#xff08;通過某種數學運算來建立數據位和校驗位(CRC)的約定關系的&#xff09;。它是利用除法以及余數的原理來作錯誤偵測。 發送方: 使用…

客戶關系管理怎么做?這4個工具一定要會用!

在商海浮沉中&#xff0c;每一位企業家和銷售經理都深知&#xff0c;客戶是企業生存與發展的基石。但如何有效管理這些寶貴的資源&#xff0c;讓每一次互動都成為加深關系、促進成交的契機&#xff0c;卻是一門藝術加科學的結合體。今天&#xff0c;咱們就來聊聊客戶關系管理&a…

3SRB5016-ASEMI逆變箱專用3SRB5016

編輯&#xff1a;ll 3SRB5016-ASEMI逆變箱專用3SRB5016 型號&#xff1a;3SRB5016 品牌&#xff1a;ASEMI 封裝&#xff1a;SGBJ-5 批號&#xff1a;2024 現貨&#xff1a;50000 最大重復峰值反向電壓&#xff1a;1600V 最大正向平均整流電流(Vdss)&#xff1a;50A 功…

CNN -1 神經網絡-概述

CNN -1 神經網絡-概述 一:芯片科技發展介紹了解1> 芯片科技發展趨勢2> 芯片使用領域3> 芯片介紹1. 神經網絡芯片2. 神經網絡處理單元NPU(Neural Processing Unit)二:神經網絡1> 什么是神經網絡2> 神經元3> 人工神經網絡三:卷積神經網絡(CNN)入門講解一…

【Spring】springSecurity使用

一、基本配置 1. 引入依賴 在Spring Boot項目中&#xff0c;使用Spring Security首先需要引入相應的依賴。在pom.xml中添加spring-boot-starter-security依賴&#xff1a; <dependency> <groupId>org.springframework.boot</groupId> <artifactId>…

Kodcloud可道云安裝與一鍵發布上線實現遠程訪問詳細教程

文章目錄 1.前言2. Kodcloud網站搭建2.1. Kodcloud下載和安裝2.2 Kodcloud網頁測試 3. cpolar內網穿透的安裝和注冊4. 本地網頁發布4.1 Cpolar云端設置4.2 Cpolar本地設置 5. 公網訪問測試6.結語 1.前言 本文主要為大家介紹一款國人自研的在線Web文件管理器可道云&#xff0c;…

唐劉:當 SaaS 愛上 TiDB(一)- 行業挑戰與 TiDB 的應對之道

導讀 在 TiDB 8.1 發布后&#xff0c;TiDB 展現了強大的支持 SaaS 業務的能力&#xff0c;成為 SaaS 業務數據庫的優先選擇之一。 本文為“當 SaaS 愛上 TiDB”系列文章的第一篇&#xff0c;系列文章將從技術原理和真實用戶體驗兩個角度深入探討 TiDB 在 SaaS 業務中的表現&a…

qt gridlayout 應用舉例

Qt的GridLayout是一種非常有用的布局管理器&#xff0c;它允許你在一個網格中放置控件&#xff0c;這樣你就可以創建出結構清晰、布局整齊的用戶界面。下面是一個使用GridLayout的簡單例子&#xff0c;展示了如何在一個窗口中放置幾個按鈕。 #include <QApplication> …

太速科技-3U VPX飛騰處理器刀片計算機

3U VPX飛騰處理器刀片計算機 一 、產品概述 該產品是一款基于國產飛騰FT2000 4核或騰銳D2000 8核的高性能3U VPX刀片式計算機。產品提供了4個x4 PCIe 3.0總線接口&#xff0c;同時可配置為1個x16或2個x8 PCIe3.0接口&#xff0c;因此具有很強的擴展性&#xff0c;極大…

agents 分類

一、分類 自動agent、半自動agent、領域、自定義sop和支持人為干預的agent。 先潑個冷水&#xff0c;目前這些agent項目都是實驗品&#xff0c;發展還沒有做知識庫問答相關開源項目那么成熟&#xff0c; 二、全自動agent autoGPT、loopGPT、babyAGI 全自動agent就是人類不可…

sizeof()

一、題目 *struct T { char a; int *d; int b; int c:16; double e; }; T *p; 在64位系統以及64位編譯器下&#xff0c;以下描述正確的是 A: sizeof 24 B: sizeof(p) 24 C: sizeof(p->a) 1 D: sizeof(p->e) 4 二、解析 p是一個指針&#xff0c;指針在32位機器上是…