不用 Visual Studio 也能开发.NET Windows 应用

阅读数:2414 2015 年 12 月 29 日

话题:.NET语言 & 开发架构

对于.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))。