.net core 与 .net framework 的一些不同点
2021-04-22 13:26
标签:一点 abstract 业务需求 对比 art 没有 close core span 随大流的用.net core也没有系统的学习,只知道.net core支持跨平台,其他的点上没办法讲出个一二,今天听老师讲到的一个点,记录下来 测试点:在.net core/.net framework不同平台下 接口,抽象类,类以及各自对应的实现类 循环调用,哪个平台中哪个的运行效率最高? 新建两个控制台程序,.net core(3.1) 和 .net framework(我用的是4.7.2) 同样一份代码,在不同平台运行,以下是code: 下图是运行的效果对比图: 总体测试下来是.net core > .net framework 且快10倍左右 (我看老师运行快个7,8倍左右) 接口和抽象谁效率高?我将test的方法循环了10次,:.net core中不相上下,抽象类 > 接口 (略微) 个人经验:在接口和抽象类的选择中,最终还是看业务需求~ 共性大就用接口(生物:人,鱼,狗),特性就用抽象~(鱼:鲫鱼,草鱼,鲤鱼) 初学,有什么错误,欢迎指正~ 最后一点,谁能指出为什么两个平台差异这么大呢? .net core 与 .net framework 的一些不同点 标签:一点 abstract 业务需求 对比 art 没有 close core span 原文地址:https://www.cnblogs.com/hanliping/p/12244053.html 1 class Program
2 {
3 static void Main(string[] args)
4 {
5
6 Console.WriteLine("测试不同框架下,接口与抽象类的效率:.net core 3.1 release: ");
7 var t = new Test();
8 t.PerformanceTest();
9 Console.ReadKey();
10 }
11 }
1 namespace CoreConsole
2 {
3 public class Test
4 {
5 public void PerformanceTest()
6 {
7
8 IChild record1 = new IChild();
9 IBase record2 = record1;
10
11 AbsChild row1 = new AbsChild();
12 AbsBaseClass row2 = row1;
13
14 Child result1 = new Child();
15 Base result2 = result1;
16
17 Console.WriteLine($"循环{int.MaxValue}次,去执行接口,抽象类,类以及实现类里面的方法");
18
19 Stopwatch stopwatch = new Stopwatch();
20
21
22 stopwatch.Restart();
23 for (int i = 0; i int.MaxValue; i++)
24 {
25 record1.Do();
26 }
27 Console.WriteLine($"接口实现类调用时间:{stopwatch.ElapsedMilliseconds} 毫秒");
28
29
30 stopwatch.Restart();
31 for (int i = 0; i int.MaxValue; i++)
32 {
33 record2.Do();
34 }
35 Console.WriteLine($"接口基类调用时间:{stopwatch.ElapsedMilliseconds} 毫秒");
36
37
38
39 stopwatch.Restart();
40 for (int i = 0; i int.MaxValue; i++)
41 {
42 row1.Do();
43 }
44 Console.WriteLine($"抽象实现类调用时间:{stopwatch.ElapsedMilliseconds} 毫秒");
45
46
47 stopwatch.Restart();
48 for (int i = 0; i int.MaxValue; i++)
49 {
50 row2.Do();
51 }
52 Console.WriteLine($"抽象基类调用时间:{stopwatch.ElapsedMilliseconds} 毫秒");
53
54
55
56 stopwatch.Restart();
57 for (int i = 0; i int.MaxValue; i++)
58 {
59 result1.Do();
60 }
61 Console.WriteLine($"类调用时间:{stopwatch.ElapsedMilliseconds} 毫秒");
62
63 stopwatch.Restart();
64 for (int i = 0; i int.MaxValue; i++)
65 {
66 result2.Do();
67 }
68 Console.WriteLine($"基类调用时间:{stopwatch.ElapsedMilliseconds} 毫秒");
69
70 }
71 }
72
73 public interface IBase
74 {
75 void Do();
76 }
77
78 public class IChild : IBase
79 {
80 public void Do()
81 {
82
83 }
84 }
85
86 public abstract class AbsBaseClass
87 {
88 public abstract void Do();
89 }
90
91 public class AbsChild : AbsBaseClass
92 {
93 public override void Do()
94 {
95 }
96 }
97
98 public class Base
99 {
100 public virtual void Do() { }
101 }
102
103 public class Child : Base
104 {
105 public override void Do()
106 {
107
108 }
109 }
110 }
上一篇:MVC06
文章标题:.net core 与 .net framework 的一些不同点
文章链接:http://soscw.com/essay/78083.html