C/C++基础----内存相关

news2024/12/26 10:35:16

malloc分配内存

用法

  • 参数为要开辟内存的大小(字节为单位)
  • 返回值为void*,所以要强转一下
  • 语法:
    malloc()
    
  • 动态开辟20个字节的内存,代码:
    #include <iostream>
    
    using namespace std;
    
    int main() {
        int *a = (int *) malloc(sizeof(int) * 5);
        a[0] = 111;
        a[1] = 222;
        a[2] = 333;
        a[3] = 444;
        a[4] = 555;
        for (int i = 0; i < 5; i++)
            cout << a[i] << endl;
        return 0;
    }
    

开辟完内存不赋值里面的值

  • 如果用malloc开辟完内存不初始化值,里面的值就会是乱七八糟的。

    #include <iostream>
    
    using namespace std;
    
    int main() {
        int *a = (int *) malloc(5 * sizeof(int));
        if (a == nullptr) {
            cout << "内存分配失败!" << endl;
        } else {
            cout << a[0] << endl;
            cout << a[1] << endl;
            cout << a[2] << endl;
            cout << a[3] << endl;
            cout << a[4] << endl;
        }
        return 0;
    }
    

    在这里插入图片描述

内存开辟失败

  • 如果内存开辟失败则返回0
  • c++中的nullptr来判断一个指针是不是空指针,但是在c中不能用,在c中只能判断是不是0
    #include <iostream>
    
    using namespace std;
    
    int main() {
        int *a = (int *) malloc(sizeof(int) * 9999999999999999999);
        cout << a << endl;
        if (a == nullptr) {
            cout << "内存开辟失败!" << endl;
        }
        return 0;
    }
    
    在这里插入图片描述

使用完清空内存

  • free()方法清空分配的内存
    #include <iostream>
    
    using namespace std;
    
    int main() {
        int *a = (int *) malloc(sizeof(int) * 1);
        if (a == nullptr) {
            cout << "内存开辟失败!" << endl;
        } else {
            *a = 200;
            cout << "开辟的内存地址:" << a << endl;
            cout << "a的值:" << *a << endl;
            free(a);
            cout << "清空内存后a的值:" << *a << endl;
        }
        return 0;
    }
    
    在这里插入图片描述

calloc分配内存

用法和清空内存

  • 返回值、清空内存和判断是否空指针用法和malloc一样

  • 语法:

    calloc(开辟内存的个数,单个的大小)
    
    #include <iostream>
    
    using namespace std;
    
    int main() {
        int *a = (int *) calloc(10, sizeof(int));
        if (a == nullptr) {
            cout << "内存分配失败!" << endl;
        } else {
            *a = 200;
            cout << *a << endl;
            free(a);
            cout << *a << endl;
    
        }
        return 0;
    }
    

    在这里插入图片描述

开辟完内存不初始化和malloc不同

  • 都初始化为了0

    #include <iostream>
    
    using namespace std;
    
    int main() {
        int *a = (int *) calloc(10, sizeof(int));
        if (a == nullptr) {
            cout << "内存分配失败!" << endl;
        } else {
            cout << a[0] << endl;
            cout << a[1] << endl;
            cout << a[2] << endl;
    
        }
        return 0;
    }
    

    在这里插入图片描述


realloc重新分配内存

用法和清空内存

  • 返回值、清空内存用法和malloc一样

  • 开辟出的内存不赋值类似于malloc,值都是乱七八糟的

  • 重新分配内存空间时,之前指针里面的值不会变,相当于把之前指针中德内容复制过来了。

    realloc(原内存地址,重新分配的大小(单位为字节))
    
  • 重新分配后,原指针首地址可能会变可能不会变

    #include <iostream>
    
    using namespace std;
    
    int main() {
        int *a = (int *) calloc(5, sizeof(int));
        if (a == nullptr) {
            cout << "内存分配失败!" << endl;
        } else {
            a[0] = 111;
            cout << "未重新分配时a的地址:" << &a[0] << endl;
            a = (int *) realloc(a, 10 * sizeof(int));
            cout << "重新分配时a的地址:" << &a[0] << endl;
            cout << a[0] << endl;
    
    
        }
        return 0;
    }
    

    在这里插入图片描述
    在这里插入图片描述


new 关键字分配内存

