in

Darkthread

黑暗執行緒
All Tags » .NET (RSS)

Browse by Tags

  • 用 100 行 C# 打造 IP 所屬國家快速查詢功能

    講到由 IP 地址查詢所屬國家,解決方案有兩種:第一種是直接呼叫線上查詢 API(付費或免費),再不然就要下載 IP 區段資料庫自寫查詢程式。考量應用場合不一定有 Internet 連線能力,加上擔心線上 API 無法滿足 IIS Log 等超大量 IP 解析的效能要求,選擇取回資料檔自幹。(其實是因為這題目大小難易適中,十分適合練功,一時手癢難耐,就…) 爬文找到一些 IP 國別對應資料來源: Maxmind GeoIP2 https://www.maxmind.com/en/geoip2-country-database Maxmind 在 Stackoverflow 受到不少網友推薦。精準度高...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 02-12-2017
  • 使用非同步處理提升資料庫更新速度

    來自同事的資料庫程式效能調校案例一則。 情境為一支同步來源及目的資料表的排程,先一次取回來源及目的資料表,逐一檢查資料是否已存在目的資料表,若不存在即執行Insert,若存在則執行 Update 更新欄位。因 Insert/Update 之前需進行特定轉換,故難以改寫為 Stored Procedure。排程有執行過慢問題,處理四萬筆資料耗時近 27 分鐘。 程式示意如下: foreach (var src in srcList) { try { var target = findExistingData(src); if (target == null ) { AddTargetToDB(src...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 02-09-2017
  • 使用 FileChangeMonitor 實現檔案資料快取自動更新

    有個開發老鳥專屬的「成功經驗魔咒」:遇到難題,想出一套簡單有效解法,或許有些小缺點,但造成的麻煩在可忍受範圍,於是 日後再遇到同樣狀況,一律照方煎藥,數十年如一日。 但技術會革新、元件會改進,善用一些新特性,小缺點其實可以化為無形。可怕的地方在於:如果每次都能順利解決問題,就不會圖謀改進,直到有天發現洋人船堅砲利,才知自己已成滿清… 老鳥想一直寫程式又不想被時代淘汰,就得提高警覺。有個超簡單的實踐方法-對自己機車一點。當有人反應不方便時,別一句「就多一個動作會死嗎?」頂回去,改成問自己:「連這個動作都省不掉?嫩!」,對自己GY一點才能撐久一點。以下算是個實例: 專案有時會遇到上傳檔案更新資料的機制...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 01-16-2017
  • 筆記-Scott Hanselman 的 2017 .NET 開發者須知

    Scott Hanselman 前兩天有篇文章- What .NET Developers ought to know to start in 2017 ,我的工作(甚至生活)跟 .NET 息息相關,重量級人物的觀點自然不容錯過,整理筆記如下: 前言 Scott 之前整理過類似的 .NET 須知,結果被大家拿來當作面試時折磨新人的刑具… 清單很長,但並不是每則都必須搞懂弄通,應視自己所需以及學習習慣取捨,有些知道名詞即可,有些應該深入了解。 https://dot.net 是 .NET 技術資源的新入口,首頁有個線上 C# 編譯器可以玩玩。 必備知識 新的 .NET 架構 ,分成 .NET Framework...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 01-15-2017
  • ODP.NET 發行者原則檔經驗一則

    之前處理過一個 鳥問題 ,使用 ODP.NET 12.1 連線 Oracle Server 10.2.0.4 時無法參與分散式交易,傳回「Unable to enlist in a distributed transaction /無法列於分散式交易中」錯誤。依網路討論 Server 升級到 10.2.0.5 以上可解決,當時決定將資料庫移至另一台 Oracle Server 11.2 成功脫逃,安全下莊。 半年後鳥問題捲土重來,一樣是 ODP.NET 12.1 連 Oracle 10.2.0.4 無法分散式交易,但這回資料庫沒得搬也很難升級,只能乖乖面對。 確認其他機器曾有 ODP.NET 11...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 01-05-2017
  • 關於 Decimal 小數尾數零

    C#的實數型別有三種:float、double、decimal。其中 float、double 為浮點數,本站的老讀者們一定知道-「 算錢用浮點,遲早被人扁 」的道理,因此只要涉及金額計算,我一律改用 decimal 型別。前幾天,踩到 decimal 小數尾數零地雷一枚。 以下程式為例,大家猜猜結果為何? class Program { static void Main( string [] args) { float flt = 1.2300F; Console.WriteLine(flt); double dbl = 1.2300D; Console.WriteLine(dbl); decimal...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 12-11-2016
  • C# Interpolated Strings 字串插值

    TypeScript 有個好東西, Template String ,輸出內嵌動態資料 HTML 時非常好用,例如: var userName: string = "Jeffrey" ; var iconUrl: string = "/imgs/runner.gif" ; var html = ` <div> Hello, ${userName}! <img src= "${iconUrl}" /> </div>`; alert(html); 場景移到 C#,字串內含換行符號靠 @"…."...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 11-21-2016
  • 快速查詢主機目前安裝的 .NET 版本

    工作上常遇到的需求:在陌生機器上想確認已安裝的 .NET Runtime 版本,只有 4.0,還是已升到 4.5.2 甚至 4.6? MSDN 建議的官方做法是 檢查 Registry ,程式邏輯不複雜要自己寫個小工具並不困難,但每次測試得 Copy 程式檔太搞剛,於是我想到了 PowerShell! 在 Stackoverflow 找到網友分享 用 Powershell 檢查 .NET 版本的範例 : Get-ChildItem 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP' -recurse | Get-ItemProperty...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 11-18-2016
  • 與上層命名空間成員名稱重複問題:TypeScript 與 C#

    同事遇到的 TypeScript 小問題一則,如下圖,Foo 與 Bar.Foo Module 裡都有個 IBlah Interface(不算良好的設計但合法,用在特定情境可簡化程式),在 Bar.Foo 內想引用更上層 Foo 的 IBlah,不管宣告型別是 IBlah 還是 Foo.IBlah,指向的都是 Bar.Foo.IBlah。 同樣的情境,在 C# 裡也會上演,在 Bar.Foo 命名空間內不管寫 Foo.IBlah 或 IBlah 指的都是Bar.Foo.IBlah: C# 可用 global:: 關鍵字 指定全域命名空間解決這個問題,寫成 global::Foo.IBlah 指明是上層...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 11-17-2016
  • 【茶包射手日記】System.Data.OracleClient更新中文變問號

    同事報案,某支在Windows 2003主機運作良好的轉檔程式,移至開發機執行更新Oracle資料庫時,中文變成問號。 比較原本執行正常的環境為Windows 2003 x86英文版 + Oracle Client 9207(真實世界永遠不乏這種與時代嚴重脫節卻維繫日常營運的中流砥柱啊),開發機則為Windows 7 x64英文版 + Oracle Client 12.1,二者存在不少差異。 寫了一段測試程式嘗試驗證問題,在我的機器(Windows 8.1 x64中文版 + Oracle Client 12.1)更新中文正常,移到同事的機器執行更新中文… 也正常。登楞! 只好回到轉檔程式用Visual...
    公佈在 黑暗執行緒 (Weblog)Jeffrey 發表於 09-15-2016
第5頁,共28頁 (278個項目) « 第一頁 ... < 上一頁 3 4 5 6 7 下一頁 > ... 最後一頁 »
Powered by Community Server (Non-Commercial Edition), by Telligent Systems