草庐IT

PERSON_REF

全部标签

c# - 引用分配是原子的,那么为什么需要 Interlocked.Exchange(ref Object, Object) 呢?

在我的多线程asmxWeb服务中,我有一个我自己的类型SystemData的类字段_allData,它由几个List组成和Dictionary标记为volatile.系统数据(_allData)偶尔会刷新一次,我通过创建另一个名为newData的对象来实现。并用新数据填充它的数据结构。完成后,我只需分配privatestaticvolatileSystemData_allDatapublicstaticboolLoadAllSystemData(){SystemDatanewData=newSystemData();/*fillnewDatawithup-to-datedata*/..

c# - C# 中的引用类型变量 "ref"有什么用?

我知道如果我传递一个值类型(int、struct等)作为参数(没有ref关键字),该变量的副本被传递给该方法,但如果我使用ref关键字,传递的是对该变量的引用,而不是新的引用。但是对于引用类型,比如类,即使没有ref关键字,引用也会传递给方法,而不是副本。那么ref关键字和引用类型有什么用呢?举个例子:varx=newFoo();以下有什么区别?voidBar(Fooy){y.Name="2";}和voidBar(refFooy){y.Name="2";} 最佳答案 您可以使用y更改foo指向的内容:Foofoo=newFoo("1

c# - 何时使用 in vs ref vs out

前几天有人问我什么时候应该使用参数关键字out而不是ref。虽然我(我认为)理解ref和out关键字(一直是askedbefore)之间的区别,但最好的解释似乎是ref==in和out,我应该始终使用out而不是的一些(假设或代码)示例引用。既然ref更通用,为什么还要使用out?它只是语法糖吗? 最佳答案 除非你需要ref,否则你应该使用out。当数据需要编码时,它会产生很大的不同,例如到另一个过程,这可能是昂贵的。因此,您希望避免在方法未使用初始值时编码初始值。除此之外,它还向声明或调用的读者显示初始值是相关的(并可能保留)还是

c# - .NET 中 ref 和 out 参数的区别

这个问题在这里已经有了答案:What'sthedifferencebetweenthe'ref'and'out'keywords?(27个答案)关闭4年前。.NET中的ref和out参数有什么区别?在什么情况下一个比另一个更有用?一个可以使用而另一个不能使用的代码片段是什么?

javascript - Firebase - ref 和 child 有什么区别?

在Firebase中,ref和child被大量使用。例如-firebase.database().ref('users/')将与firebase.database().ref('users').child('')完全相同,那么它们之间到底有什么区别,什么时候应该使用它们? 最佳答案 没有区别,无论如何你有一个DatabaseReference实例。Firebase引用代表数据库中的特定位置,可用于读取数据或将数据写入该数据库位置。方法:publicDatabaseReferencegetReference(Stringpath)获取

ruby-on-rails - Git pull 错误 : "fatal: Couldn' t find remote ref master"from Heroku

我在heroku上上传了我的应用程序。但我面临一些问题。问题是什么:致命的:'priroda'似乎不是git存储库?~/priroda$gitpullfatal:'priroda'doesnotappeartobeagitrepositoryfatal:Theremoteendhungupunexpectedly~/priroda$gitremote-vherokugit@heroku.com:secure-anchorage-3129.git(fetch)herokugit@heroku.com:secure-anchorage-3129.git(push)originpriroda

带有彩色格式字符串的 git for-each-ref

我使用gitfor-each-ref作为git别名来显示分支名称和该分支上最后一次提交的主题。也就是说,很难分辨分支名称在哪里结束以及提交消息主题从哪里开始,所以我试图对分支名称进行着色以更容易地分辨两者之间的区别。下面是没有颜色的工作别名:[alias]logbranch=for-each-ref--sort=-committerdaterefs/heads/--format='%(refname:short)%(subject)'为了添加颜色,我尝试使用外壳颜色转义(我正在使用bash),如下所示:[alias]logbranch=for-each-ref--sort=-commi

混帐 1.8 : it push error: dst ref refs/heads/master receives from more than one src

git1.8的另一个问题:$gitpusherror:dstrefrefs/heads/masterreceivesfrommorethanonesrc.error:failedtopushsomerefsto'gitosis@xxx.xx:xxx.git'建议?它在升级到1.8之前一直有效。$gitremote-vorigingitosis@xxx.xx:xxx.git(fetch)origingitosis@xxx.xx:xxx.git(push)谷歌搜索后我首先尝试了这个:$gitpushorigin:refs/heads/refs/heads/masterremote:warn

Git: "Error: refusing to create funny ref ' HEAD' remotely"用于初始推送

我正在尝试将我的Git存储库从Egit(EclipseGit)初始推送到GitHub。不幸的是,我收到以下错误:error:refusingtocreatefunnyref'HEAD'remotely我将源和目标ref都设置为“HEAD”这个错误信息是什么意思? 最佳答案 我通过选择master(refs/heads/master)作为源引用来解决这个问题。然后Egit也自动将目标ref设置为master。我想这个命令告诉git创建主分支,而选择HEAD要么尝试创建一个名为HEAD的分支,要么尝试推送到当前(不存在的)远程HEAD。

git:如何删除本地 ref 分支?

我在删除本地ref分支(refs/notes/origin/commits)时遇到了一些困难。我能够使用命令删除远程存储库中的分支(refs/notes/origin/commits)gitpushorigin:refs/notes/origin/commits但是当我尝试删除本地存储库中的同一个分支时,出现以下错误[User@centosClone]#gitbranch-rdrefs/notes/origin/commitserror:remotebranch'refs/notes/origin/commits'notfound.有什么建议吗? 最佳答案