Na programação imperativa, geralmente temos código que se parece com o seguinte:
func addOneToSlice(xs []int) []int { rs := make([]int, len(xs)) for i, value := range xs { rs[i] = value 1 } return rs }
No entanto, observe o seguinte sobre o loop for:
Compare como a mesma tarefa seria feita em F#:
let rec addOneToList = function | [] -> [] | x :: xs -> x 1 :: addOneToList xs
Agora considere o seguinte:
Dadas essas restrições, adicionar 1 a qualquer elemento y que não esteja no topo da lista alteraria significativamente a estrutura de nossa função.
Agora compare como o cálculo progride em ambos os estilos:
No estilo funcional, casar ambos os escopos com o progresso computacional tem as seguintes consequências:
Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.
Copyright© 2022 湘ICP备2022001581号-3