dotnet学习笔记一 - 装箱拆箱

.NET Framework学习总结 专栏收录该内容
5 篇文章 0 订阅

转眼作程序员已经四年了,自己也算是这一行的老人了。回头看看,自己做过的东西不算少,从应用程序到内核驱动,从普通程序到Web应用,从WindowsLinux。市面上流行的开发工具语言也都用过,VCVBDELPHIBCBJBUILDERASPJSP。不过扪心自问,那些是自己专长的呢?好像没有,找工作的时候也是项目作了不少,算得上精通的,好像没有。.NET以前也接触过,但是没有深入,前一段时间由于一段机缘,对.NET产生了喜欢之情,好强大,C#也是很规整的OO语言。再加上自己对WIN平台的多年的感情,决定投入到轰轰烈烈的.NET事业中去。书看过了需要消化和实践,自己感觉把理解的东西写出来是很好的一种消化方法,就萌生了把自己看得东西写成一套学习笔记的想法。这篇是开篇,抛砖引玉,希望各位.NET界的师兄元老们多多指点,希望和和我一样立志于学习应用.NET技术的朋友们一起讨论,一起提高。

.NET算是集现有开发平台语言之大成了,也提出了不少新概念。装箱(boxing)和拆箱(unboxing)应该是一个了。

.NET的所有类型都是由基类System.Object继承过来的,包括最常用的基础类型:int, byte, shortbool等等,就是说所有的事物都是对象。但这样造成了及底的效率,比如简单的两个数相加,bool取反都会导致从堆(Heap)中分配内存。怎样解决这个问题呢?.NET把类型分成了两类:值型和引用型。

值型在栈中分配内存,它们在声明的同时就初始化,以确保数据不为NULL。例如:

byte b = 33;

上边的声明就在栈中分配了8位的内存,并将变量初始化为8.NET的值型包括枚举(enum),结构(structure)和基本类型(int, float, short等)。值型不需要Garbage Collection来回收占用的内存。超出了作用范围后,系统会自动释放。

引用型就完全类似于c++或者java中的类了,在堆中分配内存,初始化为null。引用型是需要Garbage Collection来回收内存的。

既然值型也是从System.Object中继承过来的,那么这样一句话就应该是合法的:

int n=3;

System.Object obj = n;

正如上面所说,n这个变量的内存应该是在栈中分配内存,而obj则应该在栈中分配内存。这时候系统都作了哪些工作呢?系统在堆中分配了一个对象obj,并将n的值复制给它。这就叫做装箱(boxing。这时候n obj就是两个没有关联的对象了,继续运行如下的代码:

obj = 9;

Console.WriteLine( “{0}{1}”, n, obj );

得到的结果就是:

39

简单的说装箱就是隐式的将一个值型转换为引用型对象。

和装箱对应的就是拆箱了,拆箱(unboxing就是将一个引用型对象转换成任意的值型。与装箱不同,拆箱是显示的操作。如下面的代码:

int i=0;

System.Object obj = i;

int j=(int)obj;

由此可见.NET的类型系统是统一的类型系统,因为不管是值型还是引用型都被看作对象,这样就允许我们可以使用一致的方式跨代码处理类型。看一看下面的一段代码更能清楚地了解装箱的好处:

ArrayList ar = new ArrayList();

Date dt = new Date();

ar.Add( dt );

 

int n = 10;

ar.Add( n );

正如最好两行代码,我们不用显示的分配一个System.Object,或者做强制的类型转换。只要用我们最常用到的int就可以和其他的引用型对象一样处理了。在最后一行代码中,当n加入到数组中时,它已经被自动的装箱了。

 

  • 0
    点赞
  • 1
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
<p> <span style="font-size:14px;color:#337FE5;">【为什么学爬虫?】</span> </p> <p> <span style="font-size:14px;">       1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到!</span> </p> <p> <span style="font-size:14px;">       2、如果是作为个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站</span> </p> <p> <br /> </p> <span style="font-size:14px;color:#337FE5;">【课程设计】</span> <p class="ql-long-10663260"> <span> </span> </p> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: </p> <ol> <li class="" style="font-size:11pt;color:#494949;"> 网络请求:模拟浏览器的行为从网上抓取数据。 </li> <li class="" style="font-size:11pt;color:#494949;"> 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 </li> <li class="" style="font-size:11pt;color:#494949;"> 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 </li> </ol> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: </p> <ol> <li class="" style="font-size:11pt;color:#494949;"> 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 </li> <li class="" style="font-size:11pt;color:#494949;"> Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 </li> </ol> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 </p> <p style="font-size:11pt;color:#494949;">   </p> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! </p> <p class="ql-long-26664262" style="font-size:11pt;color:#494949;"> <br /> </p> <p> <br /> </p> <p> <span style="font-size:14px;background-color:#FFFFFF;color:#337FE5;">【课程服务】</span> </p> <p> <span style="font-size:14px;">专属付费社群+定期答疑</span> </p> <p> <br /> </p> <p class="ql-long-24357476"> <span style="font-size:16px;"><br /> </span> </p> <p> <br /> </p> <p class="ql-long-24357476"> <span style="font-size:16px;"></span> </p>
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值