加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

.net – 我可以在Mono / Linux上使用Visual Studio附带的FSharp.

发布时间:2020-12-14 01:40:44 所属栏目:Linux 来源:网络整理
导读:因为我感到困惑,我会感激一些帮助. 如果我相信这个page,使用我的应用程序部署FSharp核心的最佳方法是将FSharp.Core.dll与app二进制文件一起复制(“xcopy部署”). In compiled applications,you should never assume that FSharp.Core is in the GAC (“Globa
因为我感到困惑,我会感激一些帮助.

如果我相信这个page,使用我的应用程序部署FSharp核心的最佳方法是将FSharp.Core.dll与app二进制文件一起复制(“xcopy部署”).

In compiled applications,you should never assume that FSharp.Core is in the GAC (“Global Assembly Cache”). Instead,you should deploy the appropriate FSharp.Core as part of your application.

到目前为止一切都很好,我对Windows感到非常满意……但是,关于Mono,同一页面上写着:

Standard installations of F# tools on Linux and Mac on Mono also install the latest FSharp.Core into the GAC. They also add machine-wide binding redirects for that component. That means that,for those machines,the latest installed FSharp.Core will be used by applications

哪种提示不应该使用应用程序部署FSharp核心副本,并且将从Mono GAC中获取正确版本的FSharp核心.我对此有两个问题:

>这迫使Windows和Linux有两种不同的部署方案;
>在Mono上,这可能会强制使用较旧的FSharp代码而不是最新的Visual Studio中可用的代码.

这两个问题都可能通过始终从GitHub源和应用程序构建FSharp核心来解决,但这看起来也不是一个优雅的解决方案.所以我想知道无论平台如何,总是使用最新FSharp核心的正确方法是什么(如果可能的话)?

解决方法

我的理解是,如果将FSharp.Core与应用程序包含在任何平台上,至少对于Framework Dependent Deployments,则在查找GAC之前首先探测并使用本地bin目录.这里可能还有很多其他的细微之处,但至少从我的理解来看,你的本地复制版本的FSharp.Core将是你的应用程序使用的版本.

顺便说一句,通过使用一些反射来查看源自FSharp.Core的加载类型并查看它来自哪个程序集,应该相对容易进行测试.此外,我可以回想起AppDomain.AssemblyResolve或类似的事件可能会让你更深入地了解解决过程,甚至可以稍微定制它.

值得一提的是,就GAC而言,这个故事可能会在.NET Core上发生很大的变化,同时还有我上面提到的反射相关技术的可用性.

有关:

> Dll in both the bin and the gac,which one gets used?
> Is there any GAC equivalent for .NET Core?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读