Yazılım yapımı - Software construction

Yazılım geliştirme
Çekirdek aktiviteleri
Paradigmalar ve modeller
Metodolojiler ve çerçeveler
Destekleyen disiplinler
Uygulamalar
Araçlar
Standartlar ve Bilgi Yapıları
Sözlükler
Anahatlar

Yazılım yapımı bir yazılım Mühendisliği disiplin. Anlamlı çalışmanın detaylı oluşturulmasıdır. yazılım kombinasyonu yoluyla kodlama, doğrulama, birim testi, entegrasyon testi, ve hata ayıklama. Tüm diğerleriyle bağlantılı yazılım Mühendisliği disiplinler, en önemlisi yazılım Tasarımı ve yazılım testi.[1]

Yazılım yapımının temelleri

Karmaşıklığı en aza indirmek

Karmaşıklığı azaltma ihtiyacı temelde çoğu insanın karmaşık yapıları ve bilgileri işleyen hafızalarında tutma konusundaki sınırlı becerisinden kaynaklanmaktadır. Azaltılmış karmaşıklık yaratılması vurgulanarak elde edilir kodu bu akıllıca olmaktan çok basit ve okunabilir. Küçültme karmaşıklık kullanılarak elde edilir standartları ve birçok özel teknik aracılığıyla kodlama. Ayrıca tarafından desteklenmektedir inşaat odaklı kalite teknikleri.[2]

Değişikliği öngörmek

Değişikliği öngörmek, yazılım mühendislerinin genişletilebilir yazılım geliştirmelerine yardımcı olur, bu da temel yapıyı bozmadan bir yazılım ürününü geliştirebilecekleri anlamına gelir.[2] 25 yılı aşkın bir süredir yapılan araştırmalar, yeniden işleme maliyetinin, gereksinimleri ilk seferde doğru bir şekilde elde etmekten 10 ila 100 kat (daha küçük projeler için 5 ila 10 kat) daha pahalı olabileceğini gösterdi. Ortalama bir projede geliştirme sırasında gereksinimlerin% 25'inin değiştiği göz önüne alındığında, yeniden çalışma maliyetini azaltma ihtiyacı, değişimi öngörme ihtiyacını ortaya çıkarır. [3]

Doğrulama için inşa

İçin inşa doğrulama inşa etmek demektir yazılım öyle bir şekilde, hatalar kolaylıkla Yazılım mühendisleri yazmak yazılım bağımsız olduğu gibi test yapmak ve operasyonel faaliyetler. İçin oluşturmayı destekleyen özel teknikler doğrulama desteklemek için aşağıdaki kodlama standartlarını dahil edin kod incelemeleri, birim testi, organize etmek kodu desteklemek otomatik test ve kısıtlı kullanımı karmaşık veya zoranlama dil diğerleri arasında yapılar.[2]

Yeniden kullan

Sistematik yeniden kullanım, önemli yazılım üretkenliği, kalitesi ve maliyet iyileştirmeleri sağlayabilir. Yeniden kullanımın birbiriyle yakından ilişkili iki yönü vardır:[2]

  • Yeniden kullanım için yapı: Yeniden kullanılabilir yazılım varlıkları oluşturun.
  • Yeniden kullanımla inşaat: Yeni bir çözümün inşasında yazılım varlıklarını yeniden kullanın.

İnşaatta standartlar

İnşaat konularını doğrudan etkileyen harici (uluslararası kuruluşlar tarafından oluşturulmuş) veya dahili (kurumsal düzeyde oluşturulmuş) standartlar şunları içerir:[2]

İnşaat yönetimi

İnşaat modeli

Sayısız modeller geliştirmek için yaratıldı yazılım bazıları inşaatı diğerlerinden daha fazla vurgulamaktadır. Biraz modeller inşaat açısından daha doğrusaldır, örneğin Şelale ve aşamalı teslimat yaşam döngüsü modelleri. Bunlar modeller İnşaatı, yalnızca önemli ön koşul çalışmaları tamamlandıktan sonra ortaya çıkan bir faaliyet olarak ele alın - ayrıntılar dahil Gereksinimler iş, kapsamlı tasarım iş ve detaylı planlama. Diğer modeller daha fazlasıdır yinelemeli, gibi evrimsel prototipleme, Aşırı Programlama, ve Scrum. Bu yaklaşımlar, inşaatı diğerleriyle eşzamanlı olarak gerçekleşen bir faaliyet olarak ele alma eğilimindedir. yazılım geliştirme dahil olmak üzere faaliyetler Gereksinimler, tasarım, ve planlama veya bunlarla örtüşüyor.[1]

