【C#跨平台开发详解】C#跨平台开发技术之.NET Core基础学习及快速入门

1. C#与.NET的发展历程

C#是由Microsoft开发的现代编程语言,最初伴随着.NET
Framework发布。随着技术的进步,特别是针对跨平台开发的需求,Microsoft推出了.NET
Core,这是一个开源且跨平台的框架,支持Windows、macOS和Linux。

  • 2002年:C# 1.0 发布,仅限于Windows。
  • 2016年:.NET Core 1.0 发布,开启了C#跨平台开发的新时代。
  • 2020年:.NET 5 发布,整合了.NET
     Framework和.NET
     Core。
  • 2021年:.NET 6 发布,进一步提升跨平台能力。
  • 2022年:.NET 7 发布,持续优化性能与功能。

2. .NET Core:跨平台的基础

.NET Core(现称为.NET
5及以后的版本)是实现C#跨平台的核心技术。它是开源的,具备高性能和模块化的特点。

主要特点:

  • 跨平台:支持在多个操作系统上运行,包含Windows、macOS和Linux。
  • 开源:完全开源,依赖社区的支持和贡献。
  • 高性能:在运行时和内存管理方面进行了优化。
  • 模块化:通过NuGet包管理,轻松引用所需库。
  • 容器支持:适合微服务架构,易于部署。

架构图

40418f820b974388a4aa68adfabf8503.png 

3. C# 跨平台的实现原理

C# 的跨平台能力主要依赖于 .NET 框架,特别是 .NET Core(现已成为统一的 .NET 平台,如 .NET 5、.NET 6 和 .NET 7 等版本)。C# 跨平台实现的核心是通过 中间语言(Intermediate Language, IL)公共语言运行时(Common Language Runtime, CLR)JIT 编译器(Just-In-Time Compiler) 以及 .NET 平台上的各种库和工具实现的。

以下是 C# 实现跨平台开发的核心原理和机制:

1. 编译为中间语言(IL)

C# 源代码首先经过编译器(如 Roslyn)编译为 中间语言(IL),也称为 CIL(Common Intermediate Language)MSIL(Microsoft Intermediate Language)

中间语言的关键特性:

  • 平台无关:IL 是一种平台无关的二进制代码,这意味着它可以在任何支持 .NET 运行时的操作系统上执行(Windows、macOS、Linux 等)。
  • 可移植性:IL 使得编写的 C# 程序在不同的操作系统上具有一致的行为,因为它不是直接的机器码,而是高层次的字节码。

编译过程

编译 C# 代码到 IL 的过程如下:

  1. C# 源代码经过 Roslyn 编译器,生成 IL。
  2. IL 存储在 .dll 或 .exe 文件中。

例如:

public class Program
{public static void Main(){Console.WriteLine("Hello, World!");}
}

 编译后的 IL:

.method public static void Main() cil managed
{.entrypointIL_0000: ldstr "Hello, World!"IL_0005: call void [mscorlib]System.Console::WriteLine(string)IL_000a: ret
}

2. 公共语言运行时(CLR)

公共语言运行时(CLR) 是 .NET 平台中的核心组件,它负责执行 IL 代码,并管理程序的内存、线程、安全性和其他运行时服务。

主要功能:

  • 内存管理和垃圾回收:CLR 自动管理内存分配,并在对象不再使用时自动释放内存。
  • 类型安全性:CLR 运行时检查类型和内存访问,确保类型安全。
  • 异常处理:提供一致的异常处理机制,跨平台应用中一致处理错误。
  • 安全性:通过代码访问安全(CAS)等机制,提供应用程序安全性保障。

CLR 的实现是跨平台的,例如在 Windows 上使用 .NET Framework CLR,在 Linux 和 macOS 上使用 CoreCLR(用于 .NET Core)。这些不同平台上的运行时在实现细节上有差异,但都能执行 IL 代码,确保程序的行为一致。

3. JIT 编译器(即时编译器)

当 IL 代码运行时,.NET 的 JIT 编译器(Just-In-Time Compiler) 将 IL 编译为目标平台的机器码,这一步使得同一个 IL 在不同平台上能够正常执行。

JIT 的工作机制:

  1. 启动时加载 IL:当应用程序启动时,CLR 会加载并解析 IL 代码。
  2. 即时编译:在方法首次被调用时,JIT 编译器会将该方法的 IL 转换为目标平台的机器码。
  3. 执行机器码:编译后的机器码保存在内存中,以备后续使用。如果该方法被多次调用,不需要重新编译。

JIT 编译的优点

  • 平台独立性:JIT 编译使得相同的 IL 可以运行在不同的硬件和操作系统上。
  • 性能优化:JIT 编译时可以针对具体平台进行优化,保证良好的性能。

4. Ahead-of-Time(AOT)编译

在某些场景下,例如移动应用或高性能应用,.NET 支持 Ahead-of-Time(AOT)编译。AOT 编译在发布阶段将 IL 提前编译为目标平台的机器码,而不是在运行时编译,从而减少启动时间并提高执行效率。

典型使用场景

  • Blazor WebAssembly:在这种技术中,C# 代码被提前编译为 WebAssembly,而不是在客户端通过 JIT 编译,这样可以在浏览器中直接运行。
  • Xamarin:在跨平台移动开发中,AOT 编译可以让 C# 代码直接在 iOS 或 Android 设备上运行。

5. 跨平台运行时(CoreCLR 和 Mono)

.NET 提供了多个实现,帮助 C# 代码在不同平台上运行:

CoreCLR

  • .NET Core 和 .NET 5+ 的主要运行时。
  • 高度优化,专门为服务器和桌面环境设计。
  • 提供跨平台支持,运行在 Windows、Linux 和 macOS 上。

Mono

  • Mono 是 .NET 的早期跨平台实现,特别是在移动和嵌入式设备上非常流行。
  • 通过 Mono,可以在 Android 和 iOS 等移动操作系统上运行 C# 应用程序。
  • Xamarin 平台就是基于 Mono 构建的,提供了移动应用跨平台开发的能力。

6. BCL(基础类库)

C# 能够跨平台的重要部分还依赖于 基础类库(Base Class Library, BCL)。BCL 是.NET
提供的一组类库,提供了一致的 API,帮助开发者实现常见的功能,例如文件操作、网络通信、数据结构等。

跨平台的 BCL:

.NET 的 BCL 被设计为跨平台使用,开发者可以编写依赖于标准库的代码,无需考虑操作系统的差异。

例如,文件读写代码:

using System.IO;class Program
{static void Main(){string text = File.ReadAllText("/path/to/file.txt");Console.WriteLine(text);}
}

这种代码可以在 Windows、Linux 和 macOS 上无差别地运行,.NET 会处理底层的文件系统差异。

7. 条件编译和平台特性处理

尽管 BCL 是跨平台的,但有时开发者仍然需要处理一些平台特定的功能。这时可以使用 条件编译依赖注入 的方式,根据不同的操作系统提供不同的实现。

条件编译:

通过 #if 预处理指令,可以根据不同平台编译不同的代码。

#if WINDOWSConsole.WriteLine("Running on Windows");
#elif LINUXConsole.WriteLine("Running on Linux");
#elif OSXConsole.WriteLine("Running on macOS");
#endif

依赖注入:

使用依赖注入模式,动态注入不同平台的实现。

public interface IPlatformService
{void PlatformSpecificOperation();
}public class WindowsService : IPlatformService
{public void PlatformSpecificOperation(){Console.WriteLine("Windows specific operation");}
}public class LinuxService : IPlatformService
{public void PlatformSpecificOperation(){Console.WriteLine("Linux specific operation");}
}// 在启动时根据平台注册服务
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
{services.AddSingleton<IPlatformService, WindowsService>();
}
else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
{services.AddSingleton<IPlatformService, LinuxService>();
}

 

8. 跨平台构建工具和命令行工具

