- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
假设这个 dll 引用链
Tests.dll >> Automation.dll >> White.Core.dll
在 Tests.dll 中使用以下代码行,构建所有内容
result.MissingPaths
现在当我把它改成
result.MissingPaths.Count()
我收到以下 Tests.dll 构建错误“White.UIItem 未在未引用的程序集中定义。您必须添加对 White.Core.dll 的引用。”我不想这样做,因为它会破坏我的层次感。
这是result的类型定义,在Automation.dll中
public class HasResult
{
public HasResult(IEnumerable<string> missingPaths )
{ MissingPaths = missingPaths; }
public IEnumerable<string> MissingPaths { get; set; }
public bool AllExist
{
get { return !MissingPaths.Any(); }
}
}
在调用链中,通过(TreeNode 类在 White.Core.dll 中)创建此 ctor 的输入参数
assetPaths.Where(assetPath => !FindTreeNodeUsingCache(treeHandle, assetPath));
为什么在 IEnumerable 上调用 Count() 时会泄漏此依赖项?然后我怀疑是懒惰的评估导致了这个(出于某种原因) - 所以我在上面的行中插入了一个 ToArray() 但没有工作。
2011 年 01 月 7 日更新:越来越好奇!在我添加 White.Core 引用之前它不会构建。所以我添加了一个引用并构建它(为了找到难以捉摸的依赖源)。在 Reflector 中打开它,列出的唯一引用是 Automation、mscorlib、System.core 和 NUnit。所以编译器丢弃了 White 引用,因为它不需要。 ILDASM 还确认没有白色 AssemblyRef 条目。
关于如何深入了解这件事的任何想法(主要是出于“现在我想知道为什么”的原因)?这是 VS2010/MSBuild 错误的可能性有多大?
更新 2011 01 07 #2根据 Shimmy 的建议,尝试将该方法显式调用为扩展方法
Enumerable.Count(result.MissingPaths)
它停止抄袭(不知道为什么)。
然而,在那之后我移动了一些代码,现在我在不同的位置使用 IEnumerable 遇到了同样的问题——这次是从磁盘上的文件中读取和过滤行(与 White 完全无关)。这似乎是一个“症状修复”。var lines = File.ReadLines(aFilePath).ToArray();
再一次,如果我删除 ToArray() 它会再次编译 - 似乎任何导致计算可枚举的方法(ToArray、Count、ToList 等)都会导致这种情况。让我尝试获得一个可用的微型应用程序来演示此问题...
更新 2011 01 07 #3呸!更多信息.. 事实证明问题只出在一个源文件中——这个文件是 LINQ-phobic 的。必须显式调出对 Enumerable 扩展方法的任何调用。我所做的重构导致一个新方法被移动到这个源文件中,它有一些 LINQ :) 仍然不知道为什么这个类不喜欢 LINQ。
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using G.S.OurAutomation.Constants;
using G.S.OurAutomation.Framework;
using NUnit.Framework;
namespace G.S.AcceptanceTests
{
public abstract class ConfigureThingBase : OurTestFixture
{
....
private static IEnumerable<string> GetExpectedThingsFor(string param)
{
// even this won't compile - although it compiles fine in an adjoining source file in the same assembly
//IEnumerable<string> s = new string[0];
//Console.WriteLine(s.Count());
// this is the line that is now causing a build failure
// var expectedInfo = File.ReadLines(someCsvFilePath))
// .Where(line => !line.StartsWith("REM", StringComparison.InvariantCultureIgnoreCase))
// .Select(line => line.Replace("%PLACEHOLDER%", param))
// .ToArray();
// Unrolling the LINQ above removes the build error
var expectedInfo =
Enumerable.ToArray(
Enumerable.Select(
Enumerable.Where(
File.ReadLines(someCsvFilePath)),
line => !line.StartsWith("REM", StringComparison.InvariantCultureIgnoreCase)),
line => line.Replace("%PLACEHOLDER%", param)));
更新 2011 01 11 #4将范围缩小到看似犯罪但没有动机的范围:)
周末后恢复了任务……并使用常绿的消除过程,能够在有问题的位置上进行区域划分。问题是 Tests.dll 源文件中的以下 using 指令
using G.S.OurAutomation.Framework;
接下来,我追踪了这个命名空间中最有可能的嫌疑人,我在聚光灯下找到了 WhiteExtensions。
namespace G.S.OurAutomation.Framework
{
public static class WhiteExtensions
{
public static T PollAndGet<T>(this Window parentWindow, string automationId) where T : UIItem ...
public static Window WaitForWindowWithTitle(this Application application, string windowTitle) ...
public static bool HasTreeNode(this Tree treeHandle, string assetPath) ...
public static HasTreeNodesResult HasTreeNodes(this Tree treeHandle, IEnumerable<string> assetPaths)...
}
}
这导致了 3 个修复,都有效。
G.S.OurAutomation.Framework.White
虽然我的具体实例是固定的,但此更新可以帮助某人解释这是什么原因吗?如果不是 shimmy 得到勾号 :) 指向正确的方向。
最佳答案
尝试调用 System.Linq.Enumerable.Count(result.MissingPaths)
(有或没有完整的命名空间引用)。
Count
是一个扩展方法,您可以显式调用它。
Gishu 更新#2 后的更新:
道理都是一样的,ToArray
、Count
、ToList
等函数都是System.Linq.Enumerable
中声明的扩展方法.
顺便说一句,重要:您是否仔细检查过命名空间 System.Linq 是否已导入(using System.Linq
)到您的文件?这甚至可能会解决您所有的问题。
关于c# - 为什么调用 IEnumerable<string>.Count() 会创建额外的程序集依赖项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4613600/
C#内部访问修饰符的定义是内部:只能在包含程序集或友元程序集内访问。所以我的问题是什么是 C# 程序集?在包含程序集或 friend 程序集之内是什么意思?它是否意味着在同一个命名空间或项目中? 最佳
任何人都可以回答以下问题。我正在使用 c# 语言。 我可以将程序集调用为 .ddl 或 .exe 文件吗? 我可以将 Assembly Manifest 称为程序集吗? 程序集、元数据和程序集 lis
我正在从 Python 运行一个 .NET COM 程序集,只有当我将程序集 dll 和依赖项复制到我的 Python 根路径 c:\Python27 时才能使它正常工作。 这是不整洁的,所以我想将
作为世界上任何一名程序员,他/她一生中至少有一次,我正在尝试创建我的“革命性”,新的且唯一的操作系统。 :D 好吧,我正在使用虚拟模拟器(Oracle VM Virtual Box),为此我创建了一个
我创建了以下程序来读取 5 个数字,然后 dumpreg查看输入的数字... INCLUDE Irvine32.inc .data count = 5 scor
如何在保护模式下执行 IN 和 OUT 等受限指令? 我发现它需要足够高的特权级别(CPL)才能执行 IO 指令。我怎样才能在内核模式下运行,拥有 IO 权限或任何其他可能对我有帮助的东西? - 我希
目录 C# 程序集、模块和类型概念及关系 概述 程序集 模块 类型 程序集、模块和类型的关系 总结 引用
构建 maven assembly ,我留下了这样的东西: ${project.basedir} / LICENS
我的应用程序由几个核心程序集和几个扩展/插件程序集组成。为了让 MEF 知道插件必须提供的所有部件,即使我永远不会使用它们的任何部件,我也必须加载这些程序集。这使得应用程序需要更多时间来启动(如果我要
我对我们的构建基础结构有一个非常具体的要求,即将另一个 JAR 依赖项的一些内容复制到我的 Web 应用程序的特定子文件夹中。我们正在使用 maven-assembly-plugin,一个自然的方法是
为什么下面的指令会设置符号标志? mov al,0FEh sub al,2 据我了解,AL寄存器可以保存2^8 - 1或255。0FEh = 254(十进制)。减去 2 叶 252。这似乎是正数。 (
我以前使用过 NUnit,但已经有一段时间了,而且从来没有在这台机器上使用过。我在 Program Files 下解压了 2.4.8 版本,并且在尝试加载测试时不断收到此错误。 Could not l
我说的是一个使用 C# 进行游戏编程的小型游戏引擎。所以,我有一个嵌入单声道运行时的 C++ 应用程序(我称之为“启动器”)。我有一个用 C# 编写的程序集,它是我的游戏引擎类库。启动器按照 Embe
我对汇编相当陌生,并尝试从标准输入读取值(从 C 调用 scanf 函数)并将其打印回标准输出(使用 printf)。 .text readstr: .asciz "%d" #strin
谢谢帮助,我的问题是关于从下面的代码中收到的 ax 值? mov al,22h mov cl,0fdh imul cl 真机结果:ff9a 我的预期:00:9a(通过二进制相乘) 第一个数字是 22h
我正在开发一个汇编程序,该程序将整个文本文件读入缓冲区,然后将其显示在控制台中。它立即显示 24 行(每行的最大长度为 80,因为我使用 80 宽 * 25 高的 dossbox )然后等待用户输入,
我正在使用一个简单的程序集片段,使用 BIOS 作为引导加载程序的一部分将字符打印到屏幕上。这是引导加载程序代码。 [org 0x7c00] [bits 16] %include "a20_check
我只是想知道这段代码是什么意思: XOR EAX,EBX XOR EBX,EAX XOR EAX,EBX 最佳答案 那是 xor swapping . 在寄存器上执行它不会遇到常见的难看的失败案例。
我在新电脑上的 XNA 项目开始出现奇怪的错误。我有两个关于解决方案的项目和一个由它们使用的库。其中一个项目,一个 XNA 游戏项目,运行完美。另一个项目是 WindowsForm 和 XNA 的混合
是的,我正在努力实现类似的目标 __asm__(jmp label;); 其中 label 应替换为内存中保存的字符串值(结构体的字段)。 有没有办法做到这一点(或类似的方法可以让我跳转到运行时确定的
我是一名优秀的程序员,十分优秀!