1、思考

下面这些声明合法吗?

  int array[5];

  int matrix[3][3];

  int * pa = array;

  int * pm = matrix;

问题:

  array代表数组首元素的地址,那么matrix代表什么?

  array和&array的地址值相同,但是意义不同,那么它们所代表的类型相同吗?

2、数组类型

  C语言中的数组有自己特定的类型

  数组的类型由元素类型和数组大小共同决定

例: int array[5]的类型为int[5]

3、定义数组类型

C语言中通过typedef为数组类型重命名

   typedef type(name)[size]; 

数组类型:

   typedef int(AINT5)[];
2 typedef float(AFLOAT10)[];

数组定义:

   AINT5 iArray; 

   AFLOAT10 fArray;

4、数组指针

数组指针用于指向—个数组

数组名是数组首元素的起始地址,但并不是数组的起始地址

通过将取地址符&作用于数组名可以得到数组的起始地址

可通过数组类型定义数组指针: ArrayType* pointer;

也可以直接定义: type(*pointer) [n];

- pointer为数组指针变量名

- type为指向的数组的元素类型

- n为指向的数组的大小

5、实例分析

数组类型和数组指针      32-1.c

 #include <stdio.h>  
  
typedef int(AINT5)[];  
typedef float(AFLOAT10)[];  
typedef char(ACHAR9)[];  
  
int main()  
{  
    AINT5 a1;  
    float fArray[];  
    AFLOAT10* pf = &fArray;  //数组指针
    ACHAR9 cArray;  
    char(*pc)[] = &cArray;  //定义一个数组指针并用cArray数组的地址初始化
    char(*pcw)[] = cArray;  //warning or error 数组首元素地址为char* 初始化char(*)[4]
      
    int i = ;  
      
    printf("%d, %d\n", sizeof(AINT5), sizeof(a1));  //20,20
      
    for(i=; i<; i++)  
    {  
        (*pf)[i] = i;  
    }  
      
    for(i=; i<; i++)  
    {  
        printf("%f\n", fArray[i]);  
    }  
      
    printf("%p, %p, %p\n", &cArray, pc+, pcw+);  //(unsigned int)pc + 1*9
  
    return ;  
}  

数组首元素的地址为int* 类型,而数组的地址为int(*)[5]类型

pc+1=(unsigned int)pc+sizeof(*pc)=0xbfdce3ac

pcw+1=(unsigned int)pcw+sizeof(*pcw)=0xbfdce3a7

6、指针数组

指针数组是—个普通的数组

指针数组中每个元素为—个指针

指针数组的定义: type* pArray[n];

- type它为数组中每个元素的类型

- pArray为数组名

- n为数组大小

7、实例分析

指针数组的应用     32-2.c

 #include <stdio.h>  
#include <string.h>  
  
#define DIM(a) (sizeof(a)/sizeof(*a))  
  
int lookup_keyword(const char* key, const char* table[], const int size)  
{  
    int ret = -;  
      
    int i = ;  
      
    for(i=; i<size; i++)  
    {  
        if( strcmp(key, table[i]) ==  )  
        {  
            ret = i;  
            break;  
        }  
    }  
      
    return ret;  
}  
  
int main()  
{  
    const char* keyword[] = {  
            "do",  
            "for",  
            "if",  
            "register",  
            "return",  
            "switch",  
            "while",  
            "case",  
            "static"  
    };  
      
    printf("%d\n", lookup_keyword("return", keyword, DIM(keyword)));  
    printf("%d\n", lookup_keyword("main", keyword, DIM(keyword)));  
  
    return ;  
}  

const char* table[]作参数实际会退化为const char** table

8、小结

数组的类型由元素类型和数组大小共同决定

数组指针是—个指针,指向对应类型的数组

指针数组是—个数组,其中每个元素都为指针

数组指针遵循指针运算法则

指针数组拥有C语言数组的各种特性