.NET 提供了强大的命令行工具 dotnet CLI,支持在不同平台上进行应用的创建、编译和部署。

# 创建新的控制台应用
dotnet new console -n MyApp# 进入项目目录
cd MyApp# 编译应用
dotnet build# 运行应用
dotnet run

这些命令可以在 Windows、Linux 和 macOS 上执行,确保了开发体验的一致性。

4. 跨平台框架和库

        C#的跨平台框架和库使得开发者能够构建可以在多种操作系统上运行的应用程序。 以下将详细讲解几个重要的跨平台框架和库,以.NET6.0版本为基础提供示例代码以展示它们的使用。

a) 
 ASP.NET Core


  ASP.NET Core是用于构建现代云应用的开源框架。它支持构建Web应用、Web API和微服务,允许开发者使用C#在多种平台上运行应用。

特点

  • 跨平台:可以在Windows、macOS和Linux上运行。
  • 高性能:ASP.NET Core在处理请求时性能表现非常优越。
  • 模块化:支持NuGet包管理,开发者可以根据需要来引入库。
  • 依赖注入:内置的依赖注入支持使得代码更加清晰且易于测试。

示例


 以下是一个简单的ASP.NET Core Web API的示例:

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;var builder = WebApplication.CreateBuilder(args);// 添加服务
builder.Services.AddControllers();var app = builder.Build();// 配置HTTP请求管道
if (app.Environment.IsDevelopment())
{app.UseDeveloperExceptionPage();
}app.UseRouting();
app.UseAuthorization();app.MapControllers();app.Run();

 路由控制器示例

using Microsoft.AspNetCore.Mvc;[ApiController]
[Route("api/[controller]")]
public class HelloWorldController : ControllerBase
{[HttpGet]public IActionResult Get(){return Ok("Hello, World!");}
}

b) .NET MAUI

.NET MAUI(Multi-platform App UI)是用于构建跨平台桌面和移动应用的框架,支持Android、iOS、Windows和macOS。它是Xamarin.Forms的演进。

特点

  • 单一项目结构:一个项目可以构建多个平台的应用。
  • 共享代码:可以共享UI和业务逻辑代码。
  • 原生性能:使用原生控件提供性能和用户体验。

示例


以下是一个使用.NET MAUI构建简单应用的示例:

using Microsoft.Maui.Controls;namespace HelloWorldMAUI
{public class App : Application{public App(){MainPage = new ContentPage{Content = new StackLayout{Children ={new Label { Text = "Hello, .NET MAUI!" },new Button{Text = "Click Me",Command = new Command(() => {// 点击事件Application.Current.MainPage.DisplayAlert("Alert", "Button clicked!", "OK");})}}}};}}
}

c) Blazor

概述

Blazor是一个用于构建交互式Web应用的框架,支持C#和HTML。Blazor有两种模式:Blazor Server和Blazor WebAssembly(WASM)。

特点

  • 组件化:使用组件构建应用,提升复用性。
  • C#作为唯一语言:前端和后端均可使用C#开发。
  • 支持WebAssembly:可以直接在浏览器中运行C#代码。

示例

以下是一个简单的Blazor组件示例:

@page "/counter"<h3>Counter</h3><p>Current count: @currentCount</p><button class="btn btn-primary" @onclick="IncrementCount">Increment</button>@code {private int currentCount = 0;private void IncrementCount(){currentCount++;}
}

d)  Unity

概述

Unity是一个跨平台游戏引擎,使用C#作为主要编程语言。它支持从2D到3D的各种游戏开发,能够在多个平台上发布游戏。

特点

  • 强大的图形引擎:支持高质量的图形和物理渲染。
  • 广泛的平台支持:可以发布到PC、移动设备、主机等多种平台。
  • 丰富的生态系统:拥有大量的插件和资产。

示例

以下是一个简单的Unity脚本示例,用于在游戏中输出“Hello, World!”:

using UnityEngine;public class HelloWorld : MonoBehaviour
{void Start(){Debug.Log("Hello, World!");}
}

e)Avalonia

概述

Avalonia是一个用于构建跨平台桌面应用的UI框架,支持Windows、macOS和Linux。

特点

  • XAML支持:使用XAML定义UI,使得开发更加直观。
  • MVVM支持:支持MVVM设计模式,方便应用结构的组织。
  • 高性能:针对不同平台进行了优化。

示例

以下是一个简单的Avalonia应用示例:

<Application xmlns="https://github.com/avaloniaui"><Application.Styles><FluentTheme /></Application.Styles><Window Title="Hello Avalonia" Width="400" Height="200"><StackPanel><TextBlock Text="Hello, Avalonia!" Margin="10" /><Button Content="Click Me" Margin="10" Click="OnButtonClick" /></StackPanel></Window>
</Application>

 

using Avalonia.Controls;public class MainWindow : Window
{public MainWindow(){InitializeComponent();}private void OnButtonClick(object sender, RoutedEventArgs e){MessageBox.Show(this, "Button clicked!", "Notification", MessageBox.MessageBoxButtons.Ok);}
}

 

5. 跨平台开发工具和环境

a) Visual Studio

  • 平台:支持Windows和macOS。
  • 功能:提供完整的开发、调试和部署功能。

b) Visual Studio Code + C#插件

  • 平台:跨平台的轻量级编辑器。
  • 功能:通过插件支持C#开发,包括智能感知和调试。

c) JetBrains Rider

  • 平台:跨平台的IDE,专为.NET开发设计。

d) 命令行工具

  • dotnet CLI:跨平台的命令行工具,用于创建、编译和运行应用。

 

6.性能优化

为确保C#跨平台应用的性能,开发者可以进行以下优化:

a) AOT编译

