重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
在某项目中,因需要对一个通用控件做代码重构,安排一些事件前检查点与事件后检查点,方便在具体业务中,对些通用控件做继承后,加入特定的业务控制逻辑。
在重构代码的的过程中,把主要处理逻辑分成三部分:PreCheck(),Check(),AfterCheck()。又为了方便在各个方法体中使用异步方法获取数据,把三个方法的类型,都定义成Task。这种时就碰到了小问题:如果方法体中,不需要使用异步方法时,如果定义return的值。
经过测试,有了如下发现:如果方法定义为 protected virtual Task PreCheck() 时,需要 return Task.Factory.StartNew(()=> { return true; }); 来对应;但如果定义成 protected virtual async Task Check()时,可以直接return true; 来对应;在继承类中也一样的。
示例代码如下:
1、Main方法:
static async System.Threading.Tasks.Task Main(string[] args)
{
var test = new ExtendClass();
await test.Main();
Console.WriteLine("Main Program here");
Console.ReadKey();
}
2、MyBaseClass类
public class MyBaseClass
{
public async Task Main()
{
if (!await PreCheck())
{
Console.WriteLine("PreCheck not pass");
return;
}
else
{
Console.WriteLine("PreCheck pass");
}
if (!await Check())
{
Console.WriteLine("Check not pass");
return;
}
else
{
Console.WriteLine("Check pass");
}
if (!await AfterCheck())
{
Console.WriteLine("AfterCheck not pass");
return;
}
else
{
Console.WriteLine("AfterCheck pass");
}
Console.WriteLine("Well done");
}
protected virtual Task PreCheck()
{
Console.WriteLine("Base PreCheck");
return Task.Factory.StartNew(()=> { return true; });
}
protected virtual async Task Check()
{
Console.WriteLine("Base Check");
return true;
}
protected virtual Task AfterCheck()
{
Console.WriteLine("Base AfterCheck");
return Task.Factory.StartNew(() => { return true; });
}
}
3、ExtendClass类
class ExtendClass:MyBaseClass
{
private bool someCondiction = true;
protected override async Task PreCheck()
{
if (!await base.PreCheck())
return false;
return await AnotherPreCheck();
}
protected override async Task Check()
{
if(someCondiction)
{
Console.WriteLine("Extend Check");
return true;
}
else
{
return await base.Check();
}
}
protected override Task AfterCheck()
{
return base.AfterCheck();
}
private async Task AnotherPreCheck()
{
Console.WriteLine("Extend AnotherPrecheck");
return true;
}
}