zoukankan      html  css  js  c++  java
  • 从内存变化看.NET代码执行机理(三)

    1static void Main(string[] args)
     2{
     3person p;  //person为类并新建一个引用为p
     4p=new person(张三);  //新建一个实例-张三
     5p.name=李四;  //新建一个实例-李四
     6p=new person(王五);  //新建一个实例-王五
     7person p2;  //person为类并新建一个引用为p2
     8p2=new person(赵六);  //新建一个实例-赵六
     9p=p2;  //相互付值
    10p2=null;
    11p=null;
    12}

    以上伪代码表达的意思,在内存中的变化如下:
    运行第三行person p;  的时候,在栈中申请一块内存,名称为p,内容为空,假设地址为10336

    第四句运行后,在堆中申请一块内存,内存内容为"张三",堆中地址为8610.并把8610填充到栈中p的内容里.

    运行第五句代码,p.name=李四;表示在堆中地址8610里的内容由张三改为李四.

    继续运行第六句代码, p=new person(王五); 在堆中新申请一个内存,内容为王五,地址为13910,并替换掉栈中p的内容.
     
    运行第七句代码,person p2; 在栈中新申请一个内存,名称为p2,内容为空,地址为8861937.

    运行第八句p2=new person(赵六);在堆中申请一块新内存,内容为赵六,地址为1119,并填充栈中8861937的内容为1119.

    第九句p=p2 将栈8861937的内容刷到栈10336内,堆中13910由于失去栈中p的引用,被clr垃圾回收掉.

    第十句p2=null;则栈中8861937的内容清空.但堆中1119的内容仍然被栈10336所引用.

    十一句p=null;栈中10336内容清空,堆中1119的内容失去所有引用,被回收.


  • 相关阅读:
    设计模式---单例模式
    Linux介绍
    集合---Map
    集合---Collection
    JDK1.7中HashMap底层实现原理(转)
    算法面试题-用单向链表表示十进制整数,求两个正整数之和。1234+34=1268
    idea 常用插件
    ehcache配置log4j日志,或与spirng cache整合用注解形式,打印注解日志
    spring cache @CacheEvict 清除多个key
    tomcat源码及其下载版本
  • 原文地址:https://www.cnblogs.com/tommyli/p/1349694.html
Copyright © 2011-2022 走看看