Opětovné použití kódu - Code reuse

Opětovné použití kódu, také zvaný opětovné použití softwaru, je využití stávajících software, nebo znalosti softwaru, k vytvoření nového softwaru,[1] v návaznosti na zásady opětovné použitelnosti.

Přehled

Ad hoc opětovné použití kódu bylo praktikováno od prvních dnů roku programování. Programátoři vždy znovu používali části kódu, šablony, funkce a procedury. Opětovné použití softwaru jako uznávané oblasti studia v softwarovém inženýrství se však datuje teprve od roku 1968, kdy Douglas McIlroy z Bell Laboratories navrhl založit softwarový průmysl na opakovaně použitelných součástech.

Cílem opětovného použití kódu je ušetřit čas a zdroje a snížit nadbytečnost využitím výhod aktiv, která již byla v nějaké formě vytvořena v rámci procesu vývoje softwarového produktu.[2] Klíčovou myšlenkou opětovného použití je, že části a počítačový program napsané najednou mohou být nebo by měly být použity při konstrukci dalších programů napsaných později.

Opakované použití kódu může znamenat vytvoření samostatně udržované verze opakovaně použitelných aktiv. Zatímco kód je nejběžnějším prostředkem vybraným pro opětovné použití, další aktiva generovaná během vývojového cyklu mohou nabízet příležitosti k opětovnému použití: softwarové komponenty, testovací sady, návrhy, dokumentace atd.[3]

The softwarová knihovna je dobrým příkladem opětovného použití kódu. Programátoři se mohou rozhodnout vytvořit interní abstrakce, aby bylo možné znovu použít určité části jejich programu, nebo mohou vytvořit vlastní knihovny pro vlastní použití. Některé vlastnosti, díky nimž je software snadněji použitelný, jsou modularita, volné spojení, vysoká soudržnost, skrývání informací a oddělení obav.

Pro nově napsaný kód použít kus existujícího kódu, nějaký druh rozhraní, nebo komunikační prostředky, musí být definovány. Mezi ně obvykle patří „volání“ nebo použití a podprogram, objekt, třída nebo prototyp. V organizacích jsou tyto postupy formalizovány a standardizovány doménové inženýrství, také známý jako softwarová produktová řada inženýrství.

Obecná praxe používání předchozí verze existujícího programu jako výchozího bodu pro další verzi je také formou opětovného použití kódu.

Některé takzvané „opětovné použití“ kódu zahrnuje jednoduše zkopírování části nebo celého kódu ze stávajícího programu do nového. Zatímco organizace mohou realizovat čas nakupovat výhody nového produktu s tímto přístupem, mohou být následně osazeny mnoha stejnými duplikace kódu problémy způsobené programování vyjmutí a vložení.

Mnoho vědců pracovalo na tom, aby opětovné použití bylo rychlejší, jednodušší, systematičtější a nedílnou součástí běžného procesu programování. To jsou některé z hlavních cílů vynálezu objektově orientované programování, která se stala jednou z nejběžnějších forem formálního opětovného použití. O něco pozdější vynález je generické programování.

Dalším, novějším prostředkem je použití softwaru “generátory ", programy, které mohou vytvářet nové programy určitého typu na základě souboru parametrů, které si uživatelé zvolí. Studijní obory těchto systémů jsou generativní programování a metaprogramování.

Druhy opětovného použití

Pokud jde o motivaci a hnací faktory, opětovným použitím může být:

  • Oportunistické - Při přípravě na zahájení projektu si tým uvědomí, že existují existující komponenty, které mohou znovu použít.
  • Plánované - Tým strategicky navrhuje komponenty tak, aby byly v budoucích projektech znovu použitelné.

Opětovné použití lze dále kategorizovat:

  • Interní opětovné použití - Tým opakovaně používá své vlastní komponenty. Může to být obchodní rozhodnutí, protože tým může chtít ovládat komponentu kritickou pro projekt.
  • Externí opětovné použití - Tým se může rozhodnout licencovat komponentu třetí strany. Licencování komponenty třetí strany obvykle stojí tým 1 až 20 procent toho, co by stálo za interní vývoj.[4] Tým musí také zvážit čas potřebný k nalezení, učení a integraci komponenty.