预编译(Ahead-of-Time)可以提高启动性能,特别是移动和桌面应用。

b) 性能分析工具

使用dotnet-trace和PerfView等工具进行性能分析,确保应用运行高效。

c) SIMD优化

利用单指令多数据(SIMD)指令集进行性能优化。

using System.Numerics;public static void VectorAdd(float[] a, float[] b, float[] result)
{int i = 0;int vectorSize = Vector<float>.Count;int limit = a.Length - (a.Length % vectorSize);for (; i < limit; i += vectorSize){var va = new Vector<float>(a, i);var vb = new Vector<float>(b, i);(va + vb).CopyTo(result, i);}for (; i < a.Length; i++){result[i] = a[i] + b[i];}
}

 

7. 部署和分发

跨平台C#应用的部署和分发主要有以下几种方式:

a) 框架依赖部署

依赖目标机器上已安装的.NET运行时。

b) 自包含部署

将运行时和应用打包在一起,无需目标机器预装.NET

dotnet publish -c Release -r win-x64 --self-contained true
dotnet publish -c Release -r osx-x64 --self-contained true
dotnet publish -c Release -r linux-x64 --self-contained true

 

c) Docker容器化

将应用打包为Docker容器,便于在不同环境中部署。

FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
WORKDIR /app
EXPOSE 80FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build
WORKDIR /src
COPY ["MyApp.csproj", "./"]
RUN dotnet restore "MyApp.csproj"
COPY . .
RUN dotnet build "MyApp.csproj" -c Release -o /app/buildFROM build AS publish
RUN dotnet publish "MyApp.csproj" -c Release -o /app/publishFROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "MyApp.dll"]

8.未来展望

C#的跨平台技术仍在不断发展,未来可能的发展方向包括:

  • 性能提升:进一步缩小与原生应用的差距。
  • 云原生集成:强化与云服务的结合。
  • UI开发体验改善:优化跨平台UI开发的工具和框架。
  • 新兴平台支持:拓展到WebAssembly等新兴技术。

结论

        C#的跨平台技术为开发者提供了强大的工具,使他们能够用一种语言开发各种类型的应用并部署到多个平台。
