Este artigo não cita fontes confiáveis. Ajude a inserir referências. Conteúdo não verificável pode ser removido.—Encontre fontes: ABW  • CAPES  • Google (N • L • A) (Fevereiro de 2014)
Objective Caml
Paradigma Multiparadigma:
Surgido em 1996 (27–28 anos)
Última versão 4.12.0 (24 de fevereiro de 2021; há 3 anos)
Criado por INRIA
Estilo de tipagem
  • estática
  • forte
  • inferida
Dialetos:
  • JoCaml
  • MetaOCaml
  • OcamlP3l
Influenciada por
Influenciou
Sistema operacional Multiplataforma
Licença Q Public License (compilador)
LGPL (biblioteca)
Extensão do arquivo
  • .ml
  • .mli
Página oficial ocaml.org

Objective Caml, também conhecida como OCaml (Objective Categorical Abstract Machine Language), é uma linguagem de programação funcional da família ML, desenvolvida pelo INRIA em 1996. Trata-se da linguagem Caml com a adição de suporte de técnicas de orientação a objetos e algumas alterações e extensões de sintaxe.

OCaml permite dois tipos de compilação, para bytecode que corre numa máquina virtual (zinc) ou para código de máquina nativo para um grande número de plataformas. Ela não é uma linguagem puramente funcional, permitindo a existência de valores mutáveis bem como de efeitos colaterais (side-effects), tipicamente existentes apenas em linguagens imperativas. Esta característica distingue-a de outras linguagens puramente funcionais, como por exemplo Haskell.

A excelência de seu compilador que tem gerado código nativo rapidamente e com excelente desempenho quanto a tempos de execução, bem como uma biblioteca base extensa, têm-lhe conquistado bastante notoriedade.

Características

[editar | editar código-fonte]

Exemplos

[editar | editar código-fonte]

Comentários

[editar | editar código-fonte]
(* Comentário... *)

Olá Mundo

[editar | editar código-fonte]
print_endline "Hello world!"
(* Imprime "Hello world!" *)

Funções como valores

[editar | editar código-fonte]
let s x y = x + y in
let d x y = x - y in
let sq f x y = (f x y)*(f x y) in
let square_sum = sq s in
let square_dif = sq d in
print_string( string_of_int(square_sum 4 6)^ "\t" ^ string_of_int(square_dif 4 6));;

(* Imprime 100  4 *)

Closures

[editar | editar código-fonte]
let gen_next i =
    let _add x = i+x in
    _add
;;
let f = gen_next 10 in
print_int (f 5);;

(* Imprime 15 *)

Factorial recursivo

[editar | editar código-fonte]
let rec fact x =
    match x with
    |0->1
    |_ -> x*(fact (x-1))
;;
print_int (fact 20);;

(* Imprime 45350912 *)

Valores mutáveis (conhecidos como "variáveis", no estilo imperativo)

[editar | editar código-fonte]
let a = ref 1;;
print_int !a;;
a:=!a+1;;
print_int !a;;

(* Imprime 1 e 2*)

Ver também

[editar | editar código-fonte]

Ligações externas

[editar | editar código-fonte]