VS 2017 RC - 核心项目 - ClassLibrary和控制台 - 框架不同

时间:2016-11-28 20:28:52

标签: .net-core visual-studio-2017

我在VS2017 RC中创建了一个新项目我添加了一个控制台库和一个类库。

现在我可以看到框架被添加为依赖项。

但为什么核心控制台没有NetStandard.Library

相反,我可以看到Microsoft.NetCore.app

enter image description here

因此,当我尝试使用dotnet -run

启动控制台应用时

我收到此错误

[![在此处输入图像说明] [2]] [2]

2 个答案:

答案 0 :(得分:0)

有关netcoreapp和netstandard之间的区别,请查看:What's the difference between the new netstandardapp and netcoreapp TFMs?

在命令行上运行dotnet -run时,您需要安装.NET Core SDK,它是.NET Core的单独安装。安装VS2017 RC无法安装此SDK。您可以下载.NET Core 1.1 SDK here

答案 1 :(得分:0)

因为您安装了适用于1.1.0的SDK / build-tools,而不是共享框架1.1.0 SDK和共享框架不是一回事。

就Linux命令行而言,它可能是最好的解释。 如果你有,那么你目前安装的是

apt-get install dotnet-dev-1.0.1

但你缺少的是

apt-get install dotnet-sharedframework-microsoft.netcore.app-1.1.0

更深层次的原因是你有     apt-get install dotnet-dev-1.0.1

而不是

apt-get install dotnet-dev-1.1.0

SDK 1.1版将安装共享框架1.1.0,但如果你的SDK是1.0.1,则从未安装过1.1.0。

至于netstandard与netcore,David Fowler有一个很好的解释尝试here 基本上,每个版本的" .NET核心框架"和#34; .NET Framework非核心"扩展netstandard的一个版本,其中netstandard-library可以在CORE和NON-Core中使用):

具体而言,您的应用只能作为.NET Core或.NET Framework运行。没有netstandard-app(当前),只有netstandard-libraries。

NetFramework_vX和NetCoreFramework_vX都是NetStandardLibray_vX的超集。

using System;

namespace Analogy
{
    // Each interface represents a target framework and methods represents groups of APIs available on that target framework. 
    // The goal is to show the relationship between .NET Standard API surface and other .NET platforms


    // .NET Standard

    interface INetStandard10
    {
        void Primitives();
        void Reflection();
        void Tasks();
        void Collections();
        void Linq();
    }

    interface INetStandard11 : INetStandard10
    {
        void ConcurrentCollections();
        void InteropServices();
    }

    interface INetStandard12 : INetStandard11
    {
        void ThreadingTimer();
    }

    interface INetStandard13 : INetStandard12
    {
        void FileSystem();
        void Console();
        void ThreadPool();
        void Process();
        void Sockets();

        void AsyncLocal();
    }

    interface INetStandard14 : INetStandard13
    {
        void IsolatedStorage();
    }

    interface INetStandard15 : INetStandard14
    {
        void AssemblyLoadContext();
    }

    // .NET Framework 

    interface INetFramework45 : INetStandard11
    {
        void FileSystem();
        void Console();
        void ThreadPool();
        void Crypto();
        void WebSockets();
        void Process();
        void Sockets();

        void AppDomain();
        void Xml();
        void Drawing();
        void SystemWeb();
        void WPF();
        void WindowsForms();
        void WCF();
    }

    interface INetFramework451 : INetFramework45, INetStandard12
    {
        // TODO: .NET Framework 4.5.1 specific APIs
    }

    interface INetFramework452 : INetFramework451, INetStandard12
    {
        // TODO: .NET Framework 4.5.2 specific APIs
    }

    interface INetFramework46 : INetFramework452, INetStandard13
    {
        // TODO: .NET Framework 4.6 specific APIs
    }

    interface INetFramework461 : INetFramework46, INetStandard14
    {
        // TODO: .NET Framework 4.6.1 specific APIs
    }

    interface INetFramework462 : INetFramework461, INetStandard15
    {
        // TODO: .NET Framework 4.6 specific APIs
    }

    // Mono

    interface IMono43 : INetFramework46
    {
        void MonoSpecificApi();
    }

    // Windows Universal Platform

    interface IWindowsUniversalPlatform : INetStandard14
    {
        void GPS();
        void Xaml();
    }

    // Xamarin 

    interface IXamarinIOS : INetStandard15
    {
        void AppleAPIs();
    }

    interface IXamarinAndroid : INetStandard15
    {
        void GoogleAPIs();
    }

    // .NET Core

    interface INetCoreApp10 : INetStandard15
    {

    }

    // Future platform

    interface ISomeFuturePlatform : INetStandard13
    {
        // A future platform chooses to implement a specific .NET Standard version.
        // All libraries that target that version are instantly compatible with this new
        // platform
    }
}