VS_C_17/12/12 C中数组与宏和const的总结

来源:互联网 发布:linux system-auth 编辑:程序博客网 时间:2024/06/06 13:02

一:数组
一维数组:
1.1int str[] ;这样我们定义一个数组,注意它在定义时在内存中是分配
一块内存,即所分配的这一块内存都属于str这个数组所有,就算数组中的
不够填满这块内存,也会在后面补0.
e.g: int str[10] = {1,2,3,4,5};在内存中显示为{1,2,3,4,5,0,0,0,0,0}
1.2我们也可以在初始化数组后不定义数组的长度,编译器可以自动算
出数组的长度:
e.g:int str[] = {1,2,3,4,5};这样定义也是对的。
1.3访问数组数可以用数组名加下标的方式。注意,下标是从0开始的,且
C中并不检查数组下标是否越界,所以在访问数组时需注意边界问题。//烫烫烫~
1.4若定义一个数组:int str[];那 *str则表示数组的第一个元素。
str即数组名即数组中第一个元素的地址。
1.5一维数组的元素作为函数实参,与同类型的简单变量作为实参一样,
是单向的值传递,即数组元素的值传给形参,从而是改变不影响实参。
但注意:数组名代表着整个数组的地址,如果一维数组的名字作为函数
实参,传递的是整个数组,即形参数组和实参数组完全相同,是存放在同一
储存空间的同一个数组,这样形参数组修改时,实参数组也同时被修改了.
形参数组的个数可以省略。
E.g:

#include <stdio.h>#include <stdlib.h>void Lbf1(int str[],int a,int b)//传入数组形参和变量形参{     int tmp;    str[0] = 2;                 //修改str[0]的值为2    tmp = a;                    //交换a,b的值    b = tmp;    a = b;}int main(){    int str[] = { 1, 2, 3, 4, 5 };//定义数组实参    int a = 10;                   //定义变量实参    int b = 20;    Lbf1(str, a,b);    printf("%d\n",str[0]);        //打印数组str[0]    printf("%d  %d\n", a, b);      //打印变量    system("pause");    return 0;}

最后打印时>>>>>>a = 10 b = 20 str[0] = 2
说明在被调函数中修改普通的变量形参是不会改变main函数中的实参值的,而修改被调函数中数组的元素则会改变main函数中的实参值。

二:define 与 const 的区别
2.1存储方式不同
  define宏仅仅是展开,有多少地方使用,就展开多少次,不会分配内 存。(宏定义不分配内存,变量定义分配内存。)
2.2类型和安全检查不同
  define宏没有类型,不做任何类型检查,仅仅是展开
  const常量有具体的类型,在编译阶段会执行类型检查。
2.3编译器处理方式不同
  define宏是在预处理阶段展开。
  const常量是编译运行阶段使用。
2.4const 可以节省空间,避免不必要的内存分配。
const定义常量从汇编的角度来看,只是给出了对应的内存地址。所以,const定义的常量在程序运行过程中只有一份拷贝(因为是全局的只读变量,存在静态区),而 #define定义的常量在内存中有若干个拷贝(只要用到就会有拷贝)。
2.5 宏替换只作替换,不做计算,不做表达式求解;宏预编译时就替换了,程序运行时,并不分配内存。
E.g:

#define N 3#define Y(n) ((N+1)*n)执行语句z=2*(N+Y(5+1));那么z = 2 * (3 + (3 + 1) * 5 + 1) = 48

在这题中 n = 5 +1 直接替换,并不计算。