用法

  • 清空内存使用delete 指针 如果是数组使用delete[] 指针

  • 开辟内存后不初始化和malloc一样,值乱七八糟

    #include <iostream>
    
    using namespace std;
    
    int main() {
        int *a = new int[5];
        cout << a << endl;
        a[0] = 11;
        a[1] = 22;
        a[2] = 33;
        a[3] = 44;
        a[4] = 55;
        for (int i = 0; i < 5; i++) {
            cout << a[i] << endl;
        }
        delete[] a;
        cout << a[1] << endl;
        return 0;
    }
    

    在这里插入图片描述

内存分配失败时抛出一个异常

在这里插入图片描述


memcpy复制内存

用法

  • 可以全部复制也可以复制一部分
memcpy(要复制到哪的内存地址,复制的内存地址,要复制的长度)
#include <iostream>

using namespace std;

int main() {
    bool flag = false;
    int *p_a = new int[5];
    int *p_b = new int[10];
    p_a[0] = 11;
    p_a[1] = 22;
    p_a[2] = 33;
    p_a[3] = 44;
    p_a[4] = 55;
    memcpy(p_b, p_a, 5 * sizeof(int));
    cout << p_b << endl;
    for (int i = 0; i < 10; i++) {
        if (i > 4 and !flag) {
            cout << "---------" << endl;
            flag = true;
        }
        cout << p_b[i] << endl;
    }
    return 0;
}

在这里插入图片描述

  • 展示一下new int开辟内存未赋值下的值乱七八糟。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1605153.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

利用常量数组解码的方法

【题目描述】 把手放在键盘上时&#xff0c;稍不注意就会往右错一位。这样&#xff0c;输入Q会变成输入W&#xff0c;输入J会变成输入K等。键盘如图所示。 输入错位后敲出的几行字符串&#xff0c;输出打字员本来想打出的句子。 输入仅包含数字、空格、大写字母或标点符号&am…

笔试题4 -- 除2!(k次机会偶数除2求最小和)

除2&#xff01;(k次机会偶数除2求最小和) 文章目录 除2&#xff01;(k次机会偶数除2求最小和)读懂题目方案一&#xff08;基于multiset实现 -- 超时&#xff09;方案二&#xff08;改进算法--基于 priority_queue 实现&#xff09;总结 题目链接&#xff1a; 除2&#xff01;…

【优质书籍推荐】《Effective Java》是人工智能的基石

大家好&#xff0c;我是爱编程的喵喵。双985硕士毕业&#xff0c;现担任全栈工程师一职&#xff0c;热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。…

3D可视化技术:研发基地的科技新篇章

在科技日新月异的今天&#xff0c;我们生活在一个充满无限可能性的时代。而在这个时代中&#xff0c;3D可视化技术正以其独特的魅力&#xff0c;引领着科技领域的新一轮变革。 3D可视化技术通过三维图像的方式&#xff0c;将现实世界或虚拟世界中的物体、场景等以立体、逼真的形…

FileZilla安装下载与使用

实用工具系列 - FileZilla安装下载与使用_filezilla下载-CSDN博客文章浏览阅读4.4k次&#xff0c;点赞112次&#xff0c;收藏113次。一、概述二、下载三、安装四、使用教程_filezilla下载https://blog.csdn.net/Passerby_Wang/article/details/125298958?ops_request_misc%257…

湖仓一体(Lakehouse)架构的核心组件之存储层——Lakehouse 架构(三)

文章目录 前言Lakehouse 存储关键概念行存储与列存储基于存储的查询性能优化 Lakehouse 存储组件云储存文件格式Apache ParquetApache ORCApache Avro相似点和差异点 表格格式Apache HiveIceberg特性和优点 Apache Hudi特性和优点 Delta Lake特性和优点 相似点和差异点 总结 前…

抓住2024必应Bing国内广告推广的获客流量红利期

线上广告已成为企业获取客户流量的重要手段&#xff0c;作为全球领先的搜索引擎之一&#xff0c;必应Bing在国内市场拥有庞大的用户群体&#xff0c;为企业提供了一个宝贵的广告推广平台。展望2024年&#xff0c;必应Bing国内广告推广预计将进入一个获客流量的红利期&#xff0…

C语言知识(1) static修饰详解分享

1.前言 哈喽大家好啊&#xff0c;今天来给大家分享c中static的使用&#xff0c;希望能对大家有所帮助&#xff0c;请大家多多点赞&#xff0c;收藏支持我哦~ 2.正文 在讲解static之前&#xff0c;先给大家铺垫三个概念&#xff0c;方便大家理解。 2.1三则知识铺垫 2.1.1作…

Windows突然蓝屏解决办法

