上個(gè)月月底,VS2017RC版發(fā)布了,一個(gè)很大的特點(diǎn)就是將原來的xProj文件又改回了csproj了。
這樣一改,其實(shí)很多新的問題也暴露出來了,最嚴(yán)重的問題就是Net版本兼容性。
原來的Net體系大致是NetFramework,Net Core這樣的,雖然也有Net Standard 這樣的概念,但是很少有人會(huì)去關(guān)注。
但是,現(xiàn)在的VS將這三種體系都結(jié)合在一起了,傳統(tǒng)的Winform還是NetFramework體系,新的AspNet使用的是NetCore體系,但是動(dòng)態(tài)連接庫使用的是NetStandard體系。
這三個(gè)體系是可以相互轉(zhuǎn)化的,通過試驗(yàn)證明,在運(yùn)行的層面,沒有什么問題,但是由于MSBuild還沒有跟上,所以VS里面報(bào)錯(cuò)是密密麻麻,不忍直視。
新建的解決方案,一個(gè)是NetFrame的Winform,一個(gè)是Standard的動(dòng)態(tài)鏈接庫。
下圖中就可以看到,動(dòng)態(tài)鏈接庫是可以引入的(作為解決方案中的項(xiàng)目),但是存在警告。
同時(shí)可以看到最大的問題是VS里面,都是錯(cuò)誤警告:
在原來的VS2015,使用project.json的時(shí)候,在上圖的左上角是可以選擇 NetFramework462,NetCore的,現(xiàn)在是無法選擇的。
暫時(shí)不知道VS2017的后續(xù)版本這么處理這個(gè)問題。
個(gè)人覺得這次NetCore的發(fā)展速度很快,但是思路卻有些混亂了,現(xiàn)在主要的問題是:
1.原本的庫,沒有辦法完整的移植到跨平臺(tái)的環(huán)境,除了UI的庫之外,很多涉及到平臺(tái)特性的庫,都是缺失的。
2.現(xiàn)在微軟的方向,即考慮到要通過NetStandard實(shí)現(xiàn)來作為標(biāo)準(zhǔn),又要兼容之前的NetCore的命名方式。估計(jì)近期有會(huì)出現(xiàn)一股命名潮。
3.VS工具不成熟的前提下,硬推Mac版的VS,其實(shí)Mac版的VS沒有什么亮點(diǎn),雞肋。還不如全力完善Win版的VS。
[更新]
如果編輯了csproj文件
<PropertyGroup> <TargetFramework>netstandard1.6</TargetFramework> <TargetFramework>net462</TargetFramework> </PropertyGroup>
則發(fā)現(xiàn),項(xiàng)目無法編譯成功(單個(gè)TargetFramework可以編譯成功)
<PackageReference Include="System.Xml.XmlSerializer"> <Version>4.3.0</Version> </PackageReference>
這個(gè)包,在兩個(gè)Framework的時(shí)候無法使用。不知道怎么修改。
在過去project.json