`

Manifest的问题

阅读更多
原始连接:http://www.zming.net/blog/index_en.php?itemid=183

Manifest的问题
嗯 开始试着使用免费下载的Visual Studio 2005 Express Edition了
还是挺好用的,以前的很多程序也都顺利地移植到了新的开发环境下,编译器和IDE都多了好多选项,正在熟悉中
比较困惑的是Manifest,呵呵 编译出来的程序 即使是Native的,离了它也运行不了,会找不到dll报错,除非把它embed进exe文件

后来查了查 基本明白了,具体的说是这样的:

dll是被动态调用的,所以会被若干个程序共享使用的 但是如果dll在应用程序不知道的情况下升级了、或是被另一个程序更改了,就可能会出现问题,即"DLL Hell"

随着系统资源越来越丰富,硬盘不那么紧张,所以在XP以后的操作系统中,用新的机制来管理DLL
(这种机制,这不仅仅是对于.NET而言,对于普通的Native程序也是一样的)

Madifest是个XML的描述文件,对于每个DLL有DLL的Manifest文件,对于每个应用程序Application也有自己的Manifest

对于应用程序而言,Manifest可以是一个和exe文件同一目录下的.manifest文件,也可以是作为一个资源嵌入在exe文件内部的(Embed Manifest)

XP以前版本的windows,会像以前那样执行这个exe文件,寻找相应的dll,没有分别
Manifest只是个多余的文件或资源,dll文件会直接到system32的目录下查找,并且调用

而XP以后的操作系统,则会首先读取Manifest,获得exe文件需要调用的DLL列表
(此时获得的,并不直接是DLL文件的本身的位置,而是DLL的manifest)
操作系统再根据DLL的Manifest去寻找对应的DLL
<因此就可能区别不同版本的同一个DLL文件,或是指定一个程序本身Isolated的DLL>

不过使用Visual Studio 2005以后的一个新问题是,
VS2005带的8.0新版的C运行库(VC 8.0 CRT)文件在XP以后支持manifest的Windows版本中被调用时,
将会check一下Application自身的Manifest,否则将会拒绝被调用
这也就是说,使用Visual Studio开发的Application,Manifest将是必不可少的
(搞不懂MS为啥要这样设置,所以与VS2003.NET不同了)
(后来想想,除了MS自己说的哪些冠冕堂皇的原因,至少这样一来Linux的Wine模拟要麻烦多了)

除非,你的程序是静态链接的,没有使用dll,只使用了操作系统核心的 Kernel32.dll, User32.dll, Ole32.dll, 或ShDocVW.dll 等
project的设置必须是Use Standard Windows Libraries、Not Using ATL、No Common Language Runtime support
那么你可以不需要考虑Manifest 可以关掉它

VS2005中Menifest相关的设置:
  Project/Properties/Linker/Manifest File/Generate Manifest  决定是否生成Manifest,如上情况才可以关闭
  Project/Properties/Linker/Manifest File/Allow Isolation      这个是设置DLL的调用的,并不能决定Manifest是否还是必须的
  Project/Properties/Manifest Tool/Input and Output/Embed Manifest  决定Manifest是个单独的文件还是嵌入到exe内的资源

【对于我来说,使用SDL必须是启用DLL的动态链接方式,所以必须开启Manifest,并且让Manifest Embed进入exe比较方便】
【与上面内容相应的 是关于如何发布软件的问题,事实上只有VC6.0的CRT库是绑定作为Windows的一部分的,之后从VS.net开始,VC程序制作安装包也是要考虑库文件的,只不过VC6.0时推荐拷入System32,VC.net时推荐放在exe文件local目录,而现在VS2005则还需要考虑Manifest的问题了,看似麻烦,其实也还好,VS自带工具打包,下面一些网址也有讲如何手工做redistribution】

参考网址:
http://msdn2.microsoft.com/en-us/library/ms235342.aspx
http://msdn2.microsoft.com/en-us/library/ms235265.aspx
http://msdn2.microsoft.com/en-us/library/8kche8ah.aspx
http://blog.kalmbachnet.de/?postid=54
http://blogs.msdn.com/nikolad/archive/2005/03/18/398720.aspx
分享到:
评论

相关推荐

    jquery-manifest.js

    jQuery Manifest插件正是为了解决这个问题,它自动化地处理AppCache的更新和同步,使得开发者能更专注于应用逻辑。 **工作原理** 1. **动态生成清单文件**:jquery-manif会动态生成或更新AppCache清单文件...

    Java程序创建Manifest文件

    当我们需要运行一个与其他jar文件有关联jar文件时,如果jar文件里面的MANIFEST.MF文件没有配置好,那在运行时就要报异常:Exception in thread "main" java.lang.NoClassDefFoundError。原因:未找到关联jar文件里面...

    MANIFEST.MF 读写操作

    MANIFEST.MF 文件是 Java 应用程序和库的核心组件,特别是在创建 JAR 文件时。它包含关于 JAR 文件的元数据,如主类、版本信息、依赖库和其他重要属性。在本文中,我们将深入探讨如何在 Java 中读取和写入 MANIFEST....

    manifest.json(文档标准格式).rar

    如果manifest.json存在语法错误或缺少必要字段,这些工具会给出错误提示,帮助开发者快速定位并修复问题。 总结来说,manifest.json是现代Web技术和应用程序的核心组成部分,它为应用提供了清晰的标识和行为规范。...

    MANIFEST文件配置

    ### MANIFEST 文件配置详解 #### 一、MANIFEST 文件概览 **MANIFEST** 文件是 Java 归档文件 (JAR, Java Archive) 中的重要组成部分,它存储了 JAR 文件的相关元数据信息。MANIFEST 文件通常命名为 `manifest.mf`...

    Manifest生成器

    总之,Manifest生成器是VB6开发者解决UI主题兼容性问题的一个实用工具,它简化了复杂的手动配置过程,使得旧版VB6程序也能享受到现代操作系统的视觉增强。对于那些仍在维护VB6项目的人来说,这是一个非常有价值的...

    MANIFEST.MF 文件内容详解(转)

    标题中的"MANIFEST.MF 文件内容详解(转)"是指一篇关于理解Java应用程序的MANIFEST.MF文件的文章。MANIFEST.MF文件是Java档案(JAR)文件格式的一部分,它包含了有关JAR文件元数据的重要信息。这篇博文可能是从其他...

    清单文件.manifest

    对于VS2005中的SDK V2.0,清单文件主要用来解决UAC(User Account Control,用户账户控制)问题。UAC是Windows Vista及更高版本操作系统的一项安全特性,它要求应用程序在执行特定操作时必须具有管理员权限。如果...

    Manifest_UFSFiles_Android

    Manifest_UFSFiles_Android.txt

    steam-appmanifest, 在 ~/.steam/steam/SteamApps 中,生成 appmanifest_APPID.acf 文件.zip

    steam-appmanifest, 在 ~/.steam/steam/SteamApps 中,生成 appmanifest_APPID.acf 文件 Steam AppManifest生成器这是一个简短的python 脚本,可以让 Steam 下载到下载非Linux应用程序中。注:Steam 不会运行没有...

    mt.exe 导入manifest信息的工具

    用来导入manifest信息的工具

    使VC6可以实现xp风格的manifest文件

    xpStyle.manifest 用记事本或其它文本编辑工具手动修改工程目录下的资源文件(.rc),在文件最后加上一行: 1 24 "XPStyle.manifest" 编译即可

    manifest.json

    manifest

    android manifest 解密jar

    android manifest 解密jar

    利用HTML5的manifest文件做缓存

    在使用时要考虑不同浏览器的兼容性问题。 4. **离线状态下的交互**:虽然离线状态下可以访问缓存的页面,但与服务器的交互(如提交表单或获取实时数据)将不可用。开发者需要设计适当的离线体验,如显示离线消息或...

    cxf-manifest

    cxf-manifest cxf-manifest

    Laravel开发-laravel-asset-manifest

    `laravel-asset-manifest`是一个针对Laravel 4的扩展包,专门解决这类问题,帮助开发者更有效地管理和映射前端资产路径。 这个包的主要功能是生成一个资产映射文件,它记录了经过处理(例如,压缩、合并或添加版本...

    android Manifest.xml详解

    - 当配置发生改变时,如果未处理好相应的逻辑,可能导致应用出现布局错乱等问题。 - 如果需要监听键盘隐藏/显示的变化,可以使用 `android:configChanges="keyboardHidden"` 这一配置项。 以上是对 Android `...

    VC++程序界面美化(xpstyle.Manifest)

    在描述中提到的“VC++程序界面美化(xpstyle.Manifest)”,主要涉及到的是Windows程序的视觉样式(Visual Styles)以及应用程序清单(Application Manifest)的应用。下面我们将深入探讨这两个关键概念。 1. **...

    manifest-explorer

    3. **搜索和过滤**:快速查找特定设置或关键字,帮助定位问题。 4. **编辑与保存**:可能允许用户直接在工具内修改`manifest`文件,实时预览效果,并保存更改。 5. **比较与差异**:对比不同版本的`manifest`文件,...

Global site tag (gtag.js) - Google Analytics