当前位置:网站首页>字符数组/字符串数组|数组指针/指针数组/

字符数组/字符串数组|数组指针/指针数组/

2022-08-02 14:13:00 白U

数组;
数组的类型 由

  • 元素的类型
  • 数量
    数组的定义决定了数组的类型,元素个数以及元素类型。
    语法结构: 类型 数组名 [元素个数]
    int Arr [10]
    元素的个数必须是整型常量,且必须 >0 .
    数组的大小是在编译期确定的,编译系统按照定义为数组分配一段连续的存储单元。(且大小不可改变,所以不可以定义为变量,但C99标准可以)
    计算数组大小:sizeof(ar)/sizeof(ar[0]);//数组大小除以元素类型的大小。才是数组的大小。
    仍然占一个字节,但是strlen()`计算出来的是字符串长度,不包括。
    char str[10] = {‘a’,‘b’,‘c’,‘d’,‘e’} 0的ascll码值和\0相同。因此 被视为字符串。
    请添加图片描述
字符串:凡是由'\0'结尾均为字符串
字符数组:凡是么有'\0'结尾均为字符数组。
当len = strlen(strd), 
1char strd[] = {
    'a','b','c','d','e'} 值为5
2char strd[] = {
    'a','b','c','d','e''f','g','h'}15
明显错误,是因为它在计算的时候在寻找'\0',因此越界超出,而1式知识运气比较好罢了,刚好等于5 

请添加图片描述

不要再提字符数组的概念!!跳到字符串数组就要想到后面由\0 不能计算其长度,只能计算其大小。

  • 数组名是指针,但是却丢失了数组另一个要素:数组的大小,及数组元素的数量。编译器按数组定义时的大小分配内存,但运行时对数组的边界不加检测,这会带来无法预测的错误。
    int ar[] = {1,2,3,4,5,6}
    ar 代表数组首元素的地址
    *ar *(ar+1) *(ar+3)···· (ar+i)
    i[ar] 和 ar[]相等, 都会转化为指针
    为什么

    数组作为函数的参数会退化为指针呢:我们将从时间效率和空间效率分析。
void print_Ar(int br[10]);
void print_Ar(int br[]);
void Printf(int *br , int n);

我们先假设数组作为函数的形参,我们分析一下调用过程;
在传递过程中我们不仅要把数组名传递给形参,还要把数组个数传递给形参

   int main()
           {
    
              int arr[10] ;
                  数组名arr 未初始化也就是为赋值,没有存储数据。
              int brr[3] = {
    11,22,22};
              brr 已经初始化
              return 0}
              
  • 数组指针int *ar[5] 5个元素类型为整型指针的数组
    int *ar[5] = {&a,&b,&c,&d} //未定义的部分为 0

  • 指针数组int (*pa)[5]; pa是一个指针变量,(能够存放元素个数为5,元素类型为整型类型)的数组的地址

原网站

版权声明
本文为[白U]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_52958292/article/details/125918051