C语言-数组指针与指针数组的更多相关文章

  1. C语言学习笔记之成员数组和指针

    成员数组和指针是我们c语言中一个非常重要的知识点,记得以前在大学时老师一直要我们做这类的练习了,但是最的还是忘记了,今天来恶补一下.     单看这文章的标题,你可能会觉得好像没什么意思.你先别下这个 ...

  2. C语言中字符数组和字符串指针分析

    这几天搞Unix上的C程序,里面用到了很多字符数组和字符串指针,我记得在学完C语言后相当一段时间里,对指针这个东西还是模模糊糊,后来工作也没怎么 用到过C,虽然网上这类的文章也有很多,还是决定自己在这 ...

  3. 对于C语言中数组名是指针的理解

    我们都知道,c语言中数组名是一个指针,比如下面这段代码 #include<iostream>using namespace std;int main(){ int a[4]={1,2,3, ...

  4. 《C语言学习笔记》指针数组及其应用

    C语言中,最灵活但又容易出错的莫过于指针了.而指针数组,是在C中很常见的一个应用.指针数组的意思是说,这个数组存储的所有对象都为指针.除了存储对象为指针,即一个地址外,其它操作和普通数组完全一样. # ...

  5. C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com

    原文:C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | I ...

  6. C语言中的函数、数组与指针

    1.函数:当程序很小的时候,我们可以使用一个main函数就能搞定,但当程序变大的时候,就超出了人的大脑承受范围,逻辑不清了,这时候就需要把一个大程序分成许多小的模块来组织,于是就出现了函数概念:  函 ...

  7. 【嵌入式开发】C语言 内存分配 地址 指针 数组 参数 实例解析

    . Android源码看的鸭梨大啊, 补一下C语言基础 ... . 作者 : 万境绝尘 转载请注明出处 : http://blog.csdn.net/shulianghan/article/detai ...

  8. 别人不会给你说的---C语言中数组名和指针的区别 及 sizeof用法

    引自: http://blog.csdn.net/tianyue168/article/details/5781924 #i nclude <iostream.h> int  main( ...

  9. C/C++——C语言数组名与指针

    版权声明:原创文章,转载请注明出处. 1. 一维数组名与指针 对于一维数组来说,数组名就是指向该数组首地址的指针,对于: ]; array就是该数组的首地址,如果我们想定义一个指向该数组的指针,我们可 ...

  10. 【C语言】-指向一维数组元素的指针

    本文目录 一.用指针指向一维数组的元素 二.用指针遍历数组元素 三.指针与数组的总结 四.数组.指针与函数参数 说明:这个C语言专题,是学习iOS开发的前奏.也为了让有面向对象语言开发经验的程序员,能 ...

随机推荐

  1. Scout YYF I POJ - 3744【矩阵乘法优化求概率】

    题意: 一条路上有 $n$ 个地雷,YYF 从位置 $1$ 出发,走一步的概率为 $p$,走两步的概率是 $(1-p)$.求 YYF 能顺利通过这条路的概率. 数据范围: $1\leq n \leq ...

  2. KMP刷题记录

    [BZOJ4698][SDOI2008]Sandy的卡片 差分一下然后选一个串,用这个串的所有前缀和其他串kmp,求出最长的公共部分即可 代码: #include <bits/stdc++.h& ...

  3. WIFI Pineapple 排雷

    1.在WEB界面中无法安装插件 解决:进入SSH,执行opkg update 2.ettercap无法运行,缺少动态连接库,libpcap.so.1.3 创建软连接   ln -s /usr/lib/ ...

  4. 如何在IDEA中使用GitHub

    第一步:在GitHub网站中注册自己的账号 地址:https://github.com/ 第二步:下载Git客户端 地址:https://git-scm.com/ 第三步:在GitBash中配置用户名 ...

  5. scrapy(一)--Pycharm创建scrapy项目

    1.环境 操作系统:windows10. python版本:python3.6,Anaconda(将Anaconda3\Scripts;路径添加到环境变量Path中) pycharm:pycharm2 ...

  6. 剑指offer-面试题17-打印从1到最大的n位数-数字

    /* 题目: 输入数字n,按顺序打印从1到最大的n位十进制数. 如输入3,打印从1,2,3到999. */ /* 思路: 大数问题转化为字符串或数组. */ #include<iostream& ...

  7. youhua

  8. spark-sklearn TypeError: 'JavaPackage' object is not callable

    from sklearn import svm, datasets from spark_sklearn import GridSearchCV from pyspark import SparkCo ...

  9. Fastbin attack

    Fastbin Attack 暂时接触到了两种针对堆分配机制中fastbin的攻击方式,double free和house of spirit Double free 基本原理 与uaf是对free之 ...

  10. 19新生赛 谁更nb

    题目描述: 有一堆石子共有N个.syx xxh两个人轮流拿,syx先拿.每次最少拿1颗,最多拿K颗,拿到最后1颗石子的人获 胜.syx xxh都非常聪明,拿石子的过程中不会出现失误.给出N和K,问最后 ...