其实我是做一个列表作为引用参数如下:publicstaticListListMethod(Listresult)我也看到有人这样做:publicstaticvoidListMethod(refListresult)如果我没记错的话,“my”方法也将list作为引用参数,您应该可以像“other”在他的方法中一样使用它。但在我看来,您输入一个参数,对它做一些事情并在方法返回值中返回它似乎更“干净”。支持或反对一种方法或另一种方法的任何好的论据? 最佳答案 可能您不需要使用ref-但是有区别的。通常当我看到人们使用ref作为引用类型参数
如果您有一个Bitmap对象需要传递给许多方法(大约10个),最后传递给一个事件,在该事件中它最终将在使用后被处理掉,将它传递给(性能方面)是否有益这些方法中的每一个都是通过引用而不是值?按值传递,对象被复制,按引用传递它不是。(在这种情况下性能至关重要。应用程序需要尽可能快地运行。) 最佳答案 位图是一种引用类型。按值传递引用类型不会复制对象,而只是复制对对象的引用。通过引用而不是通过值传递位图不会带来性能优势。 关于C#'ref'关键字,性能,我们在StackOverflow上找到一
这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:PassinganIDisposableobjectbyreferencecausesanerror?为什么C#不允许将变量从usingblock作为ref或out传递给函数?这是我的代码:using(Forms=newForm()){doSomthing(refs);}函数在usingblock结束之前结束,为什么C#不让我将s作为ref或out参数传递?
声明是什么意思?FromhererefandoutparametersinC#andcannotbemarkedasvariant.1)是否意味着以下不能做。publicclassSomeClass:IVariant{publicvirtualRDoSomething(refAargs){returnnull;}}2)或者这是否意味着我不能拥有以下内容。publicdelegateRReader(Aarg,strings);publicstaticvoidAssignReadFromPeonMethodToDelegate(refReaderpReader){pReader=ReadF
下面是一个结构实例方法的例子,它试图将只读引用返回给结构的实例字段:structFoo{internalint_x;publicrefreadonlyintMemberGetX()=>ref_x;//^^^//ErrorCS8170:Structmemberscannotreturn'this'orotherinstancemembersbyreference}这会产生错误CS8170结构成员无法通过引用返回“this”或其他实例成员。然而,使用扩展方法做同样的事情不会产生错误:staticclassFooExtensions{publicstaticrefreadonlyintExt
如果我没有弄错的话,这种行为对我来说很奇怪。我不会解释,而是在下面发布示例代码,请告诉我为什么我得到输出x而不是y。privatevoidbutton1_Click(objectsender,EventArgse){Listl=newList(){1,2,3};Fuss(l);MessageBox.Show(l.Count.ToString());//outputis5}privatevoidFuss(Listl){l.Add(4);l.Add(5);}我假设输出应该是3。但我得到的输出是5。我知道如果我这样做输出可以是5:privatevoidbutton1_Click(object
我在这里的一堵砖墙边。是否可以将一个bool复制到另一个bool的ref。考虑这段代码。..boola=false;boolb=a;b现在是一个完全独立的bool值,值为false。如果我随后更改a,它将不会影响b。是否可以通过ref使a=b?我该怎么做?非常感谢 最佳答案 没有。由于bool是值类型,它总是按值复制。最好的选择是将你的bool包装在一个类中——这将赋予它引用类型语义:publicclassBoolWrapper{publicboolValue{get;set;}publicBoolWrapper(boolvalue
我遇到了一种情况,我认为只能通过使用ref参数来解决。但是,这意味着当我只需要5%的时间由ref参数提供的功能时,更改方法以始终接受ref参数。这让我觉得“哇,疯了,必须找到另一种方法”。我是不是很傻?ref参数会导致什么样的问题?编辑要求提供更多详细信息,我认为它们与我的要求并不完全相关,但我们开始吧。我想保存一个新实例(它将使用稍后可能使用的ID更新)或检索一个与某些逻辑匹配的现有实例并更新它,保存它然后将新实例的引用更改为指向现有的。代码可能会更清晰:protectedoverridevoidBeforeSave(Logentity){varnewLog=entity;varex
我想修改数组内部结构的字段,而不必设置整个结构。在下面的示例中,我想在数组中设置元素543的一个字段。我不想复制整个元素(因为复制MassiveStruct会影响性能)。classP{structS{publicinta;publicMassiveStructb;}voidf(refSs){s.a=3;}publicstaticvoidMain(){S[]s=newS[1000];f(refs[543]);//Error:Anobjectreferenceisrequiredforthenon-staticfield,method,orproperty}}有没有办法在C#中做到这一点?
所以这有效..publicMyClass(refAppleapple){apple=newApple("Macintosh");//Worksfine}但是有没有可能做这样的事情呢?privateApplemyApple;publicMyClass(refAppleapple){myApple=apple;}publicvoidModifyApple(){myApple=newApple("Macintosh");//doesnotchangetheinputvariablelikethefirstexampledid}当ref变量被复制到成员变量myApple时,它似乎失去了它的“r