- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这是我的示例场景。我有一个控制台应用程序和一个类库 dll(称之为 libraryA)。 LibraryA dll 引用了 Oracle.DataAccess.dll 版本 4.112.2.0。 Oracle DLL 位于 GAC 中。 LibraryA 中对 Oracle DLL 的引用是“Copy Local = false”。到目前为止,一切都很好。如果您构建 libraryA dll,则 Oracle.DataAccess.dll 不会显示在其输出目录中。好的。现在我在我的控制台应用程序中引用了 libraryA dll。对 libraryA dll 的引用是“copy local = true”。现在,当我构建控制台应用程序时,Oracle.DataAcess.dll 确实出现在控制台应用程序的输出目录中。但是,看起来以这种方式运行的唯一 DLL 是 Oracle dll。这是来自 LibraryA 的完整代码
public void Foo() {
Oracle.DataAccess.Client.OracleConnection c = new Oracle.DataAccess.Client.OracleConnection();
WebMatrix.WebData.OAuthAccountData x = new WebMatrix.WebData.OAuthAccountData("asd", "asd");
DevExpress.Web.ASPxCallback.ASPxCallback cvv = new DevExpress.Web.ASPxCallback.ASPxCallback();
}
WebMatrix 和DevExpress 也和Oracle DLL 一样在GAC 中。但是,这些 DLL 都不会输出到输出目录,只有 Oracle dll。 为什么?这里发生了什么事?
为此,您可以创建另一个类库,将其命名为 libraryB,不要将 libraryB 放入 GAC,从 LibraryA 引用 LibraryB 并设置 copy local = false。即使您这样做,libraryB 也不会复制到控制台应用程序的输出目录。当然,在这种情况下,程序会因为找不到库 B 而崩溃,但至少 Visual Studio 尊重复制本地标志 = false。这个愚蠢的 Oracle DLL 有什么不同?
哦,还有一件事很有趣。如果在我的控制台应用程序中,我显式添加对 Oracle.DataAccess.dll 的引用,并说复制本地 = false,然后它不会显示在输出目录。 不在输出目录中显示 DLL 似乎有点好笑,我必须实际引用它:)
编辑:
另一个线索。 Oracle 为了折磨开发者,没有为 AnyCPU 构建一个 DLL。他们有 x86 和 x64 版本。在我的例子中,我引用了一个 x86 版本并为 AnyCPU 构建。但是,如果我为 x86 构建(以匹配 oracle dll),则 Oracle DLL 不会复制到输出目录。在 AnyCPU 中构建时,MSBUILD 说:“警告 MSB3270:正在构建的项目“MSIL”的处理器架构与引用“Oracle.DataAccess,Version=4.112.2.0,Culture=neutral,PublicKeyToken=89b483f429c47342,processorArchitecture=x86”的处理器架构不匹配, "x86"。这种不匹配可能会导致运行时失败。请考虑通过配置管理器更改项目的目标处理器架构,以便使项目和引用之间的处理器架构保持一致,或者依赖于具有处理器架构的引用匹配您项目的目标处理器架构。”所以,看起来 Msbuild 最终决定,好吧,你有一个不匹配,所以让我继续将这个 dll 复制到你的输出目录,从而保证你的应用程序会崩溃。 :)
最佳答案
不引用它,就是让它使用隐式规则。好吧,这里隐含的默认值是“将其复制到本地”,因为大多数 dll 不在 GAC 中。 IDE 有默认“让它工作”的疯狂概念,这意味着“假设它不会在 GAC 中”。
如果你想使用明确的规则,那么是的:你需要告诉它你想要什么。你这样做的方法是添加一个引用,然后设置你想要的选项。
关于c# - 程序集在不应该的时候被复制到本地,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14923804/
我正在编写一个应用程序,允许用户创建一个“问卷”,然后向其中添加问题。我正在使用核心数据来存储信息。我创建了一个问卷实体,并与问题实体建立了“一对多”关系。我的问题是,如果要允许用户复制(复制)整个调
有没有办法复制或复制 SharedPreference?或者我需要从一个变量中获取每个变量,然后将它们放入另一个变量中吗? 最佳答案 尝试这样的事情: //sp1 is the shared pref
下面的(A)和(B)有区别吗? (假设 NON ARC,如果重要的话) // --- (A) --- @interface Zoo : NSObject{} @property (copy) Dog
我正在尝试将 mysql SELECT 查询保存到文件中,如下所示: $result = mysqli_query($db,$sql); $out = fopen('tmp/csv.csv', 'w'
我需要创建一个 CVPixelBufferRef 的副本,以便能够使用副本中的值以按位方式操作原始像素缓冲区。我似乎无法使用 CVPixelBufferCreate 或 CVPixelBufferCr
我在 Source 文件夹中有一个 Active wave 录音 wave-file.wav。我需要使用新名称 wave-file-copy.wav 将此文件复制到 Destination 文件夹。
在使用 GNU Autotools 构建的项目中,我有一个脚本需要通过 make 修改以包含安装路径。这是一个小例子: configure.ac: AC_INIT(foobar, 1.0) AC_PR
我想将 SQL 的行复制到同一个表中。但是在我的表中,我有一个“文本”列。 使用此 SQL: CREATE TEMPORARY TABLE produit2 ENGINE=MEMORY SELECT
谁能给我解释一下 df2 = df1 df2 = df1.copy() df3 = df1.copy(deep=False) 我已经尝试了所有选项并执行了以下操作: df1 = pd.DataFram
Hazelcast 是否具有类似于 Ehcache 的复制? http://www.ehcache.org/generated/2.9.0/pdf/Ehcache_Replication_Guide.
我有以下拓扑。一个 Ubuntu 16.04。运行我的全局 MySQL 服务器的 Amazon AWS 上的实例。我想将此服务器用作许多本地主服务器(Windows 机器 MySQL 服务器)的从服务
使用 SQLyog,我正在测试表中是否设置了正确的值。我尝试过 SELECT type_service FROM service WHERE email='test@gmail.com' 因此,只输出
有人可以提供一些关于如何配置 ElasticSearch 进行复制的说明。我在 Windows 中运行 ES,并且了解如果我在同一台服务器上多次运行 bat 文件,则会启动一个单独的 ES 实例,并且
一 点睛 ThreadGroup 复制线程的两个方法。 public int enumerate(Thread list[]) // 会将 ThreadGroup 中的 active 线程全部复制到
一 点睛 ThreadGroup 复制线程组的两个方法。 public int enumerate(ThreadGroup list[]) // 相对于 enumerate(list,true) pu
官方documentation Cassandra 说: Configure the keyspace and create the new datacenter: Use ALTER KEYSPAC
This question already has answers here: How to weight smoothing by arbitrary factor in ggplot2? (2个答
我们有一个表格来表明对各种俱乐部的兴趣。输出将数据记录在 Excel 电子表格中,其中列有他们的首选姓名、姓氏、电子邮件、代词,以及他们感兴趣的俱乐部的相应列中的“1”(下面的模型)。 我们希望为俱乐
This question already has answers here: Closed 8 years ago. Possible Duplicate: In vim, how do I get
如何复制形状及其所在的单元格?当我手动复制时,形状会跟随单元格,但是当我使用宏进行复制时,我会得到除形状之外的所有其他内容。 Cells(sourceRow, sourceColumn).Copy C
我是一名优秀的程序员,十分优秀!