上個(gè)月月底,VS2017RC版發(fā)布了,一個(gè)很大的特點(diǎn)就是將原來(lái)的xProj文件又改回了csproj了。
這樣一改,其實(shí)很多新的問(wèn)題也暴露出來(lái)了,最嚴(yán)重的問(wèn)題就是Net版本兼容性。

原來(lái)的Net體系大致是NetFramework,Net Core這樣的,雖然也有Net Standard 這樣的概念,但是很少有人會(huì)去關(guān)注。
但是,現(xiàn)在的VS將這三種體系都結(jié)合在一起了,傳統(tǒng)的Winform還是NetFramework體系,新的AspNet使用的是NetCore體系,但是動(dòng)態(tài)連接庫(kù)使用的是NetStandard體系。
這三個(gè)體系是可以相互轉(zhuǎn)化的,通過(guò)試驗(yàn)證明,在運(yùn)行的層面,沒(méi)有什么問(wèn)題,但是由于MSBuild還沒(méi)有跟上,所以VS里面報(bào)錯(cuò)是密密麻麻,不忍直視。

新建的解決方案,一個(gè)是NetFrame的Winform,一個(gè)是Standard的動(dòng)態(tài)鏈接庫(kù)。

Android培訓(xùn),安卓培訓(xùn),手機(jī)開發(fā)培訓(xùn),移動(dòng)開發(fā)培訓(xùn),云培訓(xùn)培訓(xùn)

下圖中就可以看到,動(dòng)態(tài)鏈接庫(kù)是可以引入的(作為解決方案中的項(xiàng)目),但是存在警告。

Android培訓(xùn),安卓培訓(xùn),手機(jī)開發(fā)培訓(xùn),移動(dòng)開發(fā)培訓(xùn),云培訓(xùn)培訓(xùn)

同時(shí)可以看到最大的問(wèn)題是VS里面,都是錯(cuò)誤警告:
Android培訓(xùn),安卓培訓(xùn),手機(jī)開發(fā)培訓(xùn),移動(dòng)開發(fā)培訓(xùn),云培訓(xùn)培訓(xùn)

在原來(lái)的VS2015,使用project.json的時(shí)候,在上圖的左上角是可以選擇 NetFramework462,NetCore的,現(xiàn)在是無(wú)法選擇的。
暫時(shí)不知道VS2017的后續(xù)版本這么處理這個(gè)問(wèn)題。

個(gè)人覺(jué)得這次NetCore的發(fā)展速度很快,但是思路卻有些混亂了,現(xiàn)在主要的問(wèn)題是:
1.原本的庫(kù),沒(méi)有辦法完整的移植到跨平臺(tái)的環(huán)境,除了UI的庫(kù)之外,很多涉及到平臺(tái)特性的庫(kù),都是缺失的。
2.現(xiàn)在微軟的方向,即考慮到要通過(guò)NetStandard實(shí)現(xiàn)來(lái)作為標(biāo)準(zhǔn),又要兼容之前的NetCore的命名方式。估計(jì)近期有會(huì)出現(xiàn)一股命名潮。
3.VS工具不成熟的前提下,硬推Mac版的VS,其實(shí)Mac版的VS沒(méi)有什么亮點(diǎn),雞肋。還不如全力完善Win版的VS。

[更新]
如果編輯了csproj文件

  <PropertyGroup>
    <TargetFramework>netstandard1.6</TargetFramework>
    <TargetFramework>net462</TargetFramework>
  </PropertyGroup>

則發(fā)現(xiàn),項(xiàng)目無(wú)法編譯成功(單個(gè)TargetFramework可以編譯成功)

    <PackageReference Include="System.Xml.XmlSerializer">
      <Version>4.3.0</Version>
    </PackageReference>

這個(gè)包,在兩個(gè)Framework的時(shí)候無(wú)法使用。不知道怎么修改。

在過(guò)去project.json

網(wǎng)友評(píng)論