对于.NET 应用的开发人员而言,以 Visual Studio(简称 VS)作为首选的开发工具应当是一种最自然不过的选择了。毕竟这款 IDE 提供了各种优秀的特性:智能提示、调试、包管理等等,而且如今绝大部分特性在免费的 Community 版本中都可以任意使用。这样看来,似乎已经没有选择其他工具的必要了。
话虽如此,但在某些场合下我们仍然可以选择脱离 Visual Studio 这样的 IDE 而进行.NET 代码的开发。最近,一位名叫 Patrick Lambert 的开发者在他的博客文章中介绍了不使用Visual Studio 进行.NET Windows 应用的过程。
Patrick 认为,选择脱离 VS 环境进行开发有几点可能的理由:一是开发者或许想深入地了解一下.NET 应用的编译过程,而不希望被图形用户界面蒙蔽了双眼。二是开发者或许出于某些原因,例如平台或工作环境的原因而无法安装 VS。三是开发者只打算开发一个非常简单的应用,为了一个 5KB 大小的应用去下载一个 5GB 大小的 IDE 好像有些太过奢侈。如果以上任何一点原因适用于你的情况,就可以考虑尝试一下 Patrick 的教程。
必备依赖
在开始编码之前,首先看看有哪些依赖项是必须的,这里假设我们选择 C#语言开发基于.NET Framework 的应用。好消息是.NET Framework 不再依赖于其他组件,只要在操作系统中安装过它,就无需再安装任何组件了!而且许多系统在安装时会自动包括.NET Framework,可以通过检查 C:\Windows\Microsoft.NET\Framework
目录确认是否已安装。在这个目录下会列出每个已安装的版本的子目录。
接下来要搞定编译的问题,在.NET Framework 中已经自带了 C#编译器。这篇教程中要用到两个二进制文件,其中csc.exe
就是 C#编译器,而msbuild.exe
则是负责读取项目文件(例如.csproj 文件)并进行编译的工具。也就是说,如果某人发送给你一个 Visual Studio 项目文件,那么你也能够在不安装 Visual Studio 的情况下,通过运行msbuild
对源代码进行编译。
.NET 项目的结构
Patrick 接下来介绍了 VS 项目的结构,虽然在本篇教程中不需要创建项目文件,但对项目结构的理解可以帮助我们了解一些概念。通常来说,在新建 Windows 项目时,VS 会自动创建一个Program.cs
文件作为入口、一个包含了代码所依赖资源信息的.csproj
文件、包含二进制名称、版本号等信息的AssemblyInfo.cs
文件,以及包含了自定义配置信息的App.config
文件。其中 App.config 这个文件主要的用途是配置一些相关的依赖信息,例如数据库连接字符串、Social Login 的帐号等等。
主体代码
接下来,Patrick 展示了一段非常简单的代码。由于这篇教程不使用 Visual Studio 等 IDE,因此可以随意选择最喜爱的文本编辑器编写以下代码,并保存为 helloworld.cs 文件:
using System; namespace HelloWorld { public class Program { static void Main(string[] args) { Console.WriteLine("Hello world!"); } } }
如你所见,这段代码的作用就是简单地在控制台中输出“Hello World!”而已。因为我们的专注点不在 C#代码本身,因此不必纠结于它太过简单。编译指令也很简单,只需指定编译器文件的位置,通过/out:
参数指定的输出文件,并在最后指定源代码文件,就能够创建可运行的应用程序了。参考如下命令:
E:\code> C:\Windows\Microsoft.NET\Framework\v3.5\csc.exe /out:helloworld.exe helloworld.cs Microsoft (R) Visual C# 2008 Compiler version 3.5.30729.5420 for Microsoft (R) .NET Framework version 3.5 Copyright (C) Microsoft Corporation. All rights reserved. E:\code> helloworld Hello world! E:\code>
添加程序集信息
现在你已经得到了这个可运行的 exe 文件了,但如果右键检查一下文件的详细信息,你会发觉诸如文件描述、版本号与版权等信息都是空白的。这些信息应该是由程序集所定义的,而通常我们都是在 VS 中填写这些信息的。其实即使没有 VS 也一样简单,只需修改一下 helloworld.cs 即可:
using System; using System.Reflection; [assembly: AssemblyTitle("Hello World Application")] [assembly: AssemblyCopyright("(C) 2015 John Doe")] [assembly: AssemblyFileVersion("1.0")] namespace HelloWorld { // class definition }
这里省略了类的定义,因为这部分没有任何变化。变化之一是引入了System.Reflection
这个命名空间,随后为程序集提供了相应的信息。当我们再次编译后,就能够在可运行文件的详细信息中找到他们了。
具有图形界面的应用
在介绍了控制台应用的创建之后,Patrick 又介绍了脱离 VS 进行图形界面应用的创建过程。微软现在推荐通过 XAML 语言创建统一应用,这种语言基于 XML 定义应用的界面。不过出于简单起见,Patrick 在这里选择了创建基于 Windows Forms 的桌面应用。
经过修改的 helloworld.cs 代码如下:
using System; using System.Reflection; using System.Windows.Forms; [assembly: AssemblyTitle("Hello World Application")] [assembly: AssemblyCopyright("(C) 2015 John Doe")] [assembly: AssemblyFileVersion("1.0")] namespace HelloWorld { public class Program { static void Main(string[] args) { MessageBox.Show("Hello world!", "Hi!"); } } }
这段代码与改动前非常相似,一个变更是引入了System.Windows.Forms
命名空间,另一个则是通过 MessageBox 输出信息。在运行时,Windows 系统会自行处理图形窗口的创建等工作。运行结果如下:
引用第三方类库
最后,Patrick 介绍了如何在应用中引用第三方资源,这次的代码通过使用 Amazon AWS SDK 实现了一个发送短消息通知的功能:
using System; using Amazon; using Amazon.SimpleNotificationService; using Amazon.SimpleNotificationService.Model; namespace AwsSnsSample { class Program { public static void Main(string[] args) { var sns = new AmazonSimpleNotificationServiceClient(); sns.Publish(new PublishRequest { Subject = "Hi!", Message = "Hello world!", TopicArn = "arn:aws:sns:us-west-2:0000000000:snstest1" }); } } }
在进行编译之前,首先要下载一个 AWS SDK ,并设置相应的 IAM 帐号,以用于发送信息。在编译命令中,要点在于通过/r:
选项指定 AWS 的引用:
E:\code> C:\Windows\Microsoft.NET\Framework\v3.5\csc.exe /out:helloworld.exe /r:"C:\Program Files (x86)\AWS SDK for .NET\bin\Net35\AWSSDK.dll" helloworld.cs
虽然本文中所介绍的应用比较简单,但其实原理都是相通的,通过类似的方法也可以创建基于 ASP.NET、Azure 或 WPF 等应用。虽然 Patrick 并不建议在专业应用开发中采取这种比较原始的方式,但了解这一过程能够帮助.NET 开发者理解编译的过程,这些知识点将对他们在进行专业应用开发中提供很大的帮助。
感谢董志南对本文的审校。
给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ , @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群(已满),InfoQ 读者交流群(#2))。
评论