数组与指针的操作

/*
 ============================================================================
 Name        : TestArray.c
 Author      : lf
 Version     :
 Copyright   : Your copyright notice
 Description : 数组与指针的操作
 1 数组的基本知识
 2 数组当做参数传递的问题

  数组当做参数传递的时候,传递的是数组的指针
  因为:
 1 数组的拷贝很耗费资源.为了避免这种情况,C语言的编译器在传递数组时传递数组的指针
 2 C语言中数组名代表了数组的首地址
 3 一般来讲在传入数组时,同时将数组的长度传过去避免越界.
   main(int, char* [])亦是如此

 参考资料:
 1 http://bbs.csdn.net/topics/380157577
 2 http://bbs.csdn.net/topics/380060409
 Thank you very much

 ============================================================================
 */

#include <stdio.h>
#include <stdlib.h>

int main(void) {
	testArray1();
	testArray2();
	return EXIT_SUCCESS;
}


/**
 * 数组的基本知识
 * 1 数组名即为数组第一个元素的首地址
 * 2 *(array+1)中的+1到底是什么意思呢???
 *   既然数组名即为数组第一个元素的首地址,那么
 *   *array就取出了第一个元素的值,为0.
 *   那为什么*(array+1)就去除了第二个元素的值1呢?
 *   在此我们注意array数组的定义:
 *   int array[5]={0,1,2,3,4};
 *   它是一个int类型的数组,里面保存的全部是int数据.
 *   即每个元素占四个字节.
 *   所以*(array+1)中的array+1表示从首地址移动了1个int的长度
 *   即移动到了第二个元素的首地址.
 *   这样就取到了第二个元素!!!!!!!!
 *   概括地说:*(p+1)的+1操作到底移动多少,关键还是看p是什么类型
 *   的指针
 * 3 array[i]和*(array+i)等价,获取数组中的某个元素
 *   &array[i]和array+i等价,获取某个元素的地址
 *   这是为什么呢?
 *   重复一下核心:核心还是在于:数组名是数组第一个元素的首地址!!
 *   所以获取某个元素比较"正宗"的写法是*(array+i)而array[i]
 *   只是它的简写.
 *   那么获取某个元素的地址比较"正宗"的写法是array+i而&array[i]
 *   只是它的简写
 * 4 利用指针访问数组
 *   这两种方式都行,第一种是第二种的简写
 *   printf("element%d = %d address=%x\n",j,p[j],&p[j]);
 *   printf("element%d = %d address=%x\n",j,*(p+j),p+j);
 *   注意:这里的p是一个指针!!!它指向了数组arr的第一个元素的首地址.
 *   既然是一个指针,那么:
 *   获取第j个元素的地址就是:p+j
 *   获取第j个元素的数据就是:*(p+j)
 */
void testArray1(){

	//1 数组名即为第一个元素的首地址
	int array[5]={0,1,2,3,4};
	printf("fisrt element address=%x\n",array);
    printf("===========\n");


    //2 关于*(array+1)的理解,见上总结
    printf("*array=%d\n",*array);
    printf("*(array+1)=%d\n",*(array+1));
    printf("===========\n");



    //3 查看每个元素的值和其地址,见上总结
    int i;
    for(i=0;i<5;i++){
    	//两种方式都可以,第一种是第二种的简写
    	printf("element%d = %d address=%x\n",i,array[i],&array[i]);
    	printf("element%d = %d address=%x\n",i,*(array+i),array+i);
    }
    printf("===========\n");



    //4 利用指针访问数组(方式一),总结见上
    //该方式采用的是下标遍历,指针是没有变化的只是在移动.比如p+j
    int arr[5]={9,5,2,7,0};
    int *p=arr;
    int j;
    for(j=0;j<5;j++){
    	//两种方式都可以,第一种是第二种的简写
    	printf("element%d = %d address=%x\n",j,p[j],&p[j]);
        printf("element%d = %d address=%x\n",j,*(p+j),p+j);
    }
    printf("===========\n");


    //4 利用指针访问数组(方式二),总结见上
    //该方式采用的是指针遍历,指针在不断变化的,比如pointer++
    int intArray[5]={5,4,3,2,1};
    int *pointer;
    for(pointer=intArray;pointer<intArray+5;pointer++){
    	 printf("element = %d address=%x\n",*pointer,pointer);
    }
    printf("===========\n");

}


void testArray2() {
	//所占内存大小为20个字节
	int array[5] = { 1, 2, 3, 4, 5 };
	printf("testArray2 int array[5] size=%d\n", sizeof(array));
	printf("===========\n");

	int i;
	for (i = 0; i < 5; i++) {
		printf("first array[%d]=%d\n", i, array[i]);
	}
	printf("===========\n");

	//把数组作为参数传递到其他的函数
	int length = sizeof(array) / sizeof(int);
	testArray3(array, length);

	//再次遍历观察原来的数组
	for (i = 0; i < 5; i++) {
		printf("second array[%d]=%d\n", i, array[i]);
	}
	printf("===========\n");
}


/**
 * 在函数中接收到传递过来的数组会退化成一个指针.
 * 于是利用该指针对原数组进行操作.
 */
void testArray3(int array[],int length){
	//因为传递过来的仅仅是个指针,所以其大小为4个字节!!!!
	printf("testArray3 int array[5] size=%d\n",sizeof(array));
	printf("===========\n");

	int i;
	for (i = 0; i < length; i++) {
		//array[i] = array[i] + 5;
		*(array+i)=*(array+i)+5;
	}
}



你可能感兴趣的:(数组,C语言,指针)