草庐IT

c# - <example></example> XML 注释标记 : how to see it?

我使用MicrosoftVisualStudio2012。当我将代码示例放入C#类/方法的XML注释中时,我想知道:引用我的程序集的用户将如何看到该代码示例?我试图引用我自己的程序集,我找到的唯一方法是:查看assembly.xml文件。我可以安装VisualStudio或其他任何软件来查看这些代码示例吗?这是我在评论中添加的内容://////Thisismymethodexample//////////////Hereismycodeexample.Callmymethodlikethis:///constinta=10;///MethodExample(a);//////publi

c# - Visual Studio 中的 "Add existing item": is it possible to make "Add as link" default?

正如this中指出的那样因此,VisualStudio中的Add>Existingitem对话框默认显示Add按钮(意味着所选项目将被物理复制到新位置),而理想的操作通常(总是?)添加为链接。是否可以配置VisualStudio,以便在打开添加>现有项目对话框时默认选择添加为链接?我已经彻底搜索了VisualStudio中的Options对话框并检查了MSDN文档以找到对此的答案,但到目前为止无济于事。ProjectLinker当两个新项目要共享同一代码库时,自动链接是一个不错的选择。但是,当将大量文件从现有项目链接到新项目时,似乎仅限于Add>Existingitem方法,而且这项工

c# - 有人可以解释测试驱动开发中的 "Fake it till you make it"方法吗?

当您采用“假装直到成功”TDD方法时,我很难理解代码的演变。好吧,你伪造了它,假设你返回了一个常量,所以失败的测试在开始时是绿色的。然后你重构了你的代码。然后你运行同样的测试,它显然会通过,因为你伪造了它!但是如果测试通过了,你怎么能相信它,尤其是当你知道你是伪造的时候?应该如何用您的真实代码重构来重构伪造的测试,以便它仍然可靠?谢谢 最佳答案 简短的回答是:编写更多测试。如果该方法返回一个常量(当它应该计算某些东西时),只需添加一个具有不同结果的条件测试。因此,假设您有以下内容:@TestpublicvoidtestLength(

c# - 在 SelectSingleNode : Retrieving individual element from XML if it's present 中使用 XPath

我的XML看起来像:onetwothree.....maybemoreItemshere.一些单独的Item可能存在也可能不存在。假设我想检索元素两个如果它存在。我尝试了以下XPath(在C#中)。XMLNodenode=myXMLdoc.SelectSingleNode("/itemSet[Item='two']")---如果Itemtwo存在,则它只返回第一个元素one。也许这个查询只是指向itemSet中的第一个元素,如果它在某个地方有一个值为2的Item作为子元素。这种解释正确吗?所以我尝试了:XMLNodenode=myXMLdoc.SelectSingleNode("/it

c# - 我的控件是 "not allowed here because it does not extend class ' System.Web.UI.UserControl'”

所以我有另一个刮面器(无论如何对我来说)。我正在尝试在CMS中创建我自己的自定义控件,我只有部分源代码(即供应商提供给我的示例)。基本上,我创建了一个名为DataDefinitionContent的类,它扩展了ControlBase。现在,根据我从元数据中获得的信息,ControlBase扩展了UserControl,所以我原以为这不会发生什么戏剧性的事情。谁能阐明为什么这对我不起作用?我的类(class):publicpartialclassDataDefinitionContent:ControlBase,ICustomControl{...Stuff}控制库:usingSyste

c# - 通过自定义结构类型验证原始 .NET 值类型 : Is it worth the effort?

我正在尝试通过将原始.NET值类型包装在自定义struct中来使原始.NET值类型更加类型安全和更加“self记录”。但是,我想知道在现实世界的软件中是否真的值得付出努力。(That"effort"canbeseenbelow:Havingtoapplythesamecodepatternagainandagain.We'redeclaringstructsandsocannotuseinheritancetoremovecoderepetition;andsincetheoverloadedoperatorsmustbedeclaredstatic,theyhavetobedefin

c# - TaskCompletionSource 抛出 "An attempt was made to transition a task to a final state when it had already completed"

我想使用TaskCompletionSource来包装MyService这是一个简单的服务:publicstaticTaskProcessAsync(MyServiceservice,intparameter){vartcs=newTaskCompletionSource();//EverytimeProccessAsynciscalledthisassignstoCompleted!service.Completed+=(sender,e)=>{tcs.SetResult(e.Result);};service.RunAsync(parameter);returntcs.Task;}

c# - 通过 LINQ 创建 XML 文档,添加 xmlns,xmlns :xsi to it

我尝试通过LINQtoXML创建GPXXML文档。除了向文档添加xmlns、xmlns:xsi属性外,一切都很好。通过尝试不同的方式,我得到了不同的异常。我的代码:XDocumentxDoc=newXDocument(newXDeclaration("1.0","UTF-8","no"),newXElement("gpx",newXAttribute("creator","XMLtester"),newXAttribute("version","1.1"),newXElement("wpt",newXAttribute("lat","7.0"),newXAttribute("lon",

c# - 公开课 - "is inaccessible due to its protection level. Only public types can be processed."

我正在做一个测试项目来了解对象的XML序列化,但我遇到了一个奇怪的运行时错误:namespaceSerializeTest{publicpartialclassForm1:Form{publicForm1(){InitializeComponent();}privatevoidForm1_Load(objectsender,EventArgse){}privatevoidserializeConnection(Connconnection){XmlSerializerserializer=newXmlSerializer(typeof(Conn));TextWritertextWrit

c# - 装箱和拆箱 : when does it come up?

所以我明白了什么是装箱和拆箱。它什么时候出现在现实世界的代码中,或者在什么例子中它是一个问题?我无法想象做这样的事情:inti=123;objecto=i;//Boxingintj=(int)o;//Unboxing...但这几乎可以肯定是过于简单化了,我什至可能在不知不觉中进行了装箱/拆箱。 最佳答案 与泛型之前相比,现在问题不大了。现在,例如,我们可以使用:Listx=newList();x.Add(10);inty=x[0];根本不需要装箱或拆箱。以前,我们有:ArrayListx=newArrayList();x.Add(1