C_Sharp 板


LINE

C# 相同的 source code 每次編譯時的輸出exe or dll不完全相同 如何知道某一版程式(exe or dll)跟source code的對應關係? 問題是這樣的 例如 某個自己開發的libray 我使用git控管了2版程式 rev1, rev2 這個libray提供給多個專案使用 舊的專案可能用到rev1 新的專案用到rev2 某個久遠的專案 某天客戶跟你回報一個bug 客戶環境中只有dll 沒有source code, 因為上述問題 我無法知道它是控管中的哪一版編譯出的output 請問已發布的dll跟source code的對應實務上是怎麼做的? 在控管中加入dll嗎? 寫C/C++時 code每次編譯的output是一樣的 在embedded or linux環境 可以用checksum檢查 最差的情況就是 git 切換到每一個rev 重新編譯一次 跟客戶端的dll比較 cksum即可 在C#碰到這個問題 特別請教一下 3Q --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 27.147.49.32
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_Sharp/M.1490527267.A.5F8.html ※ 編輯: poloball (27.147.49.32), 03/26/2017 19:21:42
1F:推 Litfal: 不是有版本號嗎?還有release版本的,要從開發分支合併到 03/26 22:43
2F:→ Litfal: release分支阿。不然至少加tag 03/26 22:43
其實我的問題跟git沒關係 換一個方式問好了 如果有兩份source code, 各自對應 dll code1 -> DLL_1 code2 -> DLL_2 如果某人隨便從其中拿一個DLL給我 可以知道是從 code1 or code2編譯出來的嗎? (不去測試的情況下) 如果是C/C+ 因為每次編譯都相同 未知的DLL跟已知的DLL binary比較就可以知道來源是code1 or code2 但是因為C#每次編譯 output檔案的binary都會變 所以這個辦法不行 會問這個是因為 我無法確定前人的專案 到底用的是哪一版code 在debug的時候碰到困難 ※ 編輯: poloball (27.147.49.32), 03/26/2017 23:48:54 ※ 編輯: poloball (27.147.49.32), 03/26/2017 23:50:01
3F:→ petercoin: decompile之後直接比對source code呢? 03/27 11:35
4F:推 reichs: 先切到ver1的版本,變更組件名稱:https://goo.gl/xZQ68E 03/27 11:39
5F:→ reichs: 改你想要的名稱,存檔。 03/27 11:39
6F:→ reichs: 切回到ver2的版本,變更組件名稱,存檔。 03/27 11:40
7F:→ reichs: 以上變更都會存到csproj檔的AssemblyName tag. 03/27 11:40
8F:→ reichs: 不想改dll名稱的話,就改組件資訊 03/27 11:52
9F:→ reichs: https://goo.gl/69ur3q 03/27 11:53
10F:→ reichs: https://goo.gl/4Agx8G 03/27 11:54
11F:→ reichs: 這些都會設定到dll->屬性->詳細資料 03/27 11:54
12F:→ Litfal: 我也不是說版本控管的版本號,是說樓上那個版本號 03/28 12:08
13F:→ Litfal: 只是這個版本號可以用release note或tag加在版本控管裡 03/28 12:09
14F:→ Litfal: 只是聽你的說法,你可能一直都是1.0.0.0 ...... 03/28 12:10
15F:→ Litfal: 有關聯起來後,只要一看版本號,就能從版本控管裡面找到對 03/28 12:11
16F:→ Litfal: 應的source code 03/28 12:12
我想要能100%確定 DLL來源source code的方式 光看 assembly 版號也不完全可靠吧? 如果沒有自動化的流程 可能某次忘了進版, 可能某人臨時隨手改了一點東西 編譯後就把DLL給人了 以前專案管理比較混亂 程式又已經在客戶端運作已久 沒十足把握不敢亂更新 petercoin大 說的decompile 可能是我要的答案 但是還滿意外 C# 在這件事上這麼麻煩? 為什麼要設計成 每次編譯都會輸出不同binary 0.0 ※ 編輯: poloball (27.147.49.32), 03/28/2017 19:53:50
17F:噓 Litfal: 與其事後用自動化流程補破網,不如release做好QC,每次都 03/28 21:56
18F:→ Litfal: decompile你會想死 03/28 21:57
19F:→ Litfal: 就算用C,你也要有個版本控管去紀錄某DLL是哪份source建的 03/28 21:59
20F:→ Litfal: 你知道DLL binary然後勒?工程師隨手給的source code還不 03/28 22:00
21F:→ Litfal: 是追蹤不到。 03/28 22:00
22F:→ Litfal: 而且C/C++編譯出來的dll/exe還是有包時間tag,checksum怎 03/28 22:20
23F:→ Litfal: 麼會一樣 03/28 22:20
24F:→ testPtt: 編譯時間追蹤也是一種方法 03/29 21:06







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Boy-Girl站內搜尋

TOP