The following are widely considered the main programming paradigms:
Paradigm | Description | Main traits | Examples |
---|---|---|---|
Imperative | Programs as statements that directly change computed state (datafields) | Direct assignments, common data structures, global variables | C, C++, Java, PHP, Python, Ruby |
Structured | A style of imperative programming with more logical program structure | Structograms, indentation, no or limited use of goto statements | C, C++, Java, Python |
Procedural | Derived from structured programming, based on the concept of modular programming or the procedure call | Local variables, sequence, selection, iteration, and modularization | C, C++, Lisp, PHP, Python |
Functional | Treats computation as the evaluation of mathematical functions avoiding state and mutable data | Lambda calculus, compositionality, formula, recursion, referential transparency, no side effects | C++,[1] Clojure, Coffeescript,[2] Elixir, Erlang, F#, Haskell, Lisp, Python, Ruby, Scala, SequenceL, Standard ML, JavaScript |
Event-driven including time-driven | Control flow is determined mainly by events, such as mouse clicks or interrupts including timer | Main loop, event handlers, asynchronous processes | JavaScript, ActionScript, Visual Basic, Elm |
Object-oriented | Treats datafields as objects manipulated through predefined methods only | Objects, methods, message passing, information hiding, data abstraction, encapsulation, polymorphism, inheritance, serialization-marshalling | Common Lisp, C++, C#, Eiffel, Java, JavaScript, PHP, Python, Ruby, Scala |
Declarative | Defines program logic, but not detailed control flow | Fourth-generation languages, spreadsheets, report program generators | SQL, regular expressions, CSS, Prolog, OWL, SPARQL |
Automata-based programming | Treats programs as a model of a finite state machine or any other formal automata | State enumeration, control variable, state changes, isomorphism, state transition table | Abstract State Machine Language |
What is the best programming paradigm for blockchain technology?
follow me on:
steemit
Not indicating that the content you copy/paste is not your original work could be seen as plagiarism.
Some tips to share content and add value:
Repeated plagiarized posts are considered spam. Spam is discouraged by the community, and may result in action from the cheetah bot.
Creative Commons: If you are posting content under a Creative Commons license, please attribute and link according to the specific license. If you are posting content under CC0 or Public Domain please consider noting that at the end of your post.
If you are actually the original author, please do reply to let us know!
Thank You!
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
Hi! I am a robot. I just upvoted you! I found similar content that readers might be interested in:
https://en.wikipedia.org/wiki/Comparison_of_programming_paradigms
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
awesome
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
What is awesome? The question? Or the fact nobody answered right now ;-)
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
follow me i will follow you and upvote all your future post lets work together
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
This is like asking which is better when using wood, a saw or a hammer? It depends on the project. There is no "one true paradigm" just as there is no "one true language" or "one true data structure" -- because each exists to solve a specific problem within a specific domain facing specific forces.
A blockchain is just a piece of the puzzle.
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit