• 用幻灯片讲解C++中的C语言风格数组


    用幻灯片讲解C++中的C语言风格数组

    1.栈内存中的C风格数组

    • 糟糕的可用性,但你将在遗留代码中看到它们。
    • 相同类型的对象块。
    • 大小必须是常量表达式。
    • 第一个元素的索引为0,即数组索引从0开始。
      注意一下数组的初始化,使用了C++11标准之后的统一初始化,即用花括号初始化变量的方法。
      在这里插入图片描述

    2.C风格数组的指针

    更奇怪的是:数组标识符退化为指向第一个元素的指针。
    这句话啥意思呢,以下图为例,数组numbers的标识符是numbers,可以单独使用它,使用它时,它退化成了此数组第一个元素的指针。
    即:numbers = &numbers[0]
    在这里插入图片描述

    3.数组存取

    给数组元素赋值的两种方法。
    在这里插入图片描述

    4.堆内存中的C风格数组

    • 相同类型的对象块。
    • 数组大小可以在运行时设定。
      第一点和栈内存数组一致,就是说所有元素类型必须一致。第二点和栈内存数组不同,在栈中数组的大小是常量表达式也就是在编译时就确定的,而堆中的数组是可以在程序运行时动态设定的。比如下图的数组个数是3,也可以是其它大小或大于0的整形表达式、变量等。make_unique模板函数是创建一个现代C++使用的唯一型智能指针。
      在这里插入图片描述

    5.向函数传递C风格数组

    • 数组标识符退化为指向第一个元素的指针
    • 问题:我们怎么知道数组的大小?
      注意:你是用double* x传递数组参数,还是用double x[]传递数组参数,两者没有不同实际都是退化为指针传递。
      在这里插入图片描述
      要知道向函数传递的数组参数的大小,C语言的典型的解决方法是再传递一个数组大小参数。
      在这里插入图片描述

    6.用STL库的copy算法复制数组

    一种是使用数组索引复制,一种是使用迭代器复制。
    使用迭代器的好处是:你不用关心数组的大小,只作用于数组标识符本身(而不是指针)!
    在这里插入图片描述
    在这里插入图片描述

    7.为什么要避免C风格数组

    • 不可深拷贝、可分配。(意思是,C风格数组标识符赋值给变量只是赋值了指针而无法进行深拷贝赋值,可分配的意思是在堆中创建C风格数组使用指针变量方式指向数组,指针变量是可以被再使用分配别的内存的,这时如果原内存没有释放则会造成内存泄漏。)
    • “退化”为指向第一个元素的指针。
    • 数组自己不知道大小。
    • 传递给函数不安全。在这里插入图片描述

    8.C语言风格的字符串

    • C风格的字符串是字符型的数组。
    • 字符串数组以’\0’字符作为结束,“\0”字符的值为0。
    • 字符串文本(字面值)"xyz"的类型是char const [ ] (只读字符串数组)
      在这里插入图片描述
      原文链接 原文
  • 相关阅读:
    Java开发自学教程!这里有份超全Java体系化进阶学习图谱
    Linux:进程的状态理解
    【Jmeter】基于JMeter开展性能测试(插件、监控、分布式压测)!
    JWT学习
    Pyecharts数据可视化(一)
    《最游记》游戏全套源码(源码+引擎+文档+客户端+服务端+工具)
    海外代理IP哪个可靠?如何测试代理的稳定性?
    使用jenkins+gitee创建docker镜像并运行
    [区间dp]Link with Bracket Sequence II 2022杭电多校第4场 1001
    Web前端接入Microsoft Azure AI文本翻译
  • 原文地址:https://blog.csdn.net/silencestarsky/article/details/139396977