C和指针 五

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函数用于修改一个原先已经分配的内存块大小









  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值