“VS2010RC关于WPF开发的X个不同之一——居然多了一个程序集引用”姊妹篇——有图有真相
本不该在这个元宵佳节里写随笔。在这花好月圆时刻应该把酒当歌,莫使金樽空对月。特别是即汶川,海地之后的智利8.8级地震,更加让我嗅到了2012的味道。
但是千不该,万不该,还是让我找到了上一篇的答案,于是没有办法写下来与诸位分享。哥写的真不是寂寞,是答案——有图有真相的答案。
首先如果诸位不熟悉Helloj2ee的问题的,可以参见上一篇:VS2010RC关于WPF开发的X个不同之一——居然多了一个程序集引用
Helloj2ee总结出来的问题是 在VS2008里面 一个WPF程序至少需要四个程序集 system.dll,presentationframework.dll,windowsbase.dll和presentationcore.dll.
而VS2010里或者承蒙怕怕的韦恩卑鄙兄指点,说的准确些是WPF4。那么他需要的是五个程序集,除去刚才四个,还有就是System.xaml.dll。
现在Helloj2ee在这里告诉他的答案。如果在VS2010里编译,会报一个什么错误呢?
error CS0012: The type 'System.Windows.Markup.IQueryAmbient' is defined in an assembly that is not referenced. You must add a reference to assembly 'System.Xaml, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089'.
意思是已经定义了一个IQueryAmbient接口,而这个接口在System.xaml程序集当中。
如果您要去找IQueryAmbient接口,我打保票,您是寻访整个工程都找不到的。如果您在过去的MSDN,我是指3.5SP1的MSDN去搜索IQueryAmbient接口,那也是找不到的。
好在.Net4.0里可以找到的,这里是该接口的官方文档:http://msdn.microsoft.com/en-us/library/system.windows.markup.iqueryambient(VS.100).aspx
关键的修改之处在于FrameworkElement 实现了该接口。该接口是System.xaml.dll程序集当中的,而Window又派生自FrameworkElement,因此需要该程序集的引用。
这个接口非常简单只有一个称之为IsAmbientPropertyAvailable的方法,传递进去的参数是string,返回的是bool型。如下所示:

// Queries for whether a specified property should be treated as ambient in
// the current scope.
public interface IQueryAmbient
{
// Summary:
// Queries for whether a specified named property can be considered ambient
// in the current scope.
//
// Parameters:
// propertyName:
// The name of the property to check for ambience state.
//
// Returns:
// true if the requested property can be considered ambient; otherwise, false.
bool IsAmbientPropertyAvailable(string propertyName);
}
这个接口的作用,我简单看了一下还是为了提高效率的。具体也可以请各位高手指点,我在这里抛砖先,你们尽管砸玉。
如果继续Reflector的话,不难发现原有的System.windows.markup命名空间当中的类和接口有相当一部分从过去的Windowsbase.dll移植到了System.xaml.dll当中。不妨看下面几张图。第一张图是3.0版本下面的WindowsBase.dll中的System.windows.markup当中的类和接口,我只能说挺长,挺多。
下一张就是4.0版本下面的windowsbase.dll当中的System.windows.markup当中的类和接口。
可以看到相比上一张图,类和接口少了不少。不是凭空消失了相当一部分类和接口移到了System.xaml.dll程序集当中了。比如IComponetConnector接口等。下图就是System.xaml程序集当中的关于System.windows.markup当中的类和接口。
在这花好月圆夜,Helloj2ee写下了事实的真相。当然比较凌乱,概括一下就是三点:
(1)WPF4当中 FrameworkElement有所改动,它实现了IQueryAmbient接口,该接口正是传说中的System.xaml程序集中的接口,因此需要引用该程序集,绕不开,躲不过。
(2)实现该接口的目的,由Helloj2ee初步判定是为了提高效率;
(3)原来在3.5SP1之前,WindowsBase.dll承担了部分关于XAML的类和接口,在System.windows.markup明名空间当中,好了4.0来了,他把这当中的部分类和接口放在System.xaml这个程序集里。当然具体还请各位自己查证。
花好月圆,大家元宵快乐。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述