第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. 【BZOJ】2125: 最短路 圆方树(静态仙人掌)

    [题意]给定带边权仙人掌图,Q次询问两点间最短距离.n,m,Q<=10000 [算法]圆方树处理仙人掌问题 [题解]树上的两点间最短路问题,常用倍增求LCA解决,考虑扩展到仙人掌图. 先对仙人掌 ...

  2. 20155117王震宇 2016-2017-2 《Java程序设计》第十周学习总结

    教材学习内容总结 Java和Android开发学习指南(第二版)(EPUBIT,Java for Android 2nd) 第22章 网络 {{屏幕快照 2017-04-30 下午8.38.06.pn ...

  3. Django(基础篇)

    1.请求周期 url> 路由 > 函数或类 > 返回字符串或者模板语言? Form表单提交:        提交 -> url > 函数或类中的方法           ...

  4. IE9 下 ellipsis bug fix

    fiddle: http://jsfiddle.net/tagliala/TtbuG/10/ original: https://github.com/FortAwesome/Font-Awesome ...

  5. 【zTree】zTree的3.5.26静态树与动态树(实用)

    1.静态树: 目录结构:(css与js为下载的原文件夹)

  6. WPF之换肤

    WPF之换肤 设计原理 WPF换肤的设计原理,利用资源字典为每种皮肤资源添加不同的样式,在后台切换皮肤资源文件. 截图 上图中,第一张图采用规则样式,第二张图采用不规则样式,截图的时候略有瑕疵. 资源 ...

  7. 【IT公司笔试面试】75道逻辑推理题及答案

    [1]假设有一个池塘,里面有无穷多的水.现有2个空水壶,容积分别为5升和6升.问题是如何只用这2个水壶从池塘里取得3升的水. 由满6向空5倒,剩1升,把这1升倒5里,然后6剩满,倒5里面,由于5里面有 ...

  8. sklearn逻辑回归(Logistic Regression)类库总结

    class sklearn.linear_model.LogisticRegression(penalty=’l2’, dual=False, tol=0.0001, C=1.0, fit_inter ...

  9. python模块之xml.etree.ElementTree

    xml.etree.ElementTree用于解析和构建XML文件 <?xml version="1.0"?> <data> <country nam ...

  10. AGC 16 D - XOR Replace

    AGC 16 D - XOR Replace 附上attack(自为风月马前卒爷) 的题解 Problem Statement There is a sequence of length N: a=( ...