1. int array[10]
int *ap=array+2;
ap[0]: 对等表达式 array[2] , * (ap +(0))
ap[-1]:使用偏移量-1 得到它的前一个元素,也就是array[1]
2. 2[array] == *(2+ (array)) == *(array+2)
int array[10] ,a ;
for(a=0;a<10;a++)
{ array[a]=1};
//可以做如下的优化
int array[10],*ap;
for(ap=array;ap<array+10;ap++)
{*ap =1 ;}
为了对下标表达式求值,编译器在程序中插入指令,取得a的值,并把它与整型的长度相乘。这个乘法需要花费一定的时间和空间。
4. 当你根据某个固定数目的增量在一个数组中移动时,使用指针变量将比使用下标产生效率更高的代码。
5. 存储于静态内存的数组只初始化一次,也就是在程序之前初始化。
6.
char message1[]="hello"; //字符串数组
char *message2=“hello”;//字符串常量
7. 在二维数组中逐个访问
int *pi= &matrix[0][0];
int *pi=matrix[0];
8. 单目操作符 & 返回一个指向数组的指针,而不是一个指向数组第一个元素的指针的指针。
9. 内存操作
#include<stdio.h>
void *memcpy(void *dst , void const * src, size_t length);
void *memmove(void *dst , void const * src, size_t length);
void *memcmp(void *dst , void const * src, size_t length);
void *memchr(void *dst ,int ch, size_t length);
void *memset(void *dst , int ch, size_t length);
memmove跟memcpy差不多,只是它的源和目标操作数可以重叠。
memcmp对两端内存的内容进行比较,比较length个字节,这些值按照无符号字符逐字节进行比较。
memchr 从dst的起始位置开始查找字符ch第一次出现的位置。并返回一个指向该位的指针。
memset 函数把从a开始的length个字节都设值。
10.
void *malloc(size_t size);
void free(void * pointer);
malloc 的参数就是需要分配的内存字节数。如果成功分配,返回一个指向被分配的内存块起始位置的指针,不成功返回null 指针。
向free传递一个null 参数不会产生任何效果。
11.
标准表示 一个void *类型的指针可以转换为其他任何类型的指针。
12.
void *calloc(size_t num_elements, size_t size_element);
void * relloc(void * ptr , size_t new_size);
calloc主要实在malloc的基础上初始化地址为0
relloc函数用于修改一个原先已经分配的内存块大小