220 likes | 385 Views
Ohjelmistotekniikka johdanto. Kevät 2003 Hanna-Kaisa Lammi LTKK/Tite. Miksei vain koodata?. Kerrostaloa ei voi rakentaa samoilla tiedoilla kuin koirankoppia. Vastaavasti kaupallisia ohjelmistoja ei voi tehdä pelkällä ohjelmointitaidolla. Ohjelmoijan ja ohjelmistotuottajan suhdetta voikin
E N D
Ohjelmistotekniikkajohdanto . Kevät 2003 Hanna-Kaisa Lammi LTKK/Tite
Miksei vain koodata? Kerrostaloa ei voi rakentaa samoilla tiedoilla kuin koirankoppia. Vastaavasti kaupallisia ohjelmistoja ei voi tehdä pelkällä ohjelmointitaidolla. Ohjelmoijan ja ohjelmistotuottajan suhdetta voikin tietyssä mielessä verrata kirvesmiehen ja insinöörin suhteeseen
Mitä on ohjelmistotuotanto? • Ohjelmistotuotanto käsittää ohjelmistojen tuotantoprosessit, niiden hallitsemisen ja niissä käytettävät menetelmät, eli • tavat, kuinka ohjelmistoja tuotetaan • kuinka tuotantoprosessia hallitaan niin, että lopputuotos on sellainen kuin haluttiin • millä menetelmillä lopputulos saavutetaan
Tyypillisiä kysymyksiä • Miten saan aikaiseksi asiakkaan tarpeet täyttävän ohjelmiston? • Kuinka teen luotettavasti toimivan järjestelmän? • Kuinka suunnittelen ohjelmiston niin, että eri osat toimivat saumattomasti yhteen? • Kuinka saan tehtyä ohjelmiston sovitun aikataulun puitteissa • jne…
Ohjelmistotuotannon sovellusalueita Lähde: Haikala, Märijärvi: Ohjelmistotuotanto, 2000.
Ohjelmistotyyppejä • Varus- ja työkaluohjelmistot • Teknis-tieteelliset laskentaohjelmistot • Tietämyspohjaiset järjestelmät • Kaupallis-hallinnolliset järjestelmät • Prosessinohjaus- ja prosessiautomaatiojärjestelmät • Sulautetetut järjestelmät • WWW-pohjaiset ohjelmistot • Reaaliaikajärjestelmät, reaktiiviset järjestelmät
Ohjelmistotuotannon kasvunäkymät TEKES / Suomen ohjelmistoteollisuuden kasvun strategia ja haasteet (1999): • Ohjelmistoala kasvaa kaikkialla maailmassa paljon nopeammin kuin talous keskimäärin • Ohjelmistoteollisuus kasvaa lähivuosina todennäköisesti yhdeksi Suomen teollisuusklustereista • Ohjelmistoteollisuuden liikevaihto vuonna 1998 oli Suomessa noin 10 miljardia markkaa ja alalla työskenteli noin 20'000 henkilöä; ohjelmistoalalla toimivia yrityksiä on Suomessa tuhansia • Henkilöstöpula on maailmanlaajuinen ilmiö ohjelmistoalalla • Ohjelmistoyritykset toivovat saavansa puolet työvoimastaan yliopistotasolta
Ohjelmistotuotannon osa-alueita Haikala, Märijärvi: Ohjelmistotuotanto, 2000.
Ohjelmistotuotannon standardit ja mallit Ohjelmistoprosessin arviointi ja parantaminen - Software Process Assesment and Improvement • SPICE - Software Process Improvement and Capability dEtermination • SW-CMM - Capability Mature Model for Software • Trillium Ohjelmiston elinkaariprosessit - Software life-cycle processes • ISO/IEC 12207 - Software life-cycle processes Tuotelaatu - Software Product Quality • ISO/IEC 9126 - Product quality
Ohjelmistotuotannon standardit ja mallit Laatujärjestelmä - Quality System • ISO 9001 - Quality systems: Assurance of design/development, production, installation and servicing capability • ISO 9000-3 - Guidelines for the application of ISO 9000 to the development, supply and maintenance of software • MSQH - Modelling a Software Quality Handbook Tietoturvallisuus - Security Techniques • SSE-CCM - Systems Security Engineering CMM
Määritelmiä Software -- ohjelmisto Computer programs, procedures, rules, documentation, and data pertaining to the operation of a computer system. Software Engineering – Ohjelmistotuotanto, ohjelmistotekniikka “The art of producing high quality software - in schedule and - in budged.” “The application of a systematic; disciplined, quantifiable approach to the development, operation, and maintenance of software [IEE 610.12] Vapaa tulkinta: Ohjelmistotuotanto – ohjelmistotyö, jonka tuloksena syntyvät järjestelmät täyttävät käyttäjiensä kohtuulliset toiveet ja odotukset ja tämän lisäksi valmistuvat laadittujen aikataulujen ja kustannusarvioiden puitteissa
Ohjelmistoa kuvaavat ominaisuudet • Ohjelmiston koko ja käsiteltävän tiedon määrä • Vasteaika- ja reaaliaikaisuusvaatimukset • Luotettavuus • Hajautus • Tuotteistusaste
Yrityksen tietotekniikka Haikala, Märijärvi: Ohjelmistotuotanto, 2000.
Oma liiketoiminta Liiketoimintaympäristö Oma tietojärjestelmätoiminta Liikeidea Asiakkaat Kehittämis- Kilpailijat hankkeet Projektit Tietotekniikan Strategia, kehitys kilpailutekijät Tietohallinto Tietohallinto- strategia Yrityksen kilpailutilanne Haikala, Märijärvi: Ohjelmistotuotanto, 2000.
Ohjelmistotuotannon ongelmia • korkeat kustannukset • työmäärät ja aikataulut arvioitu väärin (yli puolet ohjelmistoprojekteista myöhästyy) • ohjelmistotuonnon ongelmat näyttävät pääasiassa liittyvän itse tuotantoprosessiin eikä uusiin menetelmiin tai tekniikoihin • alan tutkimus tulisi kohdistaa tuotantoprosessiin
Ohjelmistotekniikka kansanperinteestä tieteeksi [Shaw 1990]
Ohjelmistojen erityspiirteitä • monimutkaisuus • näkymättömyys • muunnettavuus • ainutkertaisuus • menetelmien skaalautumattomuus • epäjatkuvuus
Kannattaako edes yrittää? ”Parhaiten onnistuvat ne, jotka eivät luota liikaa viimeisimpiin poppakonsteihin, mutta ovat silti valmiita itse kokeilemaan uusia ideoita, vaikka ne esitettäisiinkin karnevaalihumussa mainosmiesten pötypuheiden seassa” [Weinberg 1982] • Mikään ei korvaa ratkaistavan ongelman perusteellista ymmärtämistä- joskus voi tosin käydä hyvä tuuri • Mikään ratkaisu ei sovellu kaikkiin tehtäviin ja johonkin tilanteeseen parhaiten soveltuva lähestymistapa voi olla toisessa tilanteessa kaikista huonoin
Onnistumisen teesejä • On olemassa monia hyödyllisiä lähestymistapoja, jotka toimivat useammassa kuin yhdessä tilanteessa, joten kannattaa tutustua sellaiseen mikä on toiminut aikaisemmin • Ongelman ratkaisun niksi ei ole pelkästään miten menetelmiä sovelletaan (know-how) vaan mieluummin milloin niitä sovelletaan (know-when)- tämä antaa mahdollisuuden sovittaa ratkaisumenetelmä ongelmaan eikä päinvastoin
Onnistumisen teesejä • Riippumatta siitä, kuinka hyvin taidat miten ja milloin, on olemassa ongelmia, jotka ovat nykytietämyksellä mahdottomia ratkaista tai joiden perimmäisiä ominaisuuksia kukaan ei ymmärrä riittävän hyvin: nöyryys on siis aina paikallaan