Çeşitli türlerde büyük olasılıkla çok sayıda (~ 300'e kadar) komut dosyası kullanacak bir Visual Studio projesi tasarlıyorum. Bu dosyalar diğer projelerle paylaşılmayacaktır, yani bunlar projeye özeldir. çalışma zamanında bunları almak için Assembly.GetManifestResourceStream()
kullanarak sonra ve (onların inşa eylemi ayarlayarak) bir gömülü kaynak gibi tüm bu dosyalar da dahil olmak üzere karşı herhangi bir iyi argüman var mı? Ya da bu, gömülü kaynakların kötüye kullanılması olabilir ve bu kaynakları dosya olarak tutan bir dosya sistemi dizini yerine kullanılmalıdır? Gömülü kaynakları kullanmanınBir projeye gömülü bir kaynak olarak çok sayıda komut dosyasını eklemek kötü bir uygulamadır mı?
faydaları gibi görünen:
- üretilen montaj (script dosyaları veya geçersiz yolları eksik hakkında endişe etmeden tek dosya dağıtım) paylaşmak ve dağıtmak kolaydır;
- izolasyon ve rahatlık: tüm kaynaklar VS proje içinde ulaşılabilir.
bu yaklaşıma karşı argümanlar genellikle şunlardır:
- montajın yeniden derleme ve reorganizasyon olmadan kaynak değiştiremezsiniz. Bununla birlikte, birçok metin tabanlı kaynağa sahip bir proje için, sonuçtaki montaj oldukça küçük olacaktır ve üzerine yazma gibi yeniden dağıtmak kolay olacaktır. tek bir dosya sistemi bulunan komut dosyası olurdu. Ve teorik olarak, sadece montajın değiştirilen parçasını değiştirmek mümkün olmalıdır (bu nedenle daha küçük güncelleme), ancak mevcut herhangi bir fark/birleştirme araçlarının mevcut olup olmadığını bilmiyorum.
- üretilen DLL sonunda belki de önemli ölçüde çok daha büyük olacak, ancak daha sonra, yerleştirilecek programın toplam boyutu, gömülü kaynaklar olmadan yalın bir derleme oluşturduysanız ve kaynakları bir dizine ayrı olarak dağıttığınızda aynı olacaktır.
orada diğer hususlar mı? Daha genel olarak, proje kaynaklarının - ne olduklarına bakılmaksızın - değiştirilmeleri durumunda gerekli montaj yeniden derlemesi dışında gömülü kaynaklar olarak dahil edilmemelerinin bir nedeni var mıdır? Bu yalnızca kendi ana bilgisayarda kullanacaksanız web projesi ise