在某项目中,因需要对一个通用控件做代码重构,安排一些事件前检查点与事件后检查点,方便在具体业务中,对些通用控件做继承后,加入特定的业务控制逻辑。
在重构代码的的过程中,把主要处理逻辑分成三部分:PreCheck(),Check(),AfterCheck()。又为了方便在各个方法体中使用异步方法获取数据,把三个方法的类型,都定义成Task<T>。这种时就碰到了小问题:如果方法体中,不需要使用异步方法时,如果定义return的值。
经过测试,有了如下发现:如果方法定义为 protected virtual Task<bool> PreCheck() 时,需要 return Task.Factory.StartNew(()=> { return true; }); 来对应;但如果定义成 protected virtual async Task<bool> 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;
Console.WriteLine("PreCheck pass");
if (!await Check())
Console.WriteLine("Check not pass");
return;
Console.WriteLine("Check pass");
if (!await AfterCheck())
Console.WriteLine("AfterCheck not pass");
return;
Console.WriteLine("AfterCheck pass");
Console.WriteLine("Well done");
protected virtual Task<bool> PreCheck()
Console.WriteLine("Base PreCheck");
return Task.Factory.StartNew(()=> { return true; });
protected virtual async Task<bool> Check()
Console.WriteLine("Base Check");
return true;
protected virtual Task<bool> AfterCheck()
Console.WriteLine("Base AfterCheck");
return Task.Factory.StartNew(() => { return true; });
3、ExtendClass类
class ExtendClass:MyBaseClass
private bool someCondiction = true;
protected override async Task<bool> PreCheck()
if (!await base.PreCheck())
return false;
return await AnotherPreCheck();
protected override async Task<bool> Check()
if(someCondiction)
Console.WriteLine("Extend Check");
return true;
return await base.Check();
protected override Task<bool> AfterCheck()
return base.AfterCheck();
private async Task<bool> AnotherPreCheck()
Console.WriteLine("Extend AnotherPrecheck");
return true;
推荐阅读:
C# List<T>用法详解
Java泛型中<T> T 与 T的区别和用法