首页 > 编程 > .NET > 正文

Csharp+Asp.net系列教程(六)

2024-07-10 12:57:20
字体:
来源:转载
供稿:网友


收集最实用的网页特效代码!

本教程参考c#和asp.net程序设计教程撰写,有什么不足之处请大家指出,或在老猫的理想blog留言。

好些天不写了。今天事情较少,有几个网友总是问,就又写了点东西。可能疏漏比较多,希望大家帮忙指正

预处理指令:与c++不同,c#没有独立的预处理器。在c#中,预处理指令并不是编译器开始编译代码之前的一个单独的处理步骤,而是作为词法分析的一部分来执行的。预处理指令都以#号开头并位于行首。
#define指令用于定义符合,他的作用域是该定义所在的整个文件,符号定义必须放在所有其他语句的前面,或者说在所有“实代码(real code)”之前。(比如:"using system"就是实代码。)
想取消某个符号的定义,则要用到#undef指令。
条件编译指令有4个:#if、#elif、#else、#endif,他们用来有条件地将部分程序代码包括进来或排除在外。条件编译指令和if语句有类似的作用。也可以在条件编译指令中用逻辑与(&&)、逻辑或(||)、等于(==)、不等于(!=)等操作符。
eg:
#define mf1
#define mf2
using system;
public class mikecat
{
public static void main()
{
#if (mf1&&!mf2)
console.writeline("mf1被定义");
#elif(!mf1&&mf2)
console.writeline("mf2被定义");
#elif(mf1&&mf2)
console.writeline("mf1和mf2被定义");
#else
console.writeline("mf1和mf2没被定义");
#endif
}
}//运行结果:mf1和mf2被定义
#error和#warning指令用于发出编译错误和警告。
eg:
#define mf1
#define mf2
using system;
public class mikecat
{
public static void main()
{
#if mf1
#warning 欢迎来到老猫的理想!
#endif
#if mf2
#error 老猫的理想blog出错
#endif
}
}//运行结果:test.cs(9,17): warning cs1030: #warning:“欢迎来到老猫的理想!”
//test.cs(12,15): error cs1029: #error:“老猫的理想blog出错”
#line指令用于修改编译器行号及文件名
eg:
using system;
public class mikecat
{
public static void main()
{
#line 66 "mfblog.cs" //将编译行号设为66并将文件名改名为mfblog.cs
intt i=1;
console.writeline("i的值是{0}",i);
}
}//运行结果:mfblog.cs(66,6): error cs0246: 找不到类型或命名空间名称“intt”(是否缺少 using指令或程序集引用?)
//mfblog.cs(67,34): error cs0103: 名称“i”在类或命名空间“mikecat”中不存在

异常处理:在c#中,引发异常有两种状况,第一种:在程序中使用throw语句,立即无条件引发一个异常。第二种情况是c#语句或表达式在执行过程中激发了某个异常的条件,从而使得操作无法正常结束,从而引发异常。
在c#中,异常是由try语句来处理。try语句提供了一种机制来捕捉程序过程中引发的异常。try有三种可能的结构,即:try-catch|try-finally|try-catch-finally
try-catch结构:try子句后跟一个或多个catch子句。如果执行try子句中的语句时引发了异常,那么程序将按顺序查找第一个能处理该异常的catch子句,并将控制权转移到catch子句执行。既没定义异常类型,也没定义异常变量的catch子句称为普通catch子句。一个try子句最多只能有一个普通catch子句,而且该子句必须排在其他catch子句的后面。
eg:
using system;
class mikecat
{
static void mf1(string s)
{
if(s==null)
throw(new argumentnullexception());//引发异常
}
static void mf2()
{
try
{
string s=null;
mf1(s);//调用mf()方法。由于s=null,因此会引发异常
}
catch(argumentnullexception ex)
{
console.writeline("mf2()方法中的异常:{0}",ex.message);
throw;//再次引发
}
}
public static void main()
{
try
{
mf2();//调用mf2()方法
}
catch(argumentnullexception ex)
{
console.writeline("main()方法中的异常{0}",e.message);
}
}
}//mf2()方法中的异常:值不能为空。
//main()方法中的异常值不能为空。
try-finally结构:即try子句后跟一个finally子句。不管try子句是如何退出的(无论正常退出,还是引发异常,甚至执行goto|break|continue|return语句退出),程序的控制权总是会被转移到finally子句执行。
eg:
using system;
public class mikecat
{
public static void main()
{
try
{
console.writeline("执行try子句");
//goto leave;//跳转到leave标签
return;
}
finally
{
console.writeline("执行finally子句");
}
leave:
console.writeline("执行leave标签!");
}
}//执行try子句执行finally子句
try-catch-finally:即try子句后跟一个或多个catch子句及一个finally子句
eg:
using system;
class mikecat
{
static void mf(string s)
{
if(s==null)
throw(new argumentnullexception());//引发异常
}
public static void main()
{
try
{
string s=null;
mf(s);//调用mf()方法,由于s=null,因此会引发异常
}
catch(argumentnullexception ex)
{
console.writeline("异常发生:{0}",ex.message);
}
finally
{
console.writeline("执行finally子句");
}
}
}

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表