当前位置: 首页 > news >正文

关于开发语言的一些效率 从堆栈角度理解一部分c java go python

关于开发语言的一些效率 从堆栈角度理解一部分

今天和朋友讨论,聊到一些开发语言上的问题,他总结了句句话 感觉挺有道理的,堆和栈是操作系统内存概念,cc++直接用系统堆栈,javago通过内存逃逸分析来确定哪些放到堆栈,python直接用堆,我后来和deepseek讨论了一下,分享出来 大家探讨

1. C/C++的情况

  • :确实直接使用系统栈。局部变量、函数调用栈帧等都由编译器自动管理。
  • :通过malloc/new手动分配堆内存,但严格来说:
    • C/C++运行时库会先向OS申请大块内存(如通过brk/sbrk或mmap)
    • 然后在此内存池中管理分配/释放,并非每次malloc都直接调用系统调用
  • 例外alloca函数可直接在栈上分配内存(但很少用)

2. Java的情况

  • 逃逸分析:确实存在,但只是JIT优化的手段之一(HotSpot默认开启)。对象分配逻辑是:
    1. 首选尝试栈上分配(若未逃逸)
    2. 次选TLAB(线程本地分配缓冲)
    3. 最后才是普通堆分配
  • 现实情况:大部分对象仍在堆上,因为:
    • 逃逸分析有成本,复杂对象可能放弃分析
    • 栈空间有限,大对象无法分配
  • 特殊类型:基本类型(int等)直接栈存储

3. Go的情况

  • 逃逸分析:编译器(非运行时)进行的静态分析,规则更明确:
    func foo() *int {x := 42  // 逃逸到堆(因为返回指针)return &x
    }
    
  • 优化特点
    • 相比Java,Go的逃逸分析更激进(如接口方法调用也可能导致逃逸)
    • 可通过-gcflags="-m"查看分析结果

4. Python的情况

  • 全部对象在堆:基本正确,但有重要细节:
    • 小整数等常用对象有内存池优化
    • PyPy等实现会尝试栈分配(类似JVM)
  • 栈的使用:Python解释器自身(用C写的)确实用系统栈执行字节码,但Python对象的存储全是堆内存

关键修正点:

  1. "直接用系统堆栈"的说法不准确

    • 现代语言运行时都有内存管理抽象层
    • 例如glibc的ptmalloc、JVM的G1/CMS等GC算法
  2. 语言实现差异

    • Java/Python等有虚拟机的语言,内存行为取决于具体实现(如J9 VM与HotSpot不同)
    • Go的逃逸分析发生在编译期,Java在JIT期
  3. 优化技术的局限性

    • 逃逸分析不是万能的,受代码复杂度和分析成本限制
    • 栈分配受栈大小限制(如Linux默认8MB栈)

更准确的说法应该是:

语言栈使用堆使用关键机制
C/C++直接系统栈通过运行时库管理堆手动内存管理
Java基本类型栈存储,对象可能栈分配主要对象存储区域逃逸分析+GC
Go值类型栈存储,逃逸对象转堆通过逃逸分析决定对象位置编译期逃逸分析
Python解释器用系统栈,对象全在堆所有对象存储在堆引用计数+GC

这些差异本质上反映了语言设计取舍:C/C++追求极致控制,Java/Go平衡安全与性能,Python优先开发效率。

http://www.dtcms.com/a/322446.html

相关文章:

  • nginx的安装
  • QML 鼠标穿透
  • 目标检测数据集 - 人脸佩戴检测数据集下载「包含VOC、COCO、YOLO三种格式」
  • 105-基于Flask的珍爱网相亲数据可视化分析系统
  • 深度学习图像分类数据集—七种虾病虫害分类
  • 制作 VSCode 插件
  • 2025华数杯B题一等奖方案:网络切片无线资源管理全解析(附Python/MATLAB代码)
  • 「iOS」————分类与扩展
  • Baumer高防护相机如何通过YoloV8深度学习模型实现火星陨石坑的检测识别(C#代码UI界面版)
  • rem:CSS中的相对长度单位
  • 从灵感枯竭到批量产出:无忧秘书创作平台如何重构内容生产者的工作流程?全环节赋能分析
  • Java基础-TCP通信单服务器接受多客户端
  • Pytorch模型复现笔记-FPN特征金字塔讲解+架构搭建(可直接copy运行)+冒烟测试
  • 强光干扰下误报率↓82%!陌讯多模态算法在睡岗检测的落地优化
  • 力扣 hot100 Day70
  • Linux高级编程-文件操作
  • 人类语义认知统一模型:融合脑科学与AI的突破
  • 工业场景反光衣识别准确率↑32%:陌讯多模态融合算法实战解析
  • Leetcode——556. 下一个更大元素 III
  • 重读《人件》Peopleware -(23)Ⅲ 适当人选 Ⅵ 乐在其中(下)
  • QT第三讲- 机制、宏、类库模块
  • 从免费到盈利:Coze智能体1小时封装变现全流程指南——井云科技
  • Spring Boot 2 集成 Redis 集群详解
  • 全栈:JDBC驱动版本和SQLserver版本是否有关系?怎么选择JDBC的版本号?
  • Spring 的原理探究
  • Java 大视界 -- Java 大数据在智能医疗手术机器人操作数据记录与性能评估中的应用(390)
  • 【Bluedroid】A2DP Sink音频焦点管理机制解析(update_audio_focus_state)
  • 【RabbitMQ】高级特性—事务、消息分发详解
  • 【n8n】学习n8n【10】:Github的项目n8n-workflows:本地安装2,053 个 n8n 工作流程集合:随时看随时抄/学习~
  • 基于开源AI大模型、AI智能名片与S2B2C商城小程序的零售智能化升级路径研究