İnşaat planlaması

İnşaat seçimi yöntem inşaat planlama faaliyetinin önemli bir yönüdür. İnşaat seçimi yöntem inşaat ön koşullarının kapsamını etkiler (ör. Gereksinimlerin analizi, Yazılım Tasarımı, .. vb.) yapılır, yapıldıkları sıra ve inşaat işi başlamadan önce tamamlanması beklenen derece. İnşaat planlaması ayrıca hangi sırayı tanımlar? bileşenleri oluşturulur ve entegre edilir, yazılım kalite yönetimi süreçler, görev atamalarının belirli Yazılım mühendisleri ve seçilene göre diğer görevler yöntem.[1]

İnşaat ölçümü

Geliştirilen kod, değiştirilen kod, yeniden kullanılan kod, imha edilen kod, kod karmaşıklığı, kod inceleme istatistikleri, hata düzeltme ve hata bulma oranları, çaba ve zamanlama dahil olmak üzere çok sayıda inşaat faaliyeti ve yapı ölçülebilir. Bu ölçümler, inşaatı yönetmek, inşaat sırasında kaliteyi sağlamak, inşaat sürecini iyileştirmek ve diğer nedenler için yararlı olabilir.[1]

Pratik hususlar

Yazılım inşası birçok pratik düşünceye göre yönlendirilir:

Yapı Tasarım

Beklenmeyen boşlukları hesaba katmak için yazılım Tasarımı Yazılım yapımı sırasında, daha küçük veya daha büyük ölçekte bazı tasarım değişikliklerinin yapılması gerekir. yazılım Tasarımı.[4]

Düşük Fan-out araştırmacılar tarafından faydalı bulunan tasarım özelliklerinden biridir. Bilgi gizlemenin, büyük programlarda 4 katıyla değiştirilmelerini kolaylaştıran kullanışlı bir tasarım tekniği olduğu kanıtlandı. [5]

İnşaat dilleri

İnşaat dilleri, bir insanın bir bilgisayara yürütülebilir bir problem çözümü belirleyebileceği tüm iletişim biçimlerini içerir. Yapılandırma dillerini, araç seti dillerini ve Programlama dilleri:[6]

  • Yapılandırma dilleri, Yazılım mühendisleri Yeni veya özel yazılım yüklemeleri oluşturmak için sınırlı bir önceden tanımlanmış seçenekler kümesinden seçim yapın.
  • Araç seti dilleri, araç takımları ve yapılandırma dillerinden daha karmaşıktır.
  • Komut dosyası dilleri derlemek yerine genellikle yorumlanan betikleri destekleyen uygulama programlama dilleridir.
  • Programlama dilleri üç genel notasyon türü kullanan en esnek inşaat dilleridir:
    • Özellikle karmaşık yazılım yapılarını temsil etmek için kelime benzeri metin dizilerinin kullanılmasıyla ve bu tür kelime benzeri dizelerin cümle benzeri bir sözdizimine sahip kalıplar halinde birleştirilmesiyle ayırt edilen dilbilimsel gösterimler.
    • Kelimelerin ve metin dizelerinin sezgisel, günlük anlamlarına daha az ve daha çok kesin, açık ve resmi (veya matematiksel) tanımlarla desteklenen tanımlara dayanan biçimsel gösterimler.
    • Hem dilbilimsel hem de biçimsel yapının metin odaklı gösterimlerine çok daha az dayanan ve bunun yerine, temeldeki yazılımı temsil eden görsel varlıkların doğrudan görsel yorumuna ve yerleştirilmesine dayanan görsel notasyonlar.

Üç yıl veya daha uzun süredir kullandıkları bir dilde çalışan programcılar, eşdeğer deneyime sahip bir dilde yeni olan programcılardan yaklaşık yüzde 30 daha üretkendir. C ++, Java, Smalltalk ve Visual Basic gibi üst düzey diller, assembly ve C gibi düşük düzeyli dillere göre 5 ila 15 kat daha iyi üretkenlik, güvenilirlik, basitlik ve anlaşılırlık sağlar. Eşdeğer kodun, daha düşük seviyeli dillere göre yüksek seviyeli dillerde uygulanmalıdır.[7]

