visual studio code調試.net core 2.0程序
最近在試.net 2.0 Preview時,在VS2017中相對麻煩,現說也怕把生產環境搞壞,於是就想在vs code下試試。
首在安裝.net core 2.0的SDK和Runtime,這裏下載
https://github.com/dotnet/core/blob/master/release-notes/download-archives/2.0.0-preview1-download.md
再安裝vs code(我安裝的是中文版),這裏下載
https://code.visualstudio.com/?wt.mc_id=DX_841432
打開vs在擴展中安裝C#擴展
安裝完成後,打開cmd
用dotnet new console創建一個項目(首先創建好項目文件夾哦)
dotnet restore一下
dotnet run跑了起來
在vs code中打開文件夾,選擇上面創建的文件夾,並雙擊Program.cs,這時,vs code會安裝一個OmniSharp和一個.Net Core Debugger,這兩個安裝相對較慢(可能在國內原因吧)
接下來在Program.cs中
加入如下代碼(測試DataTable的):
然後在vs code中restore
這樣就開始調試了,調試肯定是失敗的,因為代碼中用到ado.net連接sql server數據,所以在.csproj中添加如下節點:
<ItemGroup>
<PackageReference Include="System.Data.SqlClient"Version="4.4.0-preview1-25305-02" />
</ItemGroup>
重新restore,然後再次調試 ,如果你的數據中有漢字,這時會發現在在調試控制臺上轉出有亂碼,怎麽會事?
再返回cmd下測試(或在vs code的終端測試),都正常
看來正常,之前1.1版確實漢字也會有亂碼,用上
System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance);
就會解決掉,但本例中不一樣,首先在cmd下沒有亂碼,我試過用上這個方法,調試控制臺上也是亂碼,於是就東問西找,也沒有找到有效的解決方案(我的google能力還有待提高呀),於是只能自己想著解決了,亂碼肯定是編碼不匹配,這個問題說明設計控制臺與終端的編碼輸出不一樣,終端和cmd一個道,應該問題出在vs code輸入到控制臺上的問題,幸好我c#控制臺功底好(),想到一個輸出流,然後就找到了
Console.OutputEncoding = System.Text.Encoding.UTF8;
果然問題解決,轉了半天cmd可以顯示漢字和vs code “文件”-“首選項”-“設置”誤導了我,找了半天怎麽設置調試控制臺來改變編碼,原來在程序中控制即可。
本文出自 “桂素偉” 博客,請務必保留此出處http://axzxs.blog.51cto.com/730810/1925586
visual studio code調試.net core 2.0程序