C++程序代码的内存结构分析

C++程序内部的结构,同C程序的内部结构,也是分段的,一般分为代码段、堆、栈、数据段等。可以通过下面的代码来证明:

CClassAddress.hpp 文件:

#ifndef CClassAddress_hpp
#define CClassAddress_hpp

class CClassAddress
{
public:
    CClassAddress();
    int getNum1();
    void setNum1(int a);

private:
    int mPrvNum1;
public:
    char mPubChar1;
};

#endif /* CClassAddress_hpp */

 

CClassAddress.cpp文件:

#include "CClassAddress.hpp"
#include <iostream>

using namespace std;

CClassAddress::CClassAddress()
{
    cout << __FILE__ << ":" << __LINE__ <<":"<<__FUNCTION__<<"\tlocation is\t"<<(void*)&(__FUNCTION__)<<endl;
    mPrvNum1=0;
    mPubChar1=0;
}

int CClassAddress::getNum1()
{
    cout << __FILE__ << ":" << __LINE__ <<":"<<__FUNCTION__<<"\tlocation is\t"<<(void*)&(__FUNCTION__)<<endl;
    cout<<"mPrvNum1 location is\t"<<(void*)&(mPrvNum1)<<endl;
    return mPrvNum1;
}

void CClassAddress::setNum1(int a)
{
    cout << __FILE__ << ":" << __LINE__ <<":"<<__FUNCTION__<<"\tlocation is "<<(void*)&(__FUNCTION__)<<endl;
    this->mPrvNum1 = a;
}

 

main文件:

#include "CClassAddress.hpp"
#include <iostream>

int main(int argc, const char * argv[]) {
    std::cout<<__FILE__ << ":" << __LINE__<<":"<<__FUNCTION__ << "\t"<<(void*)&__FUNCTION__<<endl;

    CClassAddress classAdd;
    cout << __FILE__ << ":" << __LINE__ << ":" <<"local classAdd: location is\t"<< (void*)&classAdd << endl;
    classAdd.setNum1(10);
    int a = classAdd.getNum1();
    cout << __FILE__ << ":" << __LINE__ << ":" <<"local a: location is\t"<< (void*)&a << endl;
    cout << __FILE__ << ":" << __LINE__ << ":" <<"public classAdd.mPubChar1: location is\t"<< (void*)&classAdd.mPubChar1 << endl;

    static int sIntA=10;
    cout << __FILE__ << ":" << __LINE__ << ":" <<"static int sIntA: location is\t"<< (void*)&sIntA << endl;

    cout<<"================="<<endl;
    CClassAddress *p_classAdd = new CClassAddress();
    cout << __FILE__ << ":" << __LINE__ << ":" <<"local *p_classAdd: location is\t"<< (void*)&p_classAdd << endl;
    cout << __FILE__ << ":" << __LINE__ << ":" <<"local &(*p_classAdd): location is\t"<< &(*p_classAdd) << endl;
    p_classAdd->setNum1(11);
    p_classAdd->getNum1();
    cout << __FILE__ << ":" << __LINE__ << ":" <<"public p_classAdd->mPubChar1: location is\t"<< (void*)&(p_classAdd->mPubChar1) << endl;
    delete p_classAdd;
    return 0;
}

 

程序的执行结果:
/Users/huGuohua/xcode/cpp_study/cpp_study/main.cpp:167:main    0x1000235a2
/Users/huGuohua/xcode/cpp_study/cpp_study/CClassAddress.cpp:16:CClassAddress    location is    0x1000236dd
/Users/huGuohua/xcode/cpp_study/cpp_study/main.cpp:170:local classAdd: location is    0x7ffeefbff438
/Users/huGuohua/xcode/cpp_study/cpp_study/CClassAddress.cpp:30:setNum1    location is 0x100023717
/Users/huGuohua/xcode/cpp_study/cpp_study/CClassAddress.cpp:23:getNum1    location is    0x1000236f9
mPrvNum1 location is    0x7ffeefbff438
/Users/huGuohua/xcode/cpp_study/cpp_study/main.cpp:173:local a: location is    0x7ffeefbff434
/Users/huGuohua/xcode/cpp_study/cpp_study/main.cpp:174:public classAdd.mPubChar1: location is    0x7ffeefbff43c
/Users/huGuohua/xcode/cpp_study/cpp_study/main.cpp:177:static int sIntA: location is    0x100024350
=================
/Users/huGuohua/xcode/cpp_study/cpp_study/CClassAddress.cpp:16:CClassAddress    location is    0x1000236dd
/Users/huGuohua/xcode/cpp_study/cpp_study/main.cpp:181:local *p_classAdd: location is    0x7ffeefbff428
/Users/huGuohua/xcode/cpp_study/cpp_study/main.cpp:182:local &(*p_classAdd): location is    0x1039110a0
/Users/huGuohua/xcode/cpp_study/cpp_study/CClassAddress.cpp:30:setNum1    location is 0x100023717
/Users/huGuohua/xcode/cpp_study/cpp_study/CClassAddress.cpp:23:getNum1    location is    0x1000236f9
mPrvNum1 location is    0x1039110a0
/Users/huGuohua/xcode/cpp_study/cpp_study/main.cpp:185:public p_classAdd->mPubChar1: location is    0x1039110a4
Program ended with exit code: 0