Kodlama

Yazılım oluşturma kodlama etkinliği için aşağıdaki hususlar geçerlidir:[8]

  • Anlaşılır oluşturma teknikleri kaynak kodu, adlandırma ve kaynak kodu düzeni dahil. Bir çalışma, değişkenlerin adları 10 ila 16 karakter arasında olduğunda bir programda hata ayıklamak için gereken çabanın en aza indirildiğini gösterdi.[9]
  • Kullanımı sınıflar, numaralandırılmış türler, değişkenler, adlı sabitler ve diğer benzer varlıklar:
    • NASA tarafından yapılan bir çalışma, kodu iyi faktörlü sınıflara koymanın kodu ikiye katlayabileceğini gösterdi. tekrar Kullanılabilirlik fonksiyonel tasarım kullanılarak geliştirilen koda kıyasla.[10][11]
    • Bir deney, dizilere rastgele değil, sırayla erişen tasarımların daha az değişken ve daha az değişken referansıyla sonuçlandığını gösterdi.[12]
  • Kontrol yapılarının kullanımı:
    • Bir deney, çıkışlı döngülerin diğer döngü türlerinden daha anlaşılır olduğunu buldu.[13]
    • Döngülerdeki ve koşullulardaki yuvalama düzeyiyle ilgili olarak, araştırmalar programcıların üçten fazla yuvalama düzeyini anlamada güçlük çektiklerini göstermiştir.[13][14]
    • Kontrol akışı karmaşıklığının düşük güvenilirlik ve sık hatalarla ilişkili olduğu gösterilmiştir.[14]
  • Hata koşullarının ele alınması - hem planlanan hatalar hem de istisnalar (örneğin hatalı veri girişi)
  • Kod düzeyinde güvenlik ihlallerinin önlenmesi (arabellek taşmaları veya dizi indeksi örneğin taşmalar)
  • Kaynak dışlama mekanizmalarının kullanımı yoluyla kullanım ve seri olarak yeniden kullanılabilir erişimde disiplin kaynaklar (dahil olmak üzere İş Parçacığı veya veritabanı kilitleri )
  • Kaynak kodu organizasyon (içine ifadeler ve rutinler ):[11]
    • Büyük ölçüde yapışkan rutinlerin, daha düşük bağlılığa sahip rutinlerden daha az hataya meyilli olduğu kanıtlanmıştır. 450 rutin üzerinde yapılan bir çalışma, yüksek düzeyde uyumlu rutinlerin yüzde 50'sinin, düşük bağlılığa sahip rutinlerin sadece yüzde 18'ine kıyasla hatasız olduğunu buldu. 450 farklı rutin üzerinde yapılan başka bir çalışma, en yüksek rutinlerin bağlantı -kohezyon oranları, en düşük bağlanma-kohezyon oranlarına sahip olanlardan 7 kat daha fazla hataya sahipti ve düzeltilmesi 20 kat daha maliyetliydi.
    • Çalışmalar, rutin boyutlar ile bunlardaki hata oranı arasındaki korelasyona ilişkin kesin olmayan sonuçlar gösterse de, bir çalışma, 143 satırdan daha az kod içeren rutinlerin, daha büyük rutinlere göre düzeltilmesinin 2,4 kat daha ucuz olduğunu buldu. Başka bir çalışma, kodun en azından rutin ortalama 100 ila 150 satır kod olduğunda değiştirilmesi gerektiğini gösterdi. Başka bir çalışma, bir rutindeki yapısal karmaşıklığın ve veri miktarının, boyutuna bakılmaksızın hatalarla ilişkili olduğunu bulmuştur.
    • Rutinler arasındaki arayüzler, bir programın hataya en açık alanlarından bazılarıdır. Bir çalışma, tüm hataların yüzde 39'unun rutinler arasındaki iletişimde hatalar olduğunu gösterdi.
    • Kullanılmayan parametreler, artan bir hata oranı ile ilişkilidir. Bir çalışmada, birden fazla referans verilmeyen değişken içeren rutinlerin yalnızca yüzde 17 ila 29'unda hata yoktu, bu oran kullanılmayan değişken içermeyen rutinlerde yüzde 46 idi.
    • Araştırmalar, insanların genellikle aynı anda yaklaşık yedi bilgi parçasından fazlasını izleyemediğini ortaya çıkardığından, bir rutinin parametre sayısı en fazla 7 olmalıdır.
  • Kaynak kodu organizasyon (içine sınıflar, paketleri veya diğer yapılar). Göz önüne alındığında muhafaza, bir sınıftaki maksimum veri üyesi sayısı 7 ± 2'yi geçmemelidir. Araştırmalar, bu sayının, bir kişinin diğer görevleri yerine getirirken hatırlayabileceği ayrı öğe sayısı olduğunu göstermiştir. Göz önüne alındığında miras miras ağacındaki düzeylerin sayısı sınırlı olmalıdır. Derin kalıtım ağaçlarının artan hata oranları ile önemli ölçüde ilişkili olduğu bulunmuştur. Bir sınıftaki rutinlerin sayısı düşünüldüğünde, mümkün olduğunca küçük tutulmalıdır. C ++ programları üzerine yapılan bir araştırma, rutinlerin sayısı ile hata sayısı arasında bir ilişki bulmuştur.[10]
  • Kod belgeleri
  • Kod ayarlama

