Ugrás a tartalomhoz

Barbara Liskov

A Wikiszótárból, a nyitott szótárból
(Liskov szócikkből átirányítva)


Főnév

Barbara Liskov (tsz. Barbara Liskovs)

  1. (informatika) Barbara Liskov amerikai számítógép-tudós, a programozási nyelvek, az elosztott rendszerek és a szoftverfejlesztés elméleti alapjainak egyik úttörő alakja. Nevéhez fűződik többek között a híres Liskov-helyettesítési elv (Liskov Substitution Principle, LSP), amely a modern objektum-orientált programozás egyik alapelve lett. Szintén kiemelkedő munkát végzett a CLU nevű programozási nyelv megalkotásában, amely a generikus programozás, az absztrakció és az adatrejtés számos későbbi nyelvre (pl. Java, C#, Python) gyakorolt hatást.



📚 Életút

Barbara Jane Huberman néven született 1939. november 7-én, az Egyesült Államokban, Kaliforniában. Gyermekként erős érdeklődést mutatott a matematika és a logika iránt, ám a programozás akkoriban még nem volt elérhető pálya a nők számára.

  • 1950-es, 1960-as évek: A University of California, Berkeley egyetemen szerzett matematikai alapdiplomát (BA) 1961-ben. Ezt követően rövid ideig a Mitre Corporation nevű szervezetnél dolgozott, ahol elkezdett informatikával foglalkozni.
  • PhD: A Stanford Egyetemen doktorált számítástudományból 1968-ban. Érdekesség, hogy ő volt a Stanford első női hallgatója, aki PhD fokozatot szerzett számítástudományból. Disszertációjának témája: „A Program-Synthesis Technique for Generating Checkers” — az automatikus programgenerálásról szólt.
  • Karrier: 1972-től kezdődően a Massachusetts Institute of Technology (MIT) professzora lett, ahol máig is aktív kutatóként és oktatóként tevékenykedik.



👩‍💻 Tudományos munkásság

1️⃣ CLU programozási nyelv

Az 1970-es évek közepén Liskov a CLU programozási nyelvet tervezte meg csapatával az MIT-n. A CLU jelentős hatással volt a későbbi programozási nyelvek fejlődésére:

  • Absztrakt adattípusok (abstract data types, ADT): a CLU egyik fő innovációja volt az ADT fogalmának bevezetése, amely lehetővé teszi az adatstruktúrák viselkedésének világos definícióját és az implementáció elrejtését a felhasználó elől.
  • Generikusok: a típusparaméterezés (generic programming) korai támogatása.
  • Kivételkezelés: a modern kivételkezelési mechanizmusok előfutára is a CLU volt.
  • Iterátorok: bevezette az iterátor mintát, amely a mai napig jelen van például a Java, C++, C# nyelvekben.

A CLU nem vált széles körben elterjedt nyelvvé ipari környezetben, de óriási hatása volt a nyelvtervezésre.

2️⃣ Liskov-helyettesítési elv (LSP)

1987-ben Liskov és Jeannette Wing publikálta a Liskov Substitution Principle nevű alapelvet. Ennek lényege:

„Ha S típus származik T típusból, akkor minden olyan helyen, ahol T típust használnánk, S típust is használhatunk anélkül, hogy a program helyes működését befolyásolná.”

Ez a gondolat alapvető szerepet játszik az öröklődés, a polimorfizmus és a szoftvertervezési elvek (SOLID) helyes alkalmazásában. A hibásan alkalmazott öröklés sok esetben sérti ezt az elvet, aminek következményeként törékeny, nehezen karbantartható kód keletkezik.

Az LSP-t a SOLID elvek egyikeként ismerik a modern objektum-orientált tervezésben.

3️⃣ Elosztott rendszerek

Liskov fontos eredményeket ért el az elosztott rendszerek kutatásában is:

  • Argus: az egyik első elosztott programozási nyelv, amely támogatta a tranzakciókat és a hibaellenálló (fault-tolerant) programozást.
  • Thor: egy elosztott objektum-adatbázis, amely lehetővé tette a skálázható, megbízható és hatékony adattárolást.

Munkái hozzájárultak az elosztott rendszerek konzisztencia-kezelési eljárásainak és tranzakciós mechanizmusainak fejlődéséhez.

4️⃣ További területek

  • Formal Methods: formális verifikáció, korrekt programok készítése matematikai bizonyítással.
  • Fault tolerance: hibakezelő architektúrák tervezése.
  • Programming methodology: a szoftverfejlesztés módszertanainak kidolgozása.



🏆 Elismerések

Barbara Liskov kiemelkedő munkáját számos díjjal jutalmazták:

  • ACM Turing-díj (2008): az informatikai világ legnagyobb presztízsű díja, a „számítástechnika Nobel-díjaként” is emlegetik. A CLU nyelv és az absztrakt adattípusok bevezetéséért, valamint a programozási nyelvek és elosztott rendszerek fejlődéséhez való hozzájárulásáért kapta meg.
  • John von Neumann Medal (2018): az IEEE kitüntetése a kiemelkedő informatikai eredményekért.
  • National Academy of Engineering, National Academy of Sciences, American Academy of Arts and Sciences tagja.



👩‍🏫 Oktatási tevékenység

Barbara Liskov évtizedek óta a MIT professzora. Munkássága során:

  • több ezer hallgatót tanított programozáselméletre, elosztott rendszerekre, szoftvertervezésre,
  • doktorált hallgatók tucatjait irányította, közülük sokan lettek ismert kutatók.

Stílusára jellemző a rendszereségekre, absztrakciókra és a helyes tervezési elvekre való fókuszálás.



👩‍🔬 Hatása a modern szoftverfejlesztésre

Barbara Liskov öröksége a mindennapi programozási gyakorlatban is jelen van:

  • Amikor absztrakt adattípusokat, generikusokat, kivételkezelést, vagy iterátorokat használunk, lényegében az ő és csapata úttörő ötleteit használjuk.
  • Az LSP nélkülözhetetlen minden professzionális objektum-orientált tervezés során.
  • Az elosztott rendszerek világában a tranzakciós modellek és a hibakezelés alapelveit ma is az ő eredményei táplálják.



🌟 Összefoglalás

Barbara Liskov neve megkerülhetetlen a számítástechnika történetében. Úttörő volt több alapvető programozási elv bevezetésében és formalizálásában:

  • az absztrakt adattípusok,
  • a generikus programozás,
  • az LSP,
  • az elosztott rendszerek tranzakciós modelljei.

Munkája nemcsak a tudományos közösségre, hanem az iparra is mély hatást gyakorolt. Ma is aktív professzorként, kutatóként dolgozik, inspirálva a következő informatikus generációkat.