asp.net中的check与uncheck关键字用法解析

本文实例讲述了asp.net中的check与uncheck关键字用法。分享给大家供大家参考。具体分析如下:

checked和unchecked是两个不常用的关键字,但是确是非常有用的关键字,对此,建议测试时开启全局checked编译器选项。

1. 一段编译没经由过程的代码

代码如下:

int a = int.MaxValue * 2;

以上代码段编译没有经由过程,在VS2010中会有一条红色的波浪线指出这段代码有题目:”The operation overflows at compile time in checked mode”。这说了然编译器会在编译时搜检数学运算是否溢出。然则编译时能搜检出溢出的景象仅限于应用常量的运算。2中的代码编译器就不报不失足误来了。

2. 一段编译经由过程然则不克不及获得正确成果的代码

代码如下:

int temp = int.MaxValue;
int a = temp * 2;
Console.Write(a);

我先把常量int.MaxValue的值给了姑且变量temp,然后应用姑且变量乘以2策画成果赋值给a;这段代码是可以正常履行的,履行成果将输出 -2。
这申明在运行时默认景象法度是不会搜检算术运算是否溢出的,cpu尽管算,对于它来讲按规矩算就是了,成果对不合错误不是他的错。
正常履行了,而成果是错误的,这是很是危险的景象,该如何避免这种危险呢?请看3

3. 应用checked关键字,溢出时报警

代码如下:

int temp = int.MaxValue;
try
{
    int a = checked(temp * 2);
     Console.WriteLine(a);
}
catch (OverflowException)
{
Console.WriteLine("溢出了,要处理惩罚哟");
}

应用checked关键字润饰temp*2的策画成果,并应用try catch在产生溢出时做处理惩罚。以上代码将输出:“溢出了,要处理惩罚哟”
题目是若是一段代码中有很多算术运算都须要做溢出搜检,那会有很多checked润饰的表达式,怎么办呢?请看4

4. checked关键字可以润饰一个语句块,请看下面代码

代码如下:

int temp = int.MaxValue;
try
{
    checked
    {
        int num = temp / 20;
        int a = temp * 2;
        int c = temp * 1000;
    }
}
catch (OverflowException)
{
    Console.WriteLine("溢出了,要处理惩罚哟");
}

以上法度输出成果和3一样

5. checked在避免算术溢出方面很有效,那么unchecked呢,它有效吗?答案是必然的,有时辰我们不须要正确的策画成果,我们只是须要那么一个数罢了,至于溢出不溢出的关系不大,比如说生成一个对象的HashCode,比如说按照一个算法策画出一个相对随机数,这都是不须要正确成果的。如下代码片段

代码如下:

class Person
{
   public string Name { get; set; }
 
    public string Title { get; set; }
 
    public override int GetHashCode()
    {
        return unchecked(Name.GetHashCode() + Title.GetHashCode());
    }
}

unchecked也可以润饰语句块,其用法和checked完全一样。

6. checked和unchecked是可以嵌套应用的,固然没啥意义。语句是否是checked以比来嵌套的checked或者unchecked决意

7. 从IL中看checked关键字
C#代码:

代码如下:

static void Main(string[] args)
{
    int a = int.MaxValue;
    int b = a * 2;
    int c = checked(a * 2);
    int d = unchecked(a + 3);
 
    Console.Read();
}

对应IL

代码如下:

.method private hidebysig static void  Main(string[] args) cil managed
{
  .entrypoint
  // Code size       26 (0 x1a)
  .maxstack  2
  .locals init ([0] int32 a,
           [1] int32 b,
           [2] int32 c,
           [3] int32 d)
  IL_0000:  nop
  IL_0001:  ldc.i4     0 x7fffffff
  IL_0006:  stloc.0
  IL_0007:  ldloc.0
  IL_0008:  ldc.i4.2
  IL_0009:  mul
  IL_000a:  stloc.1
  IL_000b:  ldloc.0
  IL_000c:  ldc.i4.2
  IL_000d:  mul.ovf
  IL_000e:  stloc.2
  IL_000f:  ldloc.0
  IL_0010:  ldc.i4.3
  IL_0011:  add
  IL_0012:  stloc.3
  IL_0013:  call       int32 [mscorlib]System.Console::Read()
  IL_0018:  pop
  IL_0019:  ret
} // end of method Program::Main

请看IL中的红色和绿色加重显示代码,可以看出应用checked时,IL的运算是mul.ovf不应用checked或者应用unchecked时的IL运算函数是mul或者add,不带.ovf。

8. checked或者unchecked只影响其包抄的语句,不会影响到包抄的语句内调用函数的代码块,如下示例:

代码如下:

static void Main(string[] args)
{
    int a = int.MaxValue;
    int b = 20;
    checked
    {
        int c = TestMethod(a, b);
        Console.WriteLine(c);
    }
}
static int TestMethod(int a, int b)
{
    return a * b;
}

上方代码将会正常履行,checked语句块并未起到应有的感化。

9. 全局开启或者封闭checked编译选项
在项目属性页上选择“生成”选项卡,然后点击“高等”按钮,选中“搜检数学运算溢出”选项,如下示意图

希望本文所述对大家的asp.net程序设计有所帮助。

(0)

相关推荐

  • Asp.Net中索引器的用法分析

    本文实例分析了Asp.Net中索引器的用法.分享给大家供大家参考.具体如下: 索引器定义类似于属性,但其功能与属性并不相同.索引器提供一种特殊的方法编写get和set访问器.属性可以像访问字段一样访问对象的数据,索引器可以使用户像访问数组一样访问类成员. 一.索引器特性 1.get 访问器返回值.set 访问器分配值. 2.this 关键字用于定义索引器. 3.value 关键字用于定义由 set 索引器分配的值. 4.索引器不必根据整数值进行索引,由您决定如何定义特定的查找机制. 5.索引器可

  • ASP.NET中repeater控件用法实例

    本文实例讲述了ASP.NET中repeater控件用法.分享给大家供大家参考.具体实现方法如下: repeater绑定数据: 复制代码 代码如下: protected void Page_Load(object sender, EventArgs e) {         if(!IsPostBack)             BindStudent(); } private void BindStudent() {         string str = ConfigurationManag

  • .NET中的异常和异常处理用法分析

    本文较为详细的分析了.NET中的异常和异常处理用法.分享给大家供大家参考.具体分析如下: .NET中的异常(Exception) .net中的中异常的父类是Exception,大多数异常一般继承自Exception. 可以通过编写一个继承自Exception的类的方式,自定义异常类! 异常处理机制: 复制代码 代码如下: Try {     //可能发生异常的代码     //后续代码     } //Try以外的代码 catch(Exception e) { } finally { } 上述代

  • .NET中StringBuilder用法实例分析

    本文实例讲述了.NET中StringBuilder用法.分享给大家供大家参考.具体分析如下: 为什么要使用StringBuilder 为什么使用StringBuilder要从string对象的特性说起. string对象在进行字符串拼接时,因为字符串的不可变性,string对象会每次拼接,都会复制一个副本出来进行运算,而本身的串仍然留在内存中,大量的临时片段会造成不可忽视的性能损耗.所以在进行大量的字符串拼接时建议使用StringBuilder StringBuilder的简单使用方式: 复制代

  • ASP.NET(C#) String, StringBuilder 与 StringWriter性能比较

    直观认识:正面交锋  性能测试1:StringBuilder  第 1 轮测试:用时 312.5 毫秒  第 2 轮测试:用时 421.875 毫秒  第 3 轮测试:用时 453.125 毫秒  第 4 轮测试:用时 421.875 毫秒  第 5 轮测试:用时 453.125 毫秒  性能测试2:StringWriter  第 1 轮测试:用时 406.25 毫秒  第 2 轮测试:用时 453.125 毫秒  第 3 轮测试:用时 421.875 毫秒  第 4 轮测试:用时 437.5 

  • ASP.NET中 script runat server 的用法

    本文实例讲述了ASP.NET中<script runat="server">的用法,分享给大家供大家参考.具体如下: 在ASP.NET的.aspx页面中,可以在<head>代码</head>标签中通过<script runat="server">添加代码.其实,这里的代码和.cs文件中的代码地位是相同的,都是在服务器端执行的. 例: 复制代码 代码如下: <script type="text/javas

  • 水晶报表asp.net的webform下基本用法实例

    本文实例讲述了水晶报表asp.net的webform下基本用法.分享给大家供大家参考. 具体实现方法如下: 复制代码 代码如下: protected void Page_Init(object sender, EventArgs e) {      ConfigureCrystalReport();  } protected void Page_Unload(object sender, EventArgs e)  {          if (rptDocument == null)     

  • .NET中的IO操作之文件流用法分析

    本文实例讲述了.NET中的IO操作之文件流用法.分享给大家供大家参考.具体分析如下: 读操作 复制代码 代码如下: //1.创建文件流 FileStream fsRead =new FileStream("1.txt",FileMode.Open); //2.创建缓冲区,正常情况下,是不会直接等于文件大小的.这里只有读,所以就这么干了. byte[] bytes =new byte[fsRead.Length]; //3.开始读取, 返回值是读取到的长度. int r =fsRead.

  • ASP.NET中TimeSpan的用法实例解析

    本文实例讲述了ASP.NET中TimeSpan的用法,分享给大家供大家参考.具体如下: ASP.NET 中,两个时间相减,得到一个 TimeSpan 实例,TimeSpan 有一些属性:Days.TotalDays.Hours.TotalHours.Minutes.TotalMinutes.Seconds.TotalSeconds.Ticks,注意没有 TotalTicks. 一.TimeSpan常量.字段 复制代码 代码如下: TimeSpan.MaxValue;            //

  • asp.net StringBuilder的用法 实例代码

    要实现上述效果 复制代码 代码如下: public static string ShowNewMsg() { string Pic1 = "images/yzdp-_15.gif"; string Pic2 = "images/yzdp-_18.gif"; string Pic3 = "images/yzdp-_20.gif"; string Pic4 = "images/yzdp-_22.gif"; string Pic5

随机推荐