İnşaat testi

Yapım testinin amacı, hataların koda eklendiği zaman ile bu hataların tespit edildiği zaman arasındaki boşluğu azaltmaktır. Bazı durumlarda, yapı testi kod yazıldıktan sonra gerçekleştirilir. İçinde önce test programlama kod yazılmadan önce test senaryoları oluşturulur. İnşaat, genellikle tarafından gerçekleştirilen iki test biçimini içerir. yazılım Mühendisi kim yazdı kodu:[1]

Yeniden kullan

Uygulama yazılımın yeniden kullanımı oluşturmak ve kullanmaktan daha fazlasını gerektirir kütüphaneler varlıklar. Uygulamanın resmileştirilmesini gerektirir yeniden kullanmak yeniden kullanım süreçlerini ve faaliyetlerini yazılım yaşam döngüsü. Yazılım yapımında yeniden kullanımla ilgili görevler kodlama ve test yapmak şunlardır:[1]

  • Yeniden kullanılabilir ünitelerin seçimi, veritabanları, test prosedürleri veya test verisi.
  • Değerlendirilmesi kodu veya yeniden kullanılabilirliği test edin.
  • Yeniden kullanım bilgilerinin yeni kod, test prosedürleri veya test verisi.

İnşaat kalitesi

Kalitesini sağlamak için kullanılan birincil teknikler kodu inşa edildiği gibi şunları içerir:[15]

  • Birim testi ve entegrasyon testi. Bir çalışma, birim testi ve entegrasyon testinin ortalama hata tespit oranlarının sırasıyla% 30 ve% 35 olduğunu buldu.[16]
  • Önce test geliştirme
  • Kullanımı iddialar ve savunmacı programlama
  • Hata ayıklama
  • Muayeneler. Bir çalışma, resmi kod denetimlerinin ortalama kusur tespit oranının% 60 olduğunu buldu. Kusur bulmanın maliyeti ile ilgili olarak, bir çalışma, kod okumanın testten saat başına% 80 daha fazla hata tespit ettiğini buldu. Başka bir çalışma, tasarım hatalarını test kullanarak tespit etmenin teftişleri kullanmaktan altı kat daha pahalı olduğunu göstermiştir. IBM tarafından yapılan bir araştırma, kod incelemeleri yoluyla bir kusur bulmak için gereken yerlerde yalnızca 3,5 saatin, testlerde ise 15-25 saat olduğunu gösterdi. Microsoft, kod incelemelerini kullanarak bir kusuru bulup düzeltmenin 3 saat sürdüğünü ve testi kullanarak bir kusuru bulup düzeltmenin 12 saat sürdüğünü bulmuştur. 700 bin satırlık bir programda, kod incelemelerinin testten birkaç kat daha düşük maliyetli olduğu bildirildi.[16] Araştırmalar, denetimlerin, daha az resmi inceleme uygulamalarına göre 1000 kod satırı başına% 20 -% 30 daha az hata ile sonuçlandığını ve üretkenliği yaklaşık% 20 artırdığını buldu. Resmi denetimler genellikle proje bütçesinin% 10-15'ini alacak ve genel proje maliyetini azaltacaktır. Araştırmacılar, resmi bir teftişte 2-3 gözden geçirenden fazlasının bulunmasının, bulunan kusurların sayısını artırmadığını, ancak sonuçların incelenen malzemenin türüne bağlı olarak değiştiğini bulmuşlardır.[17]
  • Teknik incelemeler. Bir çalışma, kayıt dışı kişilerin ortalama kusur tespit oranlarının kod incelemeleri ve masa kontrolü sırasıyla% 25 ve% 40'tır.[16] İzlenecek yollar kusur tespit oranının% 20 -% 40 olduğu ancak özellikle proje baskıları arttığında pahalı olduğu görülmüştür. Kod okumanın, test için saatte 1,8 hataya karşılık, saat başına 3,3 kusur tespit ettiği NASA tarafından bulundu. Ayrıca, proje ömrü boyunca farklı test türlerine göre% 20 -% 60 daha fazla hata bulur. Gözden geçirme toplantıları hakkında 13 gözden geçirme üzerine yapılan bir çalışmada, kusurların% 90'ının gözden geçirme toplantısına hazırlanırken, toplantı sırasında yalnızca yaklaşık% 10'unun bulunduğu bulundu.[17]
  • Statik analiz (IEEE1028)

