I understand very clearly the difference between functional and imperative programming techniques. But there’s a widespread tendency to talk of “functional languages”, and this really confuses me.
Of course some languages like Haskell are more hospitable to functional programming than other languages like C. But even the former does I/O (it just keeps it in a ghetto). And you can write functional programs in C (it’s just absurdly harder). So maybe it’s just a matter of degree.
Still, even as a matter of degree, what does it mean when someone calls Scheme a “functional language”? Most Scheme code I see is imperative. Is it just that Scheme makes it easy to write in a functional style if you want to? So too do Lua and Python. Are they “functional languages” too?
I’m (really) not trying to be a language cop. If this is just a loose way of talking, that’s fine. I’m just trying to figure out whether it does have some definite meaning (even if it’s a matter-of-degree meaning) that I’m not seeing.
Among people who study programming languages for a living, “functional programming language” is a pretty weakly bound term. There is a strong consensus that:
A significant minority also reserve the term “functional language” for languages which are:
as in languages like Agda, Clean, Coq, and Haskell.
Beyond that, what’s considered a functional programming language is often a matter of intent, that is, whether is designers want it to be called “functional”.
Perl and Smalltalk are examples of languages that support first-class functions but whose designers don’t call them functional. Objective Caml is an example of a language that is called functional even though it has a full object system with inheritance and everything.
Languages that are called “functional” will tend to have features like the following (taken from Defining point of functional programming):
The more a particular programming language has syntax and constructs tailored to making the various programming features listed above easy/painless to express & implement, the more likely someone will label it a “functional language”.