Pokud jde o formu nebo strukturu opětovného použití, kód může být:[5]

  • Odkazováno - Kód klienta obsahuje odkaz na znovu použitý kód, a proto mají odlišné životní cykly a mohou mít odlišné verze.
  • Vidlicový - kód klienta obsahuje místní nebo soukromou kopii znovu použitého kódu, a proto sdílí jeden životní cyklus a jednu verzi.

Opakované použití vidlice se často nedoporučuje, protože jde o formu duplikace kódu, která vyžaduje, aby byla každá chyba opravena v každé kopii, a vylepšení provedená v opakovaně použitém kódu je třeba ručně sloučit v každé kopii, jinak budou zastaralé. Opakované použití vidlice však může mít výhody, jako je izolace, flexibilita při změně znovu použitého kódu, snazší balení, nasazení a správa verzí.[5]

Systematický

Systematické opětovné použití softwaru je strategie pro zvýšení produktivity a zlepšení kvality softwarového průmyslu. I když je to v koncepci jednoduché, úspěšná implementace opětovného použití softwaru je v praxi obtížná. Důvodem je závislost opětovného použití softwaru na kontextu, ve kterém je implementován. Některé problematické problémy, které je třeba řešit v souvislosti se systematickým opětovným použitím softwaru, jsou:[6]

  • jasná a dobře definovaná vize produktu je základním základem softwarová produktová řada (SPL).
  • evoluční implementační strategie by byla pro společnost pragmatičtější strategií.
  • pro zajištění úspěchu existuje potřeba nepřetržité podpory vedení a vedení.
  • k podpoře inženýrství SPL je nutná příslušná organizační struktura.
  • změna myšlení z projektově orientované společnosti na společnost orientovanou na produkt je zásadní.

Příklady

Softwarové knihovny

Velmi častým příkladem opětovného použití kódu je technika použití a softwarová knihovna. Mnoho běžných operací, jako je převod informací mezi různými dobře známými formáty, přístup k externímu úložišti, propojení s externími programy nebo manipulace s informacemi (čísla, slova, jména, umístění, data atd.) Běžnými způsoby, je zapotřebí mnoha různými programy. Autoři nových programů mohou k provedení těchto úkolů použít kód v softwarové knihovně namísto „nového vynalézání kolečka“ psaním zcela nového kódu přímo do programu k provedení operace. Implementace knihoven mají často tu výhodu, že jsou dobře otestovány a pokrývají neobvyklé nebo tajemné případy. Nevýhody zahrnují neschopnost vyladit podrobnosti, které mohou ovlivnit výkon nebo požadovaný výstup, a čas a náklady na pořízení, učení a konfiguraci knihovny.[7]

Designové vzory

Návrhový vzor je obecným řešením opakujícího se problému. Návrhové vzory jsou koncepčnější než hmatatelné a lze je upravit tak, aby přesně odpovídaly potřebám. Abstraktní třídy a rozhraní však lze znovu použít k implementaci určitých vzorů.

Rámce

Vývojáři obecně znovu používají velké části softwaru prostřednictvím aplikací a rámců třetích stran. I když rámce jsou obvykle specifické pro doménu a jsou použitelné pouze pro rodiny aplikací[Citace je zapotřebí ].

Funkce vyššího řádu

v Funkcionální programování funkce vyššího řádu lze použít v mnoha případech, kdy byly dříve použity návrhové vzory nebo rámce.

Zpětný výpočet

Zpětný výpočet zahrnuje opětovné použití kódu, jednoduše proto, že retro programy jsou spuštěny na starších počítačích, nebo emulátory pro ně.

Zabezpečení počítače

v zabezpečení počítače opětovné použití kódu se používá jako metoda využití softwaru.[8]Když útočník není schopen přímo zadat kód, aby upravil tok řízení programu, například za přítomnosti obrany proti vložení kódu, jako je W ^ X může přesměrovat tok řízení na sekvence kódu existující v paměti.

Příklady útoků na opakované použití kódu jsou útok zpět na libc, návratově orientované programování a programování orientované na skok.[8][9]

Součásti

Komponenta v objektově orientovaném rozsahu představuje sadu tříd spolupráce (nebo pouze jednu třídu) a její rozhraní. Rozhraní jsou odpovědná za umožnění výměny komponent. Opakovaně použitelné komponenty lze také izolovat a synchronizovat mezi úložišti SCM pomocí technologií pro správu zdrojových kódů komponent (CSCM ).

Venkovní počítače

Celá koncepce „opětovného použití kódu“ může také zahrnovat inženýrské aplikace mimo software. Například, parametrické modelování v počítačem podporovaný design umožňuje vytvářet opakovaně použitelné vzory. Standardizace vede k vytvoření interoperabilních částí, které pak mohou být znovu použity v mnoha kontextech.[Citace je zapotřebí ]

Kritika

Výsledek opětovného použití kódu v závislost na opakovaně použitou součást. Rob Pike se domníval, že „malé kopírování je lepší než malá závislost“. Když vstoupil do Google, společnost kladla velký důraz na opětovné použití kódu. Věří, že Google kódová základna stále trpí výsledky této dřívější politiky z hlediska rychlosti a udržovatelnosti kompilace.[10]

Viz také

Reference

  1. ^ Frakes, W.B .; Kyo Kang (červenec 2005). "Výzkum opětovného použití softwaru: stav a budoucnost". Transakce IEEE v softwarovém inženýrství. 31 (7): 529–536. CiteSeerX  10.1.1.75.635. doi:10.1109 / TSE.2005.85. S2CID  14561810.
  2. ^ Lombard Hill Group. „Co je to opětovné použití softwaru?“. lombardhill.com. Lombard Hill Group. Citováno 22. října 2014.
  3. ^ Lombard Hill Group. „Co je to opětovné použití softwaru?“. Citováno 22. října 2014.
  4. ^ McConnell, Steve (1996). Rychlý vývoj: Zkrocení plánů divokého softwaru. ISBN  978-1-55615-900-8.
  5. ^ A b Colombo, F. (2011). „Není to jen opětovné použití“. SharedNow.blogspot.
  6. ^ Champman, M .; Van der Merwe, Alta (2008). „Uvažuje o systematickém opětovném použití softwaru v malé společnosti zaměřené na projekt“. Pokračování SAICSIT '08 Sborník z výroční konference o výzkumu v roce 2008 Jihoafrického institutu počítačových vědců a informačních technologů o výzkumu IT v rozvojových zemích: na vlně technologie. doi:10.1145/1456659.1456662. ISBN  978-1-60558-286-3.
  7. ^ „Opětovné použití kódu“. DocForge. Archivovány od originál dne 10.7.2011. Citováno 6. prosince 2020.
  8. ^ A b Bletsch, Tyler (2011). Útoky na opakované použití kódu: Nové hranice a obrana. Státní univerzita v Severní Karolíně. ISBN  978-1-124-75297-6.
  9. ^ Bletsch, Tyler; Jiang, Xuxian; Freeh, Vince W; Liang, Zhenkai (2011). „Skokově orientované programování: nová třída útoku na opětovné použití kódu“ (PDF). Proceedings of the 6th ACM Symposium on Information, Computer and Communications Security. ACM. 30–40. doi:10.1145/1966913.1966919. ISBN  978-1-4503-0564-8. Archivovány od originál (PDF) dne 7. 8. 2017. Citováno 2017-08-07.
  10. ^ Programovací jazyk Go (01.12.2015), Go Proverbs - Rob Pike - Gopherfest - 18. listopadu 2015, vyvoláno 26. února 2016

externí odkazy