zoukankan      html  css  js  c++  java
  • 插件框架之BUILD WITH RUNTIME PACKAGE选项

    主控程序(通常是EXE程序),各插件(DLL/BPL),它们都是独立的工程,它们组成一个工程组。

    1. 主控程序和各插件工程中,BUILD WITH RUNTIME PACKAGE都勾选上。整个程序运行的时候,保障了所有的VCL对象只有唯一的一份,杜绝了VCL对象相互之间发生冲突的可能性。此种方式最为稳定和安全,建议使用此方式。但此种方式有一个缺点:发布程序的时候,DELPHI RTL包,第三方控件的BPL运行时包要一起打包发布,否则程序将不能运行。此种方式编译出来的EXE/DLL/BPL一般体积会比较小,往往只有几百K,因为运行时包没有编译进来。

    2. 主控程序和各插件工程中,BUILD WITH RUNTIME PACKAGE都不勾选上。整个程序运行的时候,同一个VCL对象可能存在有多份,容易产生对象访问的冲突。在使用一些三方控件的时候,更加容易发生冲突。此种方式也可行,一般在装载DLL的时候需要传递主控程序的APPLICATION给DLL(要保存好DLL原来的APPLICATION),在DLL释放的时候则要还原DLL原来的APPLICATION,  否则在释放DLL的时候会报“非法访问内存”的错误。此种方式也有一好处:发布程序的时候,DELPHI RTL包,第三方控件的BPL运行时包不要打包进来。此种方式编译出来的EXE/DLL/BPL一般体积会比较大,往往有几M,因为运行时包都编译进来了。

    3. 有些三方控件可能只能使用第一种方式,程序才能正常运行。具体项目中可能需要验证后才能作出决定。

  • 相关阅读:
    BZOJ 1049: [HAOI2006]数字序列
    BZOJ 1048: [HAOI2007]分割矩阵
    BZOJ 1047: [HAOI2007]理想的正方形
    BZOJ 1046: [HAOI2007]上升序列
    BZOJ 1045: [HAOI2008] 糖果传递
    Flink学习(十三) Flink 常见核心概念分析
    Flink学习(十二) Sink到JDBC(可扩展到任何关系型数据库)
    Flink学习(十一) Sink到Elasticsearch
    Flink学习(十) Sink到Redis
    Flink学习(九) Sink到Kafka
  • 原文地址:https://www.cnblogs.com/hnxxcxg/p/2368700.html
Copyright © 2011-2022 走看看