第8章 数组

1.数组与指针

  数组名是一个个元素的地址。

  int  a[10];  int  b[10];  int  *c;

(1) c = & a[0]; &a[0]表示一个指向数组第1个元素的指针。

(2) c=a; 与 c = & a[0]; 等价

(3) b = a; 非法,不能使用赋值符把一个数组的所有元素复制到另一个数组,必须使用一个循环,每次复制一个元素。

(4) a = c; 非法,a是指针常量,而c是指针变量。

2. 下标引用和间接访问完全相同。

array[subscript]  <==>  *(array + (subscript))   (完全等价)

eg:int  array[10];

int  *ap=array+2;

(1)ap : <==> array + 2  <==> &array[2]

(2)*ap : <==> array[2]  <==>  *(array+2)

(3)ap [0] : <==>  *(ap + (0))  <==>  array[2]

(4)ap + 6 : <==>  array + 8  <==> &array[8]

(5)*ap + 6 : <==>  array[2]+6

(6)*(ap + 6) : <==>  array[8]

(7)ap [6] : <==>  array[8]

(8)ap[-1] : <==>  array[1]

(9)2[array] : <==>  *(2+(array))  <==>  *(array + 2)

3. 字符串常量的表示

(1) char  message1[ ] = “ hello “;    // 初始化一个字符数组的元素

(2) char  *message2 = “ hello “;     //真正字符串常量

指针常量message2 被初始化为指向这个字符串常量的存储位置。

  1. 4. 数组元素顺序存储

eg : int  array [3][6];

数组:

  


5. int  matrix [3][10];

matrix 这个名字的值是一个指向它第1个元素的指针,所以matrix是一个指向一个包含有10个整型元素的数组的指针。

       

(1)*(matrix +1) :指向整型的指针。子数组第1个元素地址。

(2)*(matrix +1)+5 :第6个元素的地址。

(3)*(*(matrix + 1) + 5 ) :<==>  matrix [1][5]

6.指向数组的指针

int  vector[10],  *vp = vector;      //正确

int  matrix[3][10],  *mp = matrix;    //错误

因为,matrix并不是一个指向整型的指针,而是一个指向整型数组的指针。

int  (*p) [10];   //声明一个指向整型数组的指针,p是指向整型数组的指针

int  (*p) [10] = matrix;  //声明+初始化

指向matrix的第1个整型元素:

(1)int  *pi = &matrix [0][0];

(2)int  *pi = matrix[0];

7.指针的兼容性

(1)int  *pt;

    int  (*pa) [3];

int  ar1 [2] [3];

int  ar2 [3] [2];

int  **p2;

则:

pt = & ar1 [0] [0] ;

pt = ar1 [0] ;

pt = ar1;     // 个int值构成的数组

pa = ar1;    //都指向int[3]

    pa = ar2;    //个int构成的数组,而ar2指向2个int构成的数组

    p2 = &pt;   // 都指向int *

     *p2 = ar2 [0];   //*p2类型为指向int的指针,所以和ar2 [0]兼容

     p2 = ar2;   //个int值构成的数组的指针。

因此,p2和ar2类型不同。

(2)将常量或非常量数据的地址赋给指向常量的指针是合法的。只有非常量数据的地址才可以赋给普通指针。

int  *p1;

const  int  *p2;

const  int  **pp2;

p1 = p2;      //非法,把const指针赋值给非const指针

p2 = p1;      //合法,把非const指针赋值给const指针,前提是只进行一层间接运算

pp2 = &p1;   //非法,把非const指针赋值给const指针

