C和指针之学习笔记(3)
第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 被初始化为指向这个字符串常量的存储位置。
- 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)的更多相关文章
- 02.C语言关于指针的学习笔记
指针是一个特殊的变量,它里面存储的数值被解释成为内存里的一个地址. 要搞清一个指针需要搞清指针的四方面的内容: 指针的类型,指针所指向的 类型,指针的值或者叫指针所指向的内存区,还有指针本身所占据的内 ...
- 《征服c指针》学习笔记-----统计文本单词数目的程序word_count
1.程序的要求:对用户指定的英文文本文件(包括标准输入),将英文单词按照字母顺序输出到用户指定的文本文件中(包括标准输出),并且在各单词后面显示单词的出现次数. 2.模块设计: 主要分为:1.从输入流 ...
- <深入理解C指针>学习笔记和总结 第四章 指针和数组
数组是一个什么玩意: 数组和指针我的理解,有同样之处也有不同之处.因有同样之处,因此一些资料上说,数组和指针本质是同样的.因有不同之处,因此也有一些资料上说,数组和指针是不一样的. 同样之处: 数组名 ...
- C和指针之学习笔记(6)
第17章 经典数据结构类型 堆栈 堆栈接口提供三种基本的操作:push.pop 和 top. Push:把一个新值压入到堆栈的顶部. Pop: 只把顶部元素从堆栈中移除,它并不返回这个值. Top: ...
- C和指针之学习笔记(5)
第10章 使用结构和指针 单链表 typedef struct NODE { struct NODE *link; int value; } Node; 插入到一个有序单链表: #include< ...
- C和指针之学习笔记(4)
第9章 字符串 字符串的输入与输出 int ch; char strings[80]; FILE *input; (1)scanf(“%c”,&ch); printf(“%c \n” ...
- C和指针之学习笔记(2)
第6章 指针 1.在一组字符串中查找字符: #include<stdio.h> #include<assert.h> #include<stdlib.h> #def ...
- C和指针之学习笔记(1)
第1章 1.输入字符串 while((ch=getchar())!=EOF && ch!=’\n’) ; ch=getchar() while(ch!=EOF && ...
- C语言学习笔记之成员数组和指针
成员数组和指针是我们c语言中一个非常重要的知识点,记得以前在大学时老师一直要我们做这类的练习了,但是最的还是忘记了,今天来恶补一下. 单看这文章的标题,你可能会觉得好像没什么意思.你先别下这个 ...
随机推荐
- 【BZOJ】2125: 最短路 圆方树(静态仙人掌)
[题意]给定带边权仙人掌图,Q次询问两点间最短距离.n,m,Q<=10000 [算法]圆方树处理仙人掌问题 [题解]树上的两点间最短路问题,常用倍增求LCA解决,考虑扩展到仙人掌图. 先对仙人掌 ...
- 20155117王震宇 2016-2017-2 《Java程序设计》第十周学习总结
教材学习内容总结 Java和Android开发学习指南(第二版)(EPUBIT,Java for Android 2nd) 第22章 网络 {{屏幕快照 2017-04-30 下午8.38.06.pn ...
- Django(基础篇)
1.请求周期 url> 路由 > 函数或类 > 返回字符串或者模板语言? Form表单提交: 提交 -> url > 函数或类中的方法 ...
- IE9 下 ellipsis bug fix
fiddle: http://jsfiddle.net/tagliala/TtbuG/10/ original: https://github.com/FortAwesome/Font-Awesome ...
- 【zTree】zTree的3.5.26静态树与动态树(实用)
1.静态树: 目录结构:(css与js为下载的原文件夹)
- WPF之换肤
WPF之换肤 设计原理 WPF换肤的设计原理,利用资源字典为每种皮肤资源添加不同的样式,在后台切换皮肤资源文件. 截图 上图中,第一张图采用规则样式,第二张图采用不规则样式,截图的时候略有瑕疵. 资源 ...
- 【IT公司笔试面试】75道逻辑推理题及答案
[1]假设有一个池塘,里面有无穷多的水.现有2个空水壶,容积分别为5升和6升.问题是如何只用这2个水壶从池塘里取得3升的水. 由满6向空5倒,剩1升,把这1升倒5里,然后6剩满,倒5里面,由于5里面有 ...
- sklearn逻辑回归(Logistic Regression)类库总结
class sklearn.linear_model.LogisticRegression(penalty=’l2’, dual=False, tol=0.0001, C=1.0, fit_inter ...
- python模块之xml.etree.ElementTree
xml.etree.ElementTree用于解析和构建XML文件 <?xml version="1.0"?> <data> <country nam ...
- AGC 16 D - XOR Replace
AGC 16 D - XOR Replace 附上attack(自为风月马前卒爷) 的题解 Problem Statement There is a sequence of length N: a=( ...