我有用 C 和 C++ 编写控制台和网络客户端/服务器应用程序的经验,但我对使用 win32 视觉 API、MFC、Qt、wxWidgets 等几乎一无所知。从哪里开始是一个好的起点,我应该专注于什么方法,以便为未来做好准备并保持稳健?

有帮助吗?

解决方案

这是一个相当广泛的问题,因为在 Windows 中编程 GUI 应用程序可以通过多种方式完成。

开发任何 GUI 应用程序都有两个主要部分:这 语言API/框架. 。考虑到您有兴趣学习构建 Windows GUI 应用程序,该语言并不是您真正关注的焦点。因此,您应该选择一种您已经了解的语言,并使用您选择的语言可以利用的框架或 API。

如果您想使用 C,您几乎只能自己处理 Win32 API,在这种情况下,请阅读 佩措尔德 或者 里克特 将是很好的起点。Win32 API 可能相当令人畏惧,但它非常值得努力学习(恕我直言)。网上有很多关于 Win32 的教程,而且总有 微软软件定义网络, ,带有 Win32 API 的完整参考/指南。确保您不仅涵盖 API,还涵盖其他领域,例如资源/对话框,因为它们是 Win32 应用程序的构建块。

如果您想使用 C++,您可以使用 C 时的所有选项以及其他一些选项。我建议直接使用 Win32 API,然后转向已知的框架,例如 MFC、Qt、wxWindows 或 GTK,这样您就可以花更少的时间处理样板代码,而专注于编写应用程序逻辑。我刚刚列出的最后 3 个选项具有跨平台的额外好处,因此您不必过多担心特定于平台的问题。鉴于您说您想使用 Windows,我假设您热衷于专注于 Windows 而不是跨平台 - 因此请使用 MFC,但首先花一些时间使用 Win32 API 来熟悉一些的概念。

在处理 MFC 和 Win32 API 时,最好在编写代码之前尝试充分理解术语。例如,您需要了解什么是 消息泵 是,以及它是如何工作的。您需要了解诸如“所有者绘制 控制”,以及 子类化. 。当您了解这些内容(以及更多内容)时,您会发现使用 MFC 更容易,因为它在其类接口中使用类似的术语(例如,您需要先了解“翻译消息”的含义,然后才能了解如何以及何时使用 预翻译消息).

您还可以使用托管 C++ 来编写 .NET GUI 应用程序,但我在一些地方读到托管 C++ 并不是真正打算以这种方式使用的。相反,它应该用作本机/非托管代码和托管代码之间的网关。如果您使用 .NET,最好使用 .NET 语言(例如 VB.NET 或 C#)来构建 GUI。

所以如果你 要使用 .NET,您目前可以选择 窗体 图书馆,或 WPF. 。我个人认为,鉴于 WPF 旨在取代 WinForms 应用程序,您会浪费时间学习构建 WinForms 应用程序。随着时间的推移,WPF 将变得更加流行,而 Winforms 很可能会消亡。WPF 具有更丰富的 API 集,并且不受 Winforms 的许多限制。但是,如果您确实选择这条路线,那么毫无疑问您必须学习 XAML, ,这是一种驱动 WPF 应用程序的标记语言。这项技术已经成熟,有很多很棒的地方可以学习它。首先,有一些网站,例如 学习WPF, , 和 WPF博士 其中有一些非常棒的文章。其次,有 足够质量 图书话题.

因此,总而言之,一旦您选择了语言和技术,这条路实际上就很容易了。只需拿起一两本书,阅读一些博客,了解一些代码示例..最重要的是......写代码。继续写作,继续犯错误,并不断从中学习。

最后一点...

换句话说,Silverlight。如果您不想走 MS 路线,您可以看看 Adob​​e 的 Flash/Flex。Silverlight 和 Flash/Flex 都构建 RIA。我认为这就是我们的前进方向。像 Office 这样的应用程序的日子已经屈指可数了

我一点也不同意。Silverlight 与 WPF 不同。Silverlight 是特定于 Web 的,并且仅具有 WPF 功能的子集。鉴于问题要求的是 Windows GUI 应用程序,Flash/Flex Rich Internet Apps 并不是真正合适的建议。我也不同意富客户端应用程序(例如 Office)的日子已经屈指可数了。

我希望这有帮助。祝你好运 :)

其他提示

我不知道我是否会称其为一个好的起点,但如果您想为未来做好准备,请查看 Windows 演示基础 它完全是为了 Windows 的 GUI 编程而构建的

我第一次为 Windows 编写简单的 GUI 应用程序是使用 C# 和 Visual Studio。GUI 构建界面是一个简单的拖放操作,可根据潜在的用户操作生成框架方法。我只用它进行了相当基本的编程,但我想这将是一个很好的地方,可以开始学习基础知识并逐渐扩展到更高级的功能。

在线 Win32 教程有很多:

http://www.zeusedit.com/forum/viewtopic.php?t=1218

有很多编译器可供选择:

http://www.zeusedit.com/forum/viewtopic.php?t=238

我还建议您获得 Borland Win32 SDK WinHelp 文件格式的文档:

http://www.zeusedit.com/forum/viewtopic.php?t=7

它只涵盖了 Win32 的基本知识,但是在开始时,这会很有帮助,因为它不像 MSDN 那样令人畏惧和臃肿。

我永远不会走 Silverlight、Flash/Flex 或任何类似的路线。它看起来确实不错,但主要问题是运行它的引擎的代码是完全封闭的,并且由一家公司控制。以这两个版本的 64 位版本为例。如果出现一些新平台,您将无法将现有代码迁移到该平台。

对于商业应用程序来说,Windows Forms 已经非常成熟。它提供了一条温和的路径,从为您自动生成大量内容到允许细粒度控制和滚动您自己的内容。有大量高质量的第三方控件和大量示例、文档等。很难遇到别人没有解决的问题。我强烈建议您获取一些 Win32 背景知识(例如 佩措尔德),因为 WinForms 框架位于其之上。

我没有 WPF 经验,但从我看到的示例应用程序来看,对于界面将受益于更多图形隐喻的应用程序来说,它似乎是一个不错的选择。因此,如果您正在开发银行应用程序,可能不值得额外的设计开销。但是,如果您正在开发仓库管理应用程序,则可以通过将漂亮的盒子放入漂亮的垃圾箱中来改进。

@斯蒂芬考克斯:对错误问题的错误回答。OP正在询问桌面客户端应用程序,而且,WPF!= Silverlight。

对于一个简单的起点来了解“事件驱动”的本质,基本上所有框架都是围绕以下内容创建的 FLTK.

以下是一些快速入门视频 关联

对于专业用途,我推荐 Qt,虽然价格昂贵,但在商业环境中通常是值得的。

由于您已经熟悉 C 和 C++,我建议您学习如何使用 Charles Petzold 的书编写简单的 Windows GUI 应用程序。它将让您对 Windows 的工作原理有基本的了解。最好理解的是,您看到的大多数内容都是一个窗口(例如,按钮就是一个窗口),并且这些窗口响应消息。不过,我不会在这方面花费大量时间,而且如果您要选择 WPF,则不一定需要首先执行此操作。我只是认为对此有一个基本的了解是有好处的。

最近 .Net Rocks 上有一个很好的播客,叫做 “Kate Gregory 使用 C++ 为 Vista 进行开发!” 在那儿,她建议现在开始的人不要使用/学习 MFC(即使它最近已更新)。

就为未来做好准备而言,您需要学习 WPF,但它尚未完成,因此根据您想要创建的客户端应用程序的类型,您可能需要学习 WinForms。大多数人尚未使用 WPF,因此现在是开始学习的好时机。我认为您会发现使用 C# 来学习它比使用 C++ 来学习托管代码更容易。

首先要打好基础。我发现的最好的教程是: http://winprog.org/tutorial/start.html

之后,虽然主页惨不忍睹,但教程页面内容和美观都不错: http://www.tenouk.com/cplusmfcdotnet.html

那么当然还有 微软软件定义网络.

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top