Çalışmalar, yüksek kusur tespit oranına ulaşmak için bu tekniklerin bir kombinasyonunun kullanılması gerektiğini göstermiştir. Diğer araştırmalar, farklı insanların farklı kusurlar bulma eğiliminde olduğunu gösterdi. Bir çalışma şunu buldu: Aşırı Programlama uygulamaları çiftler programı, masa kontrolü, birim testi, entegrasyon testi, ve gerileme testi % 90 kusur tespit oranına ulaşabilir.[16] Deneyimli programcıların katıldığı bir deney, test ederek ortalama olarak 15 hatadan 5 hatayı (en iyi ihtimalle 9) bulabildiklerini buldu.[18]

Hataların% 80'i proje sınıflarının ve rutinlerinin% 20'sinde yoğunlaşma eğilimindedir. Hataların% 50'si proje sınıflarının% 5'inde bulunur. IBM, 425 sınıftan yalnızca 31'ini onararak veya yeniden yazarak, müşteri tarafından bildirilen kusurları on kat azaltabildi ve IMS sisteminde bakım bütçesini% 45 azaltabildi. Bir projenin rutinlerinin yaklaşık% 20'si, geliştirme maliyetlerinin% 80'ine katkıda bulunur. IBM tarafından yapılan klasik bir çalışma, OS / 360'ın hataya açık birkaç rutininin en pahalı varlıklar olduğunu buldu. 1000 kod satırı başına yaklaşık 50 kusurları vardı ve bunları düzeltmek, tüm sistemi geliştirmek için gerekenin 10 katına mal oluyordu.[18]

Entegrasyon

İnşaat sırasında önemli bir faaliyet, ayrı ayrı inşa edilen rutinler, sınıflar, bileşenleri ve alt sistemler. Ek olarak, belirli bir yazılım sistemi diğer yazılım veya donanım sistemleriyle entegre edilmesi gerekebilir. İnşaat entegrasyonuyla ilgili endişeler arasında, bileşenleri entegre edilecek, geçici destek için iskele oluşturacak versiyonlar of yazılım derecesini belirlemek test yapmak ve kalite üzerinde yapılan iş bileşenleri entegre edilmeden önce ve projenin hangi ara dönemlerde versiyonlar of yazılım test edilmektedir.[1]

İnşaat teknolojileri

Nesneye yönelik çalışma zamanı sorunları

Nesne yönelimli diller, programların esnekliğini ve uyarlanabilirliğini artıran bir dizi çalışma zamanı mekanizmasını destekler. veri soyutlama, kapsülleme, modülerlik, miras, çok biçimlilik, ve yansıma.[19][20]

