1. 程式人生 > 程式設計 >.Net 6簡介並和之前版本寫法做對比

.Net 6簡介並和之前版本寫法做對比

目錄
  • 介紹
  • 正文
  • 對比
    • 向DI 容器新增服務
    • 日誌記錄
    • Serilog 整合
  • 完成的來看效果

    介紹

    vs2022正式版已經推出了,估計很多人已經下載並開始建立.Net 6 開始嚐鮮了,本節我簡要的給大家介紹一下.Net 6的一些改動。

    正文

    本次.Net6帶來最明顯的變化就是:

    • 採用頂級語句,我們看不到Program.Main()了。
    • 隱式 using 指令,隱式 using 指令意味著編譯器會根據專案型別自動新增一組 using 指令。
    • 移除了Startup檔案。
    var builder = WebApplication.CreateBuilder(args);
    
    var app = builder.Build();
    
    app.Run();

    對於這樣的改動大家可能會覺得這是C# 10 帶來的優化,但我的理解是.Net6為了新手更加方便入門,早期我們使用.Net Core 2/3/5 版本,還要給新人解釋系統啟動入口Program.Main()以後不需要了,配置拆分成兩個檔案Program.cs和Startup.cs雖然做到了關注點分離,但是對於新人會難以理解這次也沒了,當我們討論Startup的時候不用在去解釋如何呼叫的2個約定方法,即使它們沒有顯式實現介面,也可以呼叫它們。

    我們來看一下之前的語法,我們有一大堆巢狀的 lambda,程式碼看上去非常複雜。

    var hostBuilder = Host.CreateDefaultBuilder(args)
        
    .ConfigutiDKpMxGyreServices(services => { services.AddControllers(); }) .ConfigureWebHostDefaults(webBuilder => { webBuilder.Configure((ctx,app) => { if (ctx.HostingEnvironment.IsDevelopment()) { app.UseDeveloperExceptionPage(); } app.UseStaticFiles(); app.UseRouting(); app.UseEndpoints(endpoints => { endpoints.MapGet("/",() => "Hello World!"); endpoints.MapRazorPages(); }); }); }); hostBuilder.Build().Run();

    升級到.Net 6之後,我們可以使用更簡單的 API 來實現。

    var builder = WebApplication.CreateBuilder(args);
    builder.Services.AddControllers();
    var app = builder.Build();
    app.MapGet("/",() => "Hello World!");
    app.Run();

    對比

    我們將 2個版本的語法對比來看

    向DI 容器新增服務

    var hostBuilder = Host.CreateDefaultBuilder(args);
    hostBuilder.ConfigureServices(services => 
        {
            services.AddControllers();
            services.AddSingleton<MyThingy>();
        })
    
    
    var builder = WebApplication.CreateBuilder(args);
    builder.Services.AddControllers();
    builder.Services.AddSingleton&lt;MyThingy>();

    日誌記錄

    var hostBuilder = Host.CreateDefaultBuilder(args);
    hostBuilder.ConfigureLogging(builder => 
        {
            builder.AddFile();
        })
    
    var builder = WebApplication.CreateBuilder(args);
    builder.Logging.AddFile();

    Serilog 整合

    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args)
            .UseSerilog() // <-- Add this line
            .ConfigureWebHostDefaults(webBuilder =>
            {
                webBuilder.UseStartup<Startup>();
            });
    
    
    builder.Host.UseSerilog();

    完成的來看效果

        public interface IHelloService
        {
            string Hello(bool isHappy);
        }
    
        public class HelloService : IHelloService
        {
            public string Hello(bool isHappy)
            {
                var hello = $"Hello World";
    
                if (isHappy)
                    return $"{hello},you seem to be happy today";
                return hello;
            }
        }
    
    
    using MinimalApiDemo;
    using System.Security.Claims;
    
    var builder = WebApplicationwww.cppcns.com.CreateBuilder(args);
    
    builder.Services.AddScoped<IHelloService,HelloService>();
    // Add services to the container.
    
    builder.Services.www.cppcns.comAddControllers();
    // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
    builder.Services.AddEndpointsApiExplorer();
    builder.Services.AddSwaggerGen();
    
    var app = builder.Build();
    
    // Configure the HTTP request pipeline.
    if (app.Environment.IsDevelopment())
    {
        app.UseSwagger();
        app.UseSwaggerUI();
    }
    
    app.UseHttpsRedirection();
    
    app.UseAuthorization();
    
    app.MapControllers();
    
    app.MapGet("/Hello",(bool? isHappy,IHelloService service) =>
    {
        if (isHappy is null)
            return Results.BadRequest("Please tell if you are happy or not :-)");
    
        return Results.Ok(service.Hello((bool)isHappy));
    });
    
    
    app.Run();

    以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。