proces uklanjanja fizičkih, prostornih ili vremenskih detalja[1] ili atributa u izučavanju objekata ili sistema da bi se pažnja usmjerila na detalje veće važnosti;[2] slično prirodnom procesu generalizacije;
kreiranje objekata apstraknih koncepata oponašanjem zajedničkih karakteristika ili atributa različitih neapstraktnih objekata ili sistema ili studija[2] – rezultat procesa apstrakcije.
Apstrakcija generalno, fundamentalni je koncept u računarstvu i razvoju softvera.[3] Proces apstrakcije može se također definisati kao modeliranje i usko je povezan konceptima teorije i dizajna.[4] Modeli također mogu biti smatrani tipovima apstrakcija zbog njihovih generalizacija aspekata realnosti.
Apstrakcija u računarstvu je usko povezano s apstrakcijom u matematici zbog zajedničkog fokusa na građenju apstrakcija kao objekata,[1] ali je također povezano sa pojmovima apstrakcije korištenim u ostalim poljima kao što je umjetnost.[2]
Apstrakcije se također mogu odnositi na objekte i sisteme iz stvarnog svijeta, na pravila računarskih sistema ili pravila programskih jezika koji nose ili primjenjuju karakteristike same apstrakcije, npr:
korištenje tipova podataka za obavljanje podatkovne apstrakcije za odvajanje reprezentacija korištenja od reprezentacije rada podatkovnih struktura unutar programa;[5]
koncept procedura, funkcija ili subrutina koje predstavljaju specifikaciju implementacije kontrolnih tokova u programima;
pravila zajednički nazvana "apstrakcija" koja generaliziraju izraze korištenjem slobodne i vezane varijable u različitim sistemima lambda računa;[6][7]
proces reorganizacije zajedničkih ponašanja iz neapstraktnih klasa u "apstraktne klase" korištenjem nasljeđivanja za apstrakciju preko podklasa kao što je slučaj kod objektno orijentiranihC++ i Java programskih jezika.
^Comer, D. E.; Gries, David; Mulder, Michael C.; Tucker, Allen; Turner, A. Joe; Young, Paul R. /Denning (1. 1. 1989). "Computing as a discipline". Communications of the ACM. 32 (1): 9–23. doi:10.1145/63238.63239. ISSN0001-0782.
^Liskov, Barbara (1. 5. 1988). "Keynote address – data abstraction and hierarchy". ACM SIGPLAN Notices. ACM. 23: 17–34. doi:10.1145/62138.62141. ISBN0897912667.
^Barendregt, Hendrik Pieter (1984). The lambda calculus : its syntax and semantics (Revised izd.). Amsterdam: North-Holland. ISBN0444867481. OCLC10559084.
^Barendregt, Hendrik Pieter (2013). Lambda calculus with types. Dekkers, Wil., Statman, Richard., Alessi, Fabio., Association for Symbolic Logic. Cambridge, UK: Cambridge University Press. ISBN9780521766142. OCLC852197712.