C#基础—不安全代码(unsafe code)

1.为什么要有unsafe程序员

    也许是为了实现CLR类型安全的目标吧,默认状况下,C#没有提供指针的使用算法,可是有些状况下也可能须要指针这样直接访问内存的东西(虽然目前我尚未用过),可是有时候程序员很是清楚程序的运行情况,须要使用指针直接访问内存以便于提升性能或者调试、监控程序运行的内存的使用情况,以便于采起相应的措施。还有一些状况是当咱们须要调用外面DLL中的函数又不能使用DllImport 时,也须要指针来传递这些函数。算法

2.unsafe 的定义安全

    MSDN:unsafe 关键字表示不安全上下文,该上下文是任何涉及指针的操做所必需的。函数

    其实,意思就是要使用指针前,请用unsafe 声明下,可使类、方法,成员,类全局变量和代码段,但不能修饰成员函数内部的局部变量,具体为何不清楚,还望大神指点。性能

  在使用unsafe以前,咱们必须先看一段MSDN的话:在公共语言运行时 (CLR) 中,不安全代码是指没法验证的代码。 C# 中的不安全代码不必定是危险的;只是其安全性没法由 CLR 进行验证的代码。 所以,CLR 只对在彻底受信任的程序集中的不安全代码执行操做。 若是使用不安全代码,由您负责确保您的代码不会引发安全风险或指针错误。操作系统

    所以,咱们在运行unsafe 代码是要在项目属性-生成选项里配置下"容许运行不安全代码"。先看下简单的例子:指针

unsafe static void ChangeValue(int* pData)
{
   *pData = 200; //修改所在地址值
}调试


unsafe static void Main()
{
   int data = 100;
  Console.WriteLine("原始值: {0}", data);
  ChangeValue(&data); //取data地址并传递
  Console.WriteLine("改变地址后: {0}", data);内存

  Console.ReadLine();
}it

程序输出:  原始值:100 ;  修改地址后:200

 

三、引入fixed

      当咱们讨论fixed的时候,不得不先了解下,托管代码和非托管代码,所谓托管代码就是由CLR去执行的代码而不是操做系统去执行的代码,而非托管代码就是绕过CLR,由操做系统直接执行,它有本身的垃圾回收、类型安全检查等服务。

      而不安全代码就是容许本身使用指针访问内存,但同时又要使用CLR提供的垃圾回收机制、类型安全检查等服务,有的资料认为是介于CLR和非托管代码之间的一种代码运行机制,也能够理解。

      正由于如此,咱们自定义的指针地址就有可能被CLR垃圾回收机制从新调整位置,因此就引入了fixed ,MSDN对fixed的解释是:fixed 语句设置指向托管变量的指针,并在执行该语句期间"固定"此变量。这样就能够防止变量的重定位。

      看下代码的演示:

class PointerDemo{  public int x, y;}class Program{  unsafe static void ChangeValue(int* x, int* y)  {    *x = 200; //修改所在地址值    *y = 300;  }  unsafe static void Main()  {    var obj = new PointerDemo();    Console.WriteLine("原始值: {0}, {1}", obj.x, obj.y);     fixed (int* n = &obj.x)    {      fixed (int* p = &obj.y)      {        ChangeValue(n, p); //取data地址并传递      }    }    Console.WriteLine("改变地址后: {0}, {1}", obj.x, obj.y);     Console.ReadLine();   }}

相关文章
相关标签/搜索