欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c語言指針數(shù)組的具體使用

 更新時間:2023年12月21日 08:41:26   作者:鮑海超-GNUBHCkalitarro  
指針數(shù)組就是存放指針變量的數(shù)組,指針數(shù)組的本質是數(shù)組,而非指針,本文主要介紹了c語言指針數(shù)組的具體使用,具有一定的參考價值,感興趣的可以了解一下

下面我們再討論一個特殊的數(shù)組,它的元素為指針。

我們先從普通的元素為 int 類型的數(shù)組開始。

int arr1[5] = {1, 2, 3, 4, 5};

int arr2[5] = {11, 22, 33, 44, 55};

int arr3[5] = {111, 222, 333, 444, 555};

arr1、arr2、arr3均為 int [5] 類型的數(shù)組。

若數(shù)組名出現(xiàn)在表達式中,即會轉換為指向首元素的指針,即 int * 類型。我們將這幾個數(shù)組的首元素指針存儲在另一個元素為 int * 的數(shù)組里。

int *pToArr[3];

pToArr[0] = arr1; //arr1轉換為首元素指針,int[5]到int*

pToArr[1] = arr2; //arr2轉換為首元素指針,int[5]到int*

pToArr[2] = arr3;  //arr3轉換為首元素指針,int[5]到int*

pToArr[0]的類型為 int* ,指向arr1的第1個元素。

pToArr[1]的類型為 int* ,指向arr2的第1個元素。

pToArr[2]的類型為 int* ,指向arr3的第1個元素。

pToArr的類型為 int *[3] ,是一個數(shù)組。它有3個元素,每個元素的類型為 int * 。

由于元素類型為指針,所有它也被稱為指針數(shù)組。

定義和賦值完數(shù)組后,我們使用這個指針數(shù)組來訪問所有元素。

for(int i = 0 ; i < 3; i ++)

{

int **p = pToArr + i; for(int j = 0; j < 5; j++)

{

printf("%d ", *(*p + j));

}

printf("\n");

}

看,這段程序遍歷了3個數(shù)組的元素。

不過,這段程序的類型轉換和運算稍微有點多,別著急,我們下面來詳細分析它。

pToArr是一個 int *[3] 類型的數(shù)組,若出現(xiàn)在表達式 p = pToArr + i 中,即轉換為指向首元素的指針,即 int *[3] 轉為 int ** 。

p + 0 類型為 int** ,指向pToArr的第1個元素。

p + 1 類型為 int** ,指向pToArr的第2個元素。

p + 2 類型為 int** ,指向pToArr的第3個元素。 

接著,我們分析表達式 *(*p + j) 。

假設在 int **p = pToArr + i 中,i的值為0,那么p指向pToArr的第一個元素。

*p 表達式結果為pToArr[0],指向arr1的第一個元素。

表達式 *p + j ,分別指向arr1中各個元素。

最后,表達式 *(*p + j) 取得arr1數(shù)組內各個元素的值。 

我們再來順一個整個流程。

p ,指向 pToArr 的第一個元素,類型為 int ** 。

*p ,指向 arr1 的第一個元素,類型為 int * 。

*p + j ,指向 arr1 中的第j個元素,類型為 int * 。

*(*p + j) ,為 arr1 中的第j個元素。

這樣即可完成對 arr1 的訪問,隨著循環(huán)的繼續(xù),i會變?yōu)?,2。

p會指向pToArr中的第二、第三個元素,按照上面的處理,會繼續(xù)訪問arr2,arr3中元素的訪問。

到此這篇關于c語言指針數(shù)組的具體使用的文章就介紹到這了,更多相關c語言指針數(shù)組內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C語言入門篇--注釋,關鍵字typedef及轉義字符詳解

    C語言入門篇--注釋,關鍵字typedef及轉義字符詳解

    本篇文章是c語言基礎篇,主要為大家介紹了C語言的關鍵字typedef,注釋,轉義字符的基本理論知識,希望可以幫助大家快速入門c語言的世界,更好的理解c語言
    2021-08-08
  • c++動態(tài)內存管理與智能指針的相關知識點

    c++動態(tài)內存管理與智能指針的相關知識點

    為了更容易同時也更安全地使用動態(tài)內存,新的標準庫提供了兩種智能指針(smart pointer)類型來管理對象,下面這篇文章主要給大家介紹了關于c++動態(tài)內存管理與智能指針的相關知識點,需要的朋友可以參考下
    2022-03-03
  • C++20 格式化字符串的實現(xiàn)

    C++20 格式化字符串的實現(xiàn)

    本文主要講述了C++20中新引入的std::format功能,該功能用于格式化字符串,提供了一種簡潔、類型安全且靈活的方式來構建格式化字符串,文章從使用場景、格式化規(guī)則、自定義類型的格式化等方面進行了詳細的介紹,感興趣的可以了解一下
    2024-10-10
  • C語言實現(xiàn)班級檔案管理系統(tǒng)課程設計

    C語言實現(xiàn)班級檔案管理系統(tǒng)課程設計

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)班級檔案管理系統(tǒng)課程設計,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • C++ 中的INT_MAX,INT_MIN數(shù)值大小操作

    C++ 中的INT_MAX,INT_MIN數(shù)值大小操作

    這篇文章主要介紹了C++ 中的INT_MAX,INT_MIN數(shù)值大小操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • C++重載的奧義之運算符重載詳解

    C++重載的奧義之運算符重載詳解

    函數(shù)的重載是指利用相同的函數(shù)名設計一系列功能相近,但是功能細節(jié)不一樣的函數(shù)接口;因此運算符重載也是指對于同一個運算符來說,它可以用于實現(xiàn)不同的功能。下面就一起來理解下運算符重載的應用吧
    2023-04-04
  • C語言植物大戰(zhàn)數(shù)據結構二叉樹堆

    C語言植物大戰(zhàn)數(shù)據結構二叉樹堆

    這篇文章主要為大家介紹了C語言植物大戰(zhàn)數(shù)據結構二叉樹堆的圖文示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • QT實現(xiàn)年會抽獎小軟件的示例代碼

    QT實現(xiàn)年會抽獎小軟件的示例代碼

    本文主要介紹了QT實現(xiàn)年會抽獎小軟件的示例代碼,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 基于QT和百度云api實現(xiàn)批量獲取PDF局部文字內容

    基于QT和百度云api實現(xiàn)批量獲取PDF局部文字內容

    這篇文章將為大家介紹如何使用 QT 構建圖形用戶界面,結合百度云 OCR API 實現(xiàn)批量獲取 PDF 局部文字內容并對文件進行改名的功能,需要的可以參考下
    2025-03-03
  • C++線性時間的排序算法分析

    C++線性時間的排序算法分析

    這篇文章主要介紹了C++線性時間的排序算法分析,是非常經典的非比較排序算法,對于C++程序員有很大的借鑒價值,需要的朋友可以參考下
    2014-08-08

最新評論