C和指针之学习笔记(3)的更多相关文章

  1. 02.C语言关于指针的学习笔记

    指针是一个特殊的变量,它里面存储的数值被解释成为内存里的一个地址. 要搞清一个指针需要搞清指针的四方面的内容: 指针的类型,指针所指向的 类型,指针的值或者叫指针所指向的内存区,还有指针本身所占据的内 ...

  2. 《征服c指针》学习笔记-----统计文本单词数目的程序word_count

    1.程序的要求:对用户指定的英文文本文件(包括标准输入),将英文单词按照字母顺序输出到用户指定的文本文件中(包括标准输出),并且在各单词后面显示单词的出现次数. 2.模块设计: 主要分为:1.从输入流 ...

  3. &lt;深入理解C指针&gt;学习笔记和总结 第四章 指针和数组

    数组是一个什么玩意: 数组和指针我的理解,有同样之处也有不同之处.因有同样之处,因此一些资料上说,数组和指针本质是同样的.因有不同之处,因此也有一些资料上说,数组和指针是不一样的. 同样之处: 数组名 ...

  4. C和指针之学习笔记(6)

    第17章 经典数据结构类型 堆栈 堆栈接口提供三种基本的操作:push.pop 和 top. Push:把一个新值压入到堆栈的顶部. Pop: 只把顶部元素从堆栈中移除,它并不返回这个值. Top: ...

  5. C和指针之学习笔记(5)

    第10章 使用结构和指针 单链表 typedef struct NODE { struct NODE *link; int value; } Node; 插入到一个有序单链表: #include< ...

  6. C和指针之学习笔记(4)

    第9章 字符串 字符串的输入与输出 int  ch;  char strings[80];  FILE *input; (1)scanf(“%c”,&ch);   printf(“%c \n” ...

  7. C和指针之学习笔记(2)

    第6章 指针 1.在一组字符串中查找字符: #include<stdio.h> #include<assert.h> #include<stdlib.h> #def ...

  8. C和指针之学习笔记(1)

    第1章 1.输入字符串 while((ch=getchar())!=EOF  &&  ch!=’\n’) ; ch=getchar() while(ch!=EOF  && ...

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

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

随机推荐

  1. 安装HDP时的报错信息

    1,安装ambari时报错:Bootstrap process timed out. It will be destroyed. 报错原因:/etc/sudoers文件中未设置免密权限 解决办法:ha ...

  2. docker使用host模式启动nginx

    mkdir -p /root/nginx-docker-demo/html docker run --network=host --rm --name mynginx --volume /root/n ...

  3. JAVA多线程提高十三:同步集合类的应用

    1.引言 在多线程的环境中,如果想要使用容器类,就需要注意所使用的容器类是否是线程安全的.在最早开始,人们一般都在使用同步容器(Vector,HashTable),其基本的原理,就是针对容器的每一个操 ...

  4. 转:字符集和字符编码(Charset & Encoding)

    转自:http://www.cnblogs.com/skynet/archive/2011/05/03/2035105.html ——每个软件开发人员应该无条件掌握的知识! ——Unicode伟大的创 ...

  5. python开发规范(转载)

    转载自http://www.cnblogs.com/wangcp-2014/p/4838952.html 目录 代码布局 1.1 缩进 1.2 表达式和语句中的空格 1.3 行的最大长度 1.4 空行 ...

  6. git常用命令速查表【转】

  7. ldconfig是一个动态链接库管理命令

    ldconfig是一个动态链接库管理命令 为了让动态链接库为系统所共享,还需运行动态链接库的管理命令--ldconfig ldconfig  命令的用途,主要是在默认搜寻目录(/lib和/usr/li ...

  8. 64_t2

    texlive-biblatex-chem-doc-svn42065-33.fc26.2.no..> 24-May-2017 15:44 1044190 texlive-biblatex-che ...

  9. 【题解】BZOJ 3600: 没有人的算术——替罪羊树、线段树

    题目传送门 题意 具体的自己去上面看吧...反正不是权限题. 简单来说,就是定义了一类新的数,每个数是0或者为 \((x_L, x_R)\) ,同时定义比较大小的方式为:非零数大于零,否则按字典序比较 ...

  10. SPOJ DQUERY D-query (在线主席树/ 离线树状数组)

    版权声明:本文为博主原创文章,未经博主允许不得转载. SPOJ DQUERY 题意: 给出一串数,询问[L,R]区间中有多少个不同的数 . 解法: 关键是查询到某个右端点时,使其左边出现过的数都记录在 ...