根据以上的结果,可以发现如下规律:
不管是main函数还是类内部的函数,地址在一起,放在代码段的;
不管是普通函数中的变量还是类中的变量,地址在一起,放在栈段的;
static的的变量,地址放在全局变量的数据段;
如果一个对象是用new创建的,他的数据放在堆中;

这就是内存中的进程的几个段:
代码段存放可执行代码、字符串常量、常量数据;
数据段存放已初始化全局变量、静态变量;
栈存放局部变量、函数参数;
堆是用来动态内存分配的;

由此可见:
C和C++的区别,只是从开发人员的角度来看,他的代码是不同,在内存中的结构是完全一样的。如果把类名和域运算符和成员函数看成一个整体,那么C++的代码,就是C结构的面向过程的了。

 

原文地址:https://blog.csdn.net/hawanglc/article/details/115244396

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


在有效期内的苹果开发者账号(类型为个人或者公司账号)。还有一种情况,就是你的Apple ID被添加到公司开发者账号团队里面,这样也是可以的,但是需要叫管理员给你开通相应的账号权限,如下截图:这里可能有些同学会问,苹果开发者账号是什么?如何申请?那么可以看看我的上一篇文章:iOS苹果开发者账号(公司账号)申请流程详解能正常编译打包的iOS工程项目(都不能正常编译谈何出包上架
Appuploader官网--IOS ipa上传发布工具,证书制作工具跨平台版,windows,linux,mac系统都可用 (applicationloader.net)第一步:注册苹果开发者账号,访问以下网址,按照提示注册即可,因为不需要支付688认证苹果开发者,所以没什么好讲的。证书部分:主要是通过工具生成.p12证书文件,后面这个证书要导入mac系统。描述文件:这个文件主要包含了证书,公钥,设备信息等,具体可以百度了解详情。第三步:使用xcode打包导出ipa文件,供其他人内测。..........
苹果在9月13号凌晨(北京时间)发布 iOS 16,该系统的设备可能会因为各种原因,导致功能不可用和UI错乱等问题,我们需要做好适配iOS 16。
计算机图形学--OpenGL递归实现光线追踪
Xcode 14打出来的包在低版本系统运行时会崩溃,报错信息是Library not loaded: /usr/lib/swift/libswiftCoreGraphics.dylib,在苹果开发者论坛搜索报错信息,可以看到会闪退的最高版本是iOS12.1(不敢肯定,毕竟我没测过,不过肯定低于iOS 12.4
iOS16手机开启开发者模式 "developer mode disable"Pod工程中的Bundle target签名报错
【计算机图形学】【实验报告】DDA画线算法、Bresenham中点画线算法、多边形填充算法(附代码)
iOS 16 满载全新的个性化功能、更具深度的智能技术,以及更多无缝的沟通与共享方式,让 iPhone 的体验更进一步。13、隐私权限增强,如通过 UIDevice 获取设备名称时,无法获取用户的信息,只能获取设备对应的名称。
3、回到苹果开发者中心,如下图,点击certificates,点蓝色小加号,就可以开始创建证书,创建证书的时候无论测试还是上传app store打包,都要选ios distribution app store and adhoc,不要选apple和develpment类型的证书。2、如下图,点左边的profiles菜单,点击蓝色加号,创建描述文件,创建过程中会要求我们选择描述文件的类型,假如你想发布app到app store,则选择app store,假如你想真机测试,则选择ad hoc类型。
需要:Unity,IOS平台模块,Xcode,IOS_SDk,MAC电脑,Iphone手机
最近下载安装 xcode 并解压安装,遇到一些问题误以为是错误,记录在此。从百度和谷歌上搜了很多帖子,发现并没有靠谱的 xcode 国内的镜像,这里提供一个可以跳转到官网的下载方式。xcode 不同版本的列表,下载时注意不同 macOs 不同的系统和 Xcode 版本的对应关系。如 要求 及其以上版本。https://xcodereleases.com/注意点击后会跳到官方下载地址,需要登录苹果账号。xcode 文件很大,通常要 10G 以上,下载速度很慢。可以考虑使用 Free Downlo
使用苹果登录作为第三方登录
missing xcrun at: /Library/Developer/CommandLineTools/usr/bin/xcrun解决方法
Xcode14 正式版编译报错' does not contain bitcode.You must rebuild it with bitcode enabled (Xcode setting ENABLE_BITCODE), obtain an updated library from the vendor, or disable bitcode for this target. file 'xxx' for architecture arm64解决方案
那应该和升级Xcode 14有关系。但是官方还没有给出解决方案。应该后续会有兼容的cocoapods 新版本。
项目中需要用到Xcode将C++代码输出的Mac版本的DLL文件即DYLIB文件,并能够使用C#代码调用。Unity与 DLL文件 ☀️| 怎样使用VC++生成一个DLL文件并调用!这次来看一下在Mac使用Xcode生成的方法吧!本文介绍了在Mac中怎样使用 Xcode项目使用C++生成 .dylib文件的方法。相对于在Windows中使用AndroidStudio创建动态链接库的方法来说,使用Xcode创建.dylib文件确实简单了很多。