通过.NET Core(
现.NET 5+)、多个跨平台框架和工具,C#实现了真正的“一次编写,到处运行”。虽然在处理平台特定功能和优化性能方面仍有挑战,但C#的跨平台能力正在不断提升,为开发者提供更大的灵活性和效率。

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/53481.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

利用数据分析提升SEO排名的7种方法

我们都听过“大数据分析”这个词。科技让我们能够清晰地了解我们的活动和内容的表现——向我们提供了关于受众的宝贵信息&#xff0c;甚至可以精确到他们在Google和其他搜索引擎上使用的具体搜索词。 你已经在你的业务中使用数据分析了吗&#xff1f;如果是&#xff0c;你有利…

828华为云征文|华为云Flexus X实例docker部署MinIO对象存储系统obs

828华为云征文&#xff5c;华为云Flexus X实例docker部署MinIO对象存储系统obs 华为云最近正在举办828 B2B企业节&#xff0c;Flexus X实例的促销力度非常大&#xff0c;特别适合那些对算力性能有高要求的小伙伴。如果你有自建MySQL、Redis、Nginx等服务的需求&#xff0c;一定…

数据分析:R语言计算XGBoost线性回归模型的SHAP值

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍SHAP用途计算方法:应用加载R包导入数据数据预处理函数模型介绍 SHAP(SHapley Additive exPlanations)值是一种解释机器学习模型预测的方法。它基于博弈论中的Shapley值概念,…

5G网络建设

题目描述 现需要在基城市进行5G网络建设&#xff0c;已经选取N个地点设置5G基站&#xff0c;编号固定为1到N&#xff0c;接下来需要各个基站之间使用光纤进行连接以确保基 站能互联互通&#xff0c;不同基站之间假设光纤的成本各不相同&#xff0c;且有些节点之间已经存在光纤…

GeekDesk:不只是桌面美化,更是你的时间管理与效率提升专家

前言 科技&#xff0c;如同织就未来的经纬线&#xff0c;以智慧为梭&#xff0c;穿梭于生活的每一个角落&#xff0c;编织出一张便捷之网&#xff0c;让人类的生活如诗如画&#xff0c;绚烂多彩--这一理念深刻地影响着每一个科技产品的诞生与发展。在众多旨在提升工作效率与生…

基于SpringBoot的宠物服务系统+uniapp小程序+LW参考示例

系列文章目录 1.基于SSM的洗衣房管理系统原生微信小程序LW参考示例 2.基于SpringBoot的宠物摄影网站管理系统LW参考示例 3.基于SpringBootVue的企业人事管理系统LW参考示例 4.基于SSM的高校实验室管理系统LW参考示例 5.基于SpringBoot的二手数码回收系统原生微信小程序LW参考示…

函数指针和指针函数

指针 指针函数 指针函数一个函数&#xff0c;只不过这个函数的返回值是一个地址值 和普通函数唯一的区别就是在函数名前面多了一个*号 函数返回值必须用同类型的指针变量来接受 也可以将其返回值定义为 void*类型&#xff0c;在调用的时候强制转换返回值为自己想要的类型 str…

一、selenium自动化简介selenium工具集

文章目录 一、简介二、组成部分三、selenium工具集3.1 Selenium IDE3.2 Selenium WebDriver3.3 Selenium Grid3.4 Appium 一、简介 官方网站 Selenium 是支持 web 浏览器自动化的一系列工具和库的综合项目。 它提供了扩展来模拟用户与浏览器的交互&#xff0c;用于扩展浏览器分…

Excel使用VLOOKUP公式匹配不出正确公式,返回#N/A

问题&#xff1a; Excel使用VLOOKUP公式匹配不出正确公式&#xff0c;返回#N/A 原因&#xff1a; 原数据和匹配的数据格式不一致 解决办法&#xff1a; 把格式都设置为文本。 例如添加一列&#xff0c;输入英文符号&#xff0c;然后把数据源拼接起来&#xff0c;转换为文…

Linux入门攻坚——31、rpc概念及nfs和samba

