C#基础 (一)
值类型和引用类型
堆和栈
栈存放的数据:
(1)某些类型变量的值
(2)程序当前的执行环境
(3)传递给方法的参数
堆是存放对象的地方
对象类型有两种: 值类型和引用类型,他们的存储方式不同
值类型: 只需要一段单独的内存,用于存储实际的数据
引用类型: 需要两端内存
(1)存储实际的数据,它总是位于堆中
(2)第二段是引用,指向数据在堆中的存放位置
从上图也可以看到栈中既可以放引用也可以放数据.
假若引用类型里面,持有另外一个引用类型和值类型的对象,那么它的存储方式又是怎么样的呢?如下图
值传递
值参数
目前调用方法默认的值参数,调用方法的时候进行的操作如下:
(1)在栈中为形参分配空间
(2)将实参的值复制给形参
看下面的例子
class Program
{ public static void MyMethod(MyClass myClass,int f2)
{
myClass.val = myClass.val + 5;
f2 = f2 + 5;
Console.WriteLine(string.Format("方法内: myClass.val = {0} , f2 = {1}",myClass.val,f2));
} private static void Main()
{
MyClass class1 = new MyClass();
int num = 10;
MyMethod(class1,num);
Console.WriteLine(string.Format("方法外: myClass.val = {0} , num = {1}", class1.val, num));
Console.ReadKey();
} } class MyClass
{
public int val = 20;
}
上图就可以知道值参数实际上复制了形参。
引用参数
不会为形参在栈中分配内存, 形参的参数名将作为实参变量的别名,指向相同的内存位置传入方法的形参,有out 类型的,或是ref 类型,前者是结束方法时必须为变量赋值,后者是变量在传入方法是个引用,这两个关键字的区别见下面两张图, ref 的引用在栈中本身就存在, 而out 存在而没有被赋值,
输出参数
输入参数
class Program
{ public static void MyMethod(MyClass myClass,ref int f2)
{
myClass.val = myClass.val + 5;
f2 = f2 + 5;
Console.WriteLine(string.Format("方法内: myClass.val = {0} , f2 = {1}",myClass.val,f2));
} private static void Main()
{
MyClass class1 = new MyClass();
int num = 10;
MyMethod(class1,ref num);
Console.WriteLine(string.Format("方法外: myClass.val = {0} , num = {1}", class1.val, num));
Console.ReadKey();
} } class MyClass
{
public int val = 20;
}
注意: 可以知道值参数,由于复制了一份,所以栈中会多一份数据,引用参数则不一样,栈中数据不变,只是数据的多了一个别名。
栈帧(stack frame)
即是方法里调用方法,每一层的调用就为一个stack frame stack frame 保存的东西有:
(1)返回地址,即方法退出的时候继续执行的位置
(2)方法的值参数,
(3)各种和方法调用相关的其他管理数据项
C#基础 (一)的更多相关文章
- java基础集合经典训练题
第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...
- node-webkit 环境搭建与基础demo
首先去github上面下载(地址),具体更具自己的系统,我的是windows,这里只给出windows的做法 下载windows x64版本 下载之后解压,得到以下东西 为了方便,我们直接在这个目录中 ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- Golang, 以17个简短代码片段,切底弄懂 channel 基础
(原创出处为本博客:http://www.cnblogs.com/linguanh/) 前序: 因为打算自己搞个基于Golang的IM服务器,所以复习了下之前一直没怎么使用的协程.管道等高并发编程知识 ...
- [C#] C# 基础回顾 - 匿名方法
C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...
- HTTPS 互联网世界的安全基础
近一年公司在努力推进全站的 HTTPS 化,作为负责应用系统的我们,在配合这个趋势的过程中,顺便也就想去搞清楚 HTTP 后面的这个 S 到底是个什么含义?有什么作用?带来了哪些影响?毕竟以前也就只是 ...
- Swift与C#的基础语法比较
背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...
- .NetCore MVC中的路由(1)路由配置基础
.NetCore MVC中的路由(1)路由配置基础 0x00 路由在MVC中起到的作用 前段时间一直忙于别的事情,终于搞定了继续学习.NetCore.这次学习的主题是MVC中的路由.路由是所有MVC框 ...
- .NET基础拾遗(5)多线程开发基础
Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理基础 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开 ...
- .NET 基础 一步步 一幕幕[面向对象之方法、方法的重载、方法的重写、方法的递归]
方法.方法的重载.方法的重写.方法的递归 方法: 将一堆代码进行重用的一种机制. 语法: [访问修饰符] 返回类型 <方法名>(参数列表){ 方法主体: } 返回值类型:如果不需要写返回值 ...
随机推荐
- 实验1 C语言运行环境的使用和数据类型、运算符和表达式
Part1 这一部分的内容虽然简单,但是对于初学的我来说,独自完成且没有错误还是不容易的,像老师说的一样,只有自己亲手编写以后才可以发现问题并且逐步改正.从这次实践我对与C语言程序的结构更加熟悉. ...
- luoguP3702 [SDOI2017]序列计数
https://www.luogu.org/problemnew/show/P3702 题目让我们在 $ [1, m] $ 从中选出 $ n $ 个数,当中要有 > $ 0 $ 个质数,和是 $ ...
- [AIR] AS3读取本地文件夹中的文件
import flash.filesystem.File; import flash.net.URLLoader; //var dir:File = File.desktopDirectory; // ...
- C# 服务端推送,十步十分钟,从注册到推送成功
目标 展示 C# 服务端集成极光推送的步骤,多图少字,有图有真相. 使用极光推送, C# 服务端推送到 Demo App,Android 手机收到推送,整理为十个步骤,使用十分钟左右,完成从注册账号到 ...
- consul部署多台Docker集群
Consul 最近在学习Ocelot,发现里面集成Consul,所有部署一下多机版集群,后来发现网上都是在一台虚拟机中的Docker部署,而且大同小异,没有真正解释清楚. 前提准备 4台Centos虚 ...
- Kettle配合Windows执行计划实现定时实行作业
一般作业做好后需要做成定时任务,Kettle可以借助Windows的执行计划来完成.那么可以通过写批处理的方式让执行计划来调用. 其中Kitchen和Pan都可以做定时执行,一个是针对作业,一个是针对 ...
- GPUImage处理图片(滤镜)
GPUImage 是基于 GPU 处理图像的一个开源库, 提供了各种图像处理滤镜,例如调 亮度/饱和度/曝光度/白平衡/锐化等滤镜. 并且支持照相机/摄像机 的实时滤镜. GPUImage采用链式方式 ...
- SQL语句之数据库操作
SQL语句系列 1.SQL语句之行操作 2.SQL语句之表操作 3.SQL语句之数据库操作 4.SQL语句之用户管理 占坑,带写……
- fastdfs-client-java操作fastdfs
一.在https://github.com/happyfish100/fastdfs-client-java 下载客户端,解压后并执行ant命令,在E:\tools\libs\fastdfs\fast ...
- mysql里面 limit的奇效
项目里面有遇到一个需求,查询一个表,先group by ,再按group 的count(*)进行倒序,取出每个group里面发表时间最新的一个纪录,之前的同事SQL是这样写的 SELECT * FRO ...