Veri soyutlama, veri ve programların, uygulama ayrıntılarını gizlerken, biçim olarak anlamlarına benzer bir temsil ile tanımlandığı süreçtir.[21] Akademik araştırmalar, veri soyutlamanın programları işlevsel programlardan yaklaşık% 30 daha kolay anlaşılmasını sağladığını göstermiştir.[10]

İddialar, sözleşmeye göre tasarım ve savunma amaçlı programlama

İddialar programın çalışma zamanı kontrollerine izin veren bir programa yerleştirilen çalıştırılabilir tahminlerdir.[19] Sözleşmeli tasarım her rutin için ön koşulların ve son koşulların dahil edildiği bir geliştirme yaklaşımıdır. Savunma programlama bir rutinin geçersiz girişler tarafından bozulmaya karşı korunmasıdır.[22]

Hata işleme, istisna işleme ve hata toleransı

Hata işleme, program çalıştığında ortaya çıkabilecek hata durumlarını tahmin etme ve kodlama programlama pratiğini ifade eder. İstisna işleme program yürütmenin normal akışını değiştiren özel durumların, özel koşulların oluşumunu işlemek için tasarlanmış bir programlama dili yapısı veya donanım mekanizmasıdır.[23] Hata toleransı hataları tespit ederek ve ardından mümkünse onlardan kurtararak yazılım güvenilirliğini artıran veya kurtarma mümkün değilse etkilerini içeren bir teknikler koleksiyonudur.[22]

Devlet temelli ve tablo temelli inşaat teknikleri

Durum tabanlı programlama, program davranışlarını tanımlamak için sonlu durum makinelerini kullanan bir programlama teknolojisidir.[22] Tablo temelli bir yöntem, mantık deyimleri (if ve case gibi) kullanmak yerine bilgileri aramak için tabloları kullanan bir şemadır.[24]

Çalışma zamanı yapılandırması ve uluslararasılaştırma

Çalışma zamanı yapılandırması, program çalışırken, genellikle yapılandırma dosyalarını tam zamanında modunda güncelleyerek ve okuyarak değişken değerleri ve program ayarlarını bağlayan bir tekniktir. Uluslararasılaştırma birden çok yerel ayarı desteklemek için genellikle etkileşimli bir yazılım olan bir program hazırlamanın teknik faaliyetidir. İlgili faaliyet, yerelleştirme, belirli bir yerel dili desteklemek için bir programı değiştirme etkinliğidir.[24]

Ayrıca bakınız

Notlar

  1. ^ a b c d e f g SWEBOK Pierre Bourque; Robert Dupuis; Alain Abran; James W. Moore, editörler. (2004). "Bölüm 4: Yazılım Yapısı". Yazılım Mühendisliği Bilgi Yapı Kılavuzu. IEEE Bilgisayar Topluluğu. sayfa 4–1–4–5. ISBN  0-7695-2330-7.
  2. ^ a b c d e SWEBOK 2014, s. 3-3.
  3. ^ McConnell 2004, Bölüm 3.
  4. ^ SWEBOK 2014, s. 3-5.
  5. ^ McConnell 2004, Bölüm 5.
  6. ^ SWEBOK 2014, s. 3-5 - 3-6.
  7. ^ McConnell 2004, Bölüm 4.
  8. ^ SWEBOK 2014, s. 3-6.
  9. ^ McConnell 2004, Bölüm 11.
  10. ^ a b c McConnell 2004, Bölüm 6.
  11. ^ a b McConnell 2004, Bölüm 7.
  12. ^ McConnell 2004 Bölüm 12.
  13. ^ a b McConnell 2004 16.Bölüm
  14. ^ a b McConnell 2004 Bölüm 19.
  15. ^ SWEBOK 2014, s. 3-7.
  16. ^ a b c d McConnell 2004 Bölüm 20.
  17. ^ a b McConnell 2004 Bölüm 21.
  18. ^ a b McConnell 2004 Bölüm 22.
  19. ^ a b SWEBOK 2014, s. 3-8.
  20. ^ Thayer 2013, sayfa 140 - 141.
  21. ^ Thayer 2013, s. 140.
  22. ^ a b c SWEBOK 2014, s. 3-9.
  23. ^ Thayer 2013, s. 142.
  24. ^ a b SWEBOK 2014, s. 3-10.

Referanslar

Dış bağlantılar