Windows突然蓝屏&#xff0c;然后重复开机没有用&#xff0c;但是能进入bios系统&#xff0c;证明内存和磁盘没事&#xff0c;用大白菜制作了PE系统盘制作过程&#xff08;之前一直都是用官方镜像制作&#xff0c;但是发现用大白菜制作可以对系统之前的磁盘里面重要的信息拷贝到…

Pixverse:开启文生视频与图生视频新纪元

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…

“广进计划”中的特斯拉,加码驱动Robotaxi能否迎来新未来?

近期&#xff0c;特斯拉可以说是热搜上的常驻选手。 公司先是透露将于8月8日推出自动驾驶出租车Robotaxi&#xff0c;再是宣布将开启“广进计划”&#xff0c;在全球范围内裁员10%。官方资料显示&#xff0c;截至2023年末&#xff0c;特斯拉全球拥有超14万名员工&#xff0c;此…

OpenVINO安装教程 Anaconda版

从 Conda Forge 安装 OpenVINO™ Runtime 请注意&#xff0c;Conda Forge 发行版&#xff1a; 提供 C/C 和 Python API 不支持 NPU 推理 专用于所有主要操作系统的用户&#xff1a;Windows、Linux 和 macOS &#xff08;所有 x86_64 / ARM64 架构&#xff09; 使用 Anaconda…

CSS导读 (CSS的三大特性 上)

&#xff08;大家好&#xff0c;今天我们将继续来学习CSS的相关知识&#xff0c;大家可以在评论区进行互动答疑哦~加油&#xff01;&#x1f495;&#xff09; 目录 五、CSS的三大特性 5.1 层叠性 5.2 继承性 5.2.1 行高的继承 5.3 优先级 小练习 五、CSS的三大特性 …

Windows电脑上能用的便签记事软件

上班族大多都依赖电脑进行办公&#xff0c;他们在电脑上完成各式各样的工作任务。因此&#xff0c;下载并安装高效率的软件成了提升工作效率的关键。其中&#xff0c;一款好的便签软件能够极大地帮助他们管理和跟踪任务。那么&#xff0c;有没有一款适合在电脑上使用的出色的便…

【c语言】自定义类型:结构体详解

目录 自定义类型&#xff1a;结构体 结构体类型的声明 结构体变量的创建和初始化 结构的特殊声明 结构的自引用 结构体内存对齐 对其规则 为什么存在内存对齐&#xff1f; 修改默认对⻬数 结构体传参 结构体实现位段 位段的内存分配 位段的跨平台问题 位段的应用…

github克隆报错:failed: The TLS connection was non-properly terminated.

github克隆gazebo_ros_control报错 fatal: unable to access https://github.com/ros-controls/gazebo_ros_control.git/: gnutls_handshake() failed: The TLS connection was non-properly terminated. sudo apt-get install ros-noetic-gazebo-ros-control git 克隆gazeb…

超越GPT-4V,苹果多模态大模型上新,神经形态计算加速MLLM(二)

上文介绍基于MINOnets神经网络架构加速多模态大模型的策略&#xff0c;本文将以Spinnaker2多核神经网络芯片EGRU架构为起点&#xff0c;覆盖存内计算架构&#xff0c;介绍新型计算架构在加速大模型推理的作用。SpiNNaker 2是一个设计用于大规模异步处理的多核神经形态芯片&…

如何封装Vue组件并上传到npm

前言 环境准备 1.注册npm账号&#xff1a;npm | Home (npmjs.com) 2.保证当前环境安装了vue、webpack、node&#xff0c;以下工作将在该环境下进行&#xff08;没有的小伙伴自行百度安装哈~&#xff09; 3.一下用到的环境版本 webpack&#xff1a;v5.1.4node&#xff1a;v…

每日一题---OJ题: 旋转数组

片头 嗨! 小伙伴们,咱们又见面啦,今天我们一起来学习一道OJ题---旋转数组 emmm,看上去好像没有那么难,我们一起来分析分析 比如: 数组里面有7个元素,分别为 1, 2, 3, 4, 5, 6, 7 , 现在我们将数组中的元素向右轮转3个位置 第一次轮转:将最后一个元素"7"放在第一个…

【spring】@Resource注解学习

Resource介绍 在Spring框架中&#xff0c;Resource 注解是一个JSR-250标准注解&#xff0c;用于自动装配&#xff08;autowiring&#xff09;Spring容器中的bean。Resource 注解可以用于字段、方法和方法参数上&#xff0c;以声明依赖注入。 Resource源码 Target({TYPE, FIE…