NFS&#xff1a;Network File System 传统意义上&#xff0c;文件系统在内核中实现 RPC&#xff1a;函数调用&#xff08;远程主机上的函数&#xff09;&#xff0c;Remote Procedure Call protocol 一部分功能由本地程序完成 另一部分功能由远程主机上的 NFS本质…

基于阿里云函数计算(FC)x 云原生 API 网关构建生产级别 LLM Chat 应用方案最佳实践

作者&#xff1a;计缘 LLM Chat 应用大家应该都不陌生&#xff0c;这类应用也逐渐称为了我们日常的得力助手&#xff0c;如果只是个人使用&#xff0c;那么目前市面上有很多方案可以快速的构建出一个LLM Chat应用&#xff0c;但是如果要用在企业生产级别的项目中&#xff0c;那…

C#高级:递归2-根据ID反向递归求其所有的祖先节点信息

目录 一、实现demo 二、封装方法 【ID>祖先ID】 【ID>祖先实体】 三、递归讲解 一、实现demo class MainClass {static List<Person> PersonList new List<Person>(){new Person(){ Id1,ParentIDnull,Name"小明曾祖父",},new Person(){ Id2…

python文件自动化(4)

接上节课内容&#xff0c;在开始正式移动文件到目标文件夹之前&#xff0c;我们需要再思考一个问题。在代码运行之前&#xff0c;阿文的下载文件夹里已经存在一些分类文件夹了&#xff0c;比如图例中“PDF文件”这个文件夹就是已经存在的。这样的话&#xff0c;在程序运行时&am…

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext new ClassPathXmlApplicationContext("bean.xml"); } BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanFactory的功能相似&#xff0c;都是…

linux 安装redis

1. 更新系统和安装依赖 sudo apt update sudo apt install build-essential tcl2. 下载 Redis 源码(没有opt文件夹&#xff0c;则先创建opt文件夹) cd /opt wget http://download.redis.io/releases/redis-6.2.6.tar.gz3. 解压和编译 Redis 解压下载的文件&#xff0c;并进入…

Qt/C++编写的Onvif调试助手调试神器工具/支持云台控制/预置位设置等/有手机版本

一、功能特点 广播搜索设备&#xff0c;支持IPC和NVR&#xff0c;依次返回。可选择不同的网卡IP进行对应网段设备的搜索。依次获取Onvif地址、Media地址、Profile文件、Rtsp地址。可对指定的Profile获取视频流Rtsp地址&#xff0c;比如主码流地址、子码流地址。可对每个设备设…

深入了解以太坊

1. 以太坊编程语言和操作码 以太坊中智能合约的代码以高级语言编写&#xff0c;如 Serpent、LLL、Solidity 或 Viper,并可转换为 EVM 可以理解的字节码&#xff0c;以便执行。 Solidity 是为以太坊开发的高级语言之一&#xff0c;它具有类似 JavaScript 的语法&#xff0c;可以…

用广播星历计算卫星运动的平均角速度

用广播星历计算卫星位置 1.计算卫星运动的平均角速度 首先根据广播星历中给出的参数计算参考时刻的平均角速度: 式中&#xff0c;GM为万有引力常数G与地球总质量M之乘积&#xff0c;其值为GM3.98600510^14b m3/s2。 然后根据广播星历中给定的摄动参数计算观测时刻卫星的平均…

使用AI写WebSocket知识是一种怎么样的体验?

一、WebSocket基础知识 1. WebSocket概念 1.1 为什么会出现WebSocket 一般的Http请求我们只有主动去请求接口&#xff0c;才能获取到服务器的数据。例如前后端分离的开发场景&#xff0c;自嘲为切图仔的前端大佬找你要一个配置信息的接口&#xff0c;我们后端开发三下两下开…

JDBC:连接数据库

文章目录 报错 报错 Exception in thread “main” java.sql.SQLException: Can not issue SELECT via executeUpdate(). 最后这里输出的还是地址&#xff0c;就是要重写toString()方法&#xff0c;但是我现在还不知道怎么写 修改完的代码&#xff0c;但是数据库显示&#…