阿里云购买域名后怎么建网站最新网站开发建设教材
阿里云购买域名后怎么建网站,最新网站开发建设教材,h5页面怎么做,互联网公司排名最新理想的代码优化方式团队日常协作中#xff0c;自然而然的会出现很多重复代码#xff0c;根据这些代码的种类#xff0c;之前可能会以以下方式处理方式描述应用时可能产生的问题硬编码多数新手#xff0c;或逐渐腐坏的项目会这么干#xff0c;会直接复制之前实现的代码带来… 理想的代码优化方式团队日常协作中自然而然的会出现很多重复代码根据这些代码的种类之前可能会以以下方式处理方式描述应用时可能产生的问题硬编码多数新手或逐渐腐坏的项目会这么干会直接复制之前实现的代码带来的问题显而易见的多例如架构会逐渐随时间被侵蚀例外越来越多提取函数提取成为函数然后复用提取函数然后复用会比直接硬编码好些但是仍然存在大量因“例外”而导致增加参数、增加函数重载的情况模板生成器CodeSmith/T4等因为是独立进程所以对于读取用户代码或项目实现难度较高且需要现有用户项目先生成成功再进行生成 或者是完全基于新项目代码片段VS自带的代码片段功能无法对复杂的环境或条件做出响应AOP框架面向切面编程可以解决很多于用户代码前后增加操作的事情但是大多AOP框架都是基于透明代理形式实现的对于相互调用较多的代码但形成性能压力而且因为要符合透明代理的规则所以要提供相应的子类或接口。基于Rosyln的编译时插入代码但以上这几种AOP算是最理想的方式但是感觉上还可以有更好的解决方案。直到读到了这篇文章 Introducing C# Source Generators文中提供了一种新的解决方案即通过Roslyn的Source Generator在编译时直接读取当前项目中的语法树处理并生成的新代码然后在编译时也使用这些新代码。那么如果可以读取现有代码的语法树通过读取代码中的标记那么在代码生成过程中是否就能直接生成。实现如下效果项目中的源代码 Program.csinternal class Program
{
[Log]
private static int Add( int a, int b )
{
return a b;
}
}自动根据 LogAttribute 自动编译成的代码 Program.g.csinternal class Program
{
[Log]
private static int Add( int a, int b )
{
Console.WriteLine(Program.Add(int, int) 开始运行.);
int result;
result a b;
Console.WriteLine(Program.Add(int, int) 结束运行.);
return result;
}
}当然LogAttribute中需要去实现插入代码。然后项目自动使用新生成的Program.g.cs进行编译。这样就实现了基于编译时的AOP。即实现以下流程使用Metalama实现以上流程经过寻找发现其实已经有框架可以实现我上面说的流程了也就是在编译时实现代码的插入。https://www.postsharp.net/metalama 。下面作一个简单示例创建一个.NET6.0的控制台应用我这里命名为LogDemo,其中的入口文件Program.csnamespace LogDemo {
public class Program
{
public static void Main(string[] args)
{
var r Add(1, 2);
Console.WriteLine(r);
}
// 这里写一个简单的方法一会对这个方法进行代码的插入
private static int Add(int a, int b)
{
var result a b;
Console.WriteLine(Add result);
return result;
}
}
}在项目中使用Metalama通过引用包 https://www.nuget.org/packages/Metalama.Framework, 注意Metalama当前是Preview版本如果通过可视化Nuget管理器引入需要注意勾选包含预发行版dotnet add package Metalama.Framework --version 0.5.7-preview编写一个AOP的Attribute在项目中引入 Metalama.Framework后无需多余配置或代码直接编写一个AOP的Attributeusing Metalama.Framework.Aspects;namespace LogDemo {
public class Program
{
public static void Main(string[] args)
{
var r Add(1, 2);
Console.WriteLine(r);
}
// 在这个方法中使用了下面的Attribute
[LogAttribute]
private static int Add(int a, int b)
{
var result a b;
Console.WriteLine(Add result);
return result;
}
}
// 这里是增加的 Attribute
public class LogAttribute : OverrideMethodAspect
{
public override dynamic? OverrideMethod()
{
Console.WriteLine(meta.Target.Method.ToDisplayString() 开始运行.);
var result meta.Proceed();
Console.WriteLine(meta.Target.Method.ToDisplayString() 结束运行.);
return result;}
}
}执行结果如下Program.Add(int, int) 开始运行.
Add3
Program.Add(int, int) 结束运行.
3生成的程序集进行反编译得到的代码如下using Metalama.Framework.Aspects;
namespace LogDemo {
public class Program
{
public static void Main(string[] args)
{
var r Add(1, 2);
Console.WriteLine(r);
}
// 在这个方法中使用了下面的Attribute
[LogAttribute]
private static int Add(int a, int b)
{
Console.WriteLine(Program.Add(int, int) 开始运行.);
int result_1;
var result a b;
Console.WriteLine(Add result);
result_1 result;
Console.WriteLine(Program.Add(int, int) 结束运行.);
return result_1;
}
}
#pragma warning disable CS0067
// 这里是增加的 Attribute
public class LogAttribute : OverrideMethodAspect
{
public override dynamic? OverrideMethod()
throw new System.NotSupportedException(Compile-time-only code cannot be called at run-time.);
}
#pragma warning restore CS0067
}总结这样就完全实现了我之前想要的效果当然使用Metalama还可以实现很多能极大地提高生产力的功能它不仅可以对方法进行改写也可以对属性、字段、事件、甚至是类、命名空间进行一些操作 。引用Introducing C# Source Generatorshttps://devblogs.microsoft.com/dotnet/introducing-c-source-generators/Metalama官网https://www.postsharp.net/metalama
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/89217.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!