.net – Windows体系结构中的CLR,Win32,WinRT

我浏览过并发现了类似的问题,所有的反应都不清楚,模糊不清,让我感到很烦恼,因为我没有清楚了解 Windows架构. Windows中有些层在我的脑海中总是看起来像这样(从上到下):

[.净]

[的Win32]

[微内核]

[HAL]

[硬件]

最近我看到这样的图像:

我很困惑,尤其是看起来CLR似乎与WinAPI并行运行.我想我的问题是:

UPDATE
问:在哪里可以找到描述最新版Windows(7,8,Server 2012等)中操作系统架构的清晰和解释性资源?

我会假设这个问题是关于WinRT的,否则完全过于模糊.

底部的图表非常具有误导性.它显示了您作为程序员需要了解的内容.如果你创建一个WinRT应用程序,那么旧的winapi不是你直接处理的东西.它被WinRT api取代,你只能用它来获取操作系统服务.

实施方式非常不同. CLR仍然在winapi上运行,就像在桌面应用程序中一样.它与非托管代码互操作,Windows基本上是一种非托管操作系统.对于WinRT来说,它是一个基于COM的非托管api.

每个WinRT应用程序实际上都是一个进程外的COM服务器,就像30年前使用过的服务器一样.它确实以特殊模式运行,微软在管道中添加了一个额外的层,使UAC工作.它被称为“app容器”,它的工作方式类似于沙盒.就像UAC阻止程序访问某些目录或注册表项一样,如果用户没有通过UAC提示升级,则应用程序容器会阻止程序使用麻烦的winapi函数.导致可用性或安全性问题或者电池耗电过快的类型. WinRT已经取代了这种winapi功能.

COM有点臭名昭着,它是微软使用的通用互操作解决方案,但编程并不是特别容易.微软做了很多工作来使COM更加可用,主要是通过完全隐藏它.值得注意的是,类型库被替换为.winmd文件,这是一个非常强大的版本,可以表达更多细节.他们使用.NET元数据的数据格式.

他们隐藏COM的关键方式是内置于各种运行时支持库中的语言投影.对于C,它隐藏在C/C++X语言扩展和运行时库中.对于Javascript,它隐藏在Chakra执行引擎中.对于托管代码,它隐藏在.NET框架内,并在参考程序集中使用[TypeForwardedTo].语言投影从WinRT类型和行为转换为特定于语言的类型.基本的东西,比如COM错误代码被转换为异常. WinRT HSTRING类型转换为System.String.等等.

在一些地方,语言投影透过裂缝窥视,在奇怪的看似限制中可见.像WinRT组件必须始终是密封类,COM的副作用不支持实现继承.或者,您可以在组件中公开DateTimeOffset,但不能在DateTime中公开.并且一些WinRT类型不能很好地映射到.NET类型,IBuffer是臭名昭着的.

相关文章

(1)when you ping a computer from itsafe,the ping command should return the local IP address. (...
1、点击win菜单,点击设置图标 2、选择系统选项 3、选择应用与程序选项 4、拉到最下方,选择程序与功能...
目前一直直接往Windows 2008 R2 Server中复制文件(暂时还没有搭建ftp服务),突然不能复制了,于是百度...
windows下使用vscode配合xebug调试php脚本 要下载有php_xebug.dll扩展的版本,最新版可能没有这个扩展,p...
在控制面板的程序与功能里启用和关闭windows功能打开,适用于linux的windows子系统
效果演示 推荐一个非常牛的文档网站生成器:docsify 我通过这个工具,成功将码云上的个人学习笔记发布到...