ALGOL 60
ALGOL 60 (abreviatura de Algorithmic Language 1960 ) és un membre de la família ALGOL de llenguatges de programació informàtica. Va seguir l'ALGOL 58 que havia introduït els blocs de codi i els parells Niklaus Wirth va basar el seu propi ALGOL W en ALGOL 60 abans de passar a desenvolupar Pascal. Algol-W estava pensat per ser la propera generació d'ALGOL, però el comitè ALGOL 68 va decidir un disseny més complex i avançat en lloc d'un ALGOL 60 simplificat net. Les versions oficials d'ALGOL reben el nom de l'any en què es van publicar per primera vegada. ALGOL 68 és substancialment diferent d'ALGOL 60 i va ser criticat parcialment per ser-ho, de manera que en general "ALGOL" fa referència als dialectes d'ALGOL 60. NormalitzacióALGOL 60 –amb COBOL– van ser els primers idiomes a buscar l'estandardització.
HistòriaALGOL 60 va ser utilitzat principalment per investigadors informàtics als Estats Units i a Europa. El seu ús en aplicacions comercials es va veure obstaculitzat per l'absència d'instal·lacions estàndard d'entrada/sortida en la seva descripció i la manca d'interès per l'idioma per part dels grans venedors d'ordinadors. Tanmateix, ALGOL 60 es va convertir en l'estàndard per a la publicació d'algorismes i va tenir un efecte profund en el desenvolupament futur del llenguatge. John Backus va desenvolupar el mètode de forma normal de Backus per descriure llenguatges de programació específicament per a ALGOL 58. Va ser revisat i ampliat per Peter Naur per a ALGOL 60, i per suggeriment de Donald Knuth va canviar el nom de Backus–Naur form.[2] Peter Naur: "Com a editor del Butlletí ALGOL, em vaig atreure als debats internacionals sobre la llengua i vaig ser seleccionat per ser membre del grup europeu de disseny lingüístic el novembre de 1959. En aquesta qualitat vaig ser l'editor de l'informe ALGOL 60, elaborat com a resultat de la reunió ALGOL 60 a París el gener de 1960". PropietatsL'ALGOL 60, tal com es va definir oficialment, no tenia instal·lacions d'E/S; les implementacions definien les seves pròpies de maneres que poques vegades eren compatibles entre si. En canvi, ALGOL 68 oferia una àmplia biblioteca d'instal·lacions de transput (parla d'ALGOL 68 per a entrada/sortida). ALGOL 60 va proporcionar dues estratègies d'avaluació per passar paràmetres: la trucada per valor comú i la trucada per nom. La declaració de procediment especificada, per a cada paràmetre formal, que s'havia d'utilitzar: valor especificat per a la trucada per valor i omès per a la trucada per nom. La trucada per nom té certs efectes en contrast amb la trucada per referència. Per exemple, sense especificar els paràmetres com a valor o referència, és impossible desenvolupar un procediment que intercanvii els valors de dos paràmetres si els paràmetres reals que es passen són una variable entera i una matriu que està indexada per aquesta mateixa variable entera.[3] Penseu a passar un punter per canviar (i, A[i]) a una funció. Ara que cada vegada que es fa referència a l'intercanvi, es reavalua. Digues jo := 1 i A[i] := 2, de manera que cada vegada que es fa referència a l'intercanvi retornarà l'altra combinació dels valors ([1,2], [2,1], [1,2], etc.). Una situació similar es produeix amb una funció aleatòria passat com a argument real. Call-by-name és conegut per molts dissenyadors de compiladors pels interessants " thunks " que s'utilitzen per implementar-lo. Donald Knuth va idear la " prova de l'home o del nen " per separar els compiladors que implementaven correctament la " recursivitat i les referències no locals". Aquesta prova conté un exemple de trucada per nom.[4] Referències
|