I'm a programmer who was introduced first to the functional paradigm. I'd like to better understand the object programming paradigm.<p>In the past, people have suggested Smalltalk as the best medium for learning concepts central to OOP. However, I've found the tooling has regressed in recent decades to the extent that I find using the language unpleasant (please correct me if I'm wrong).<p>In your opinion, which modern language best (and most simply) serves as a vehicle for teaching concepts core to OOP? I have no strong preference whether the type system is static or dynamic.
The problem is that your programming is styled by the language you choose. If you decide to go down the route of python then the curse of consenting adults will paint the way you believe object-oriented programming should be done. Likewise if you select something like C++ or Java, then the curse of privacy will paint the way you think about object-oriented programming.<p>The curse of privacy dictates that the existence of a public method will act as documentation for an object. methods only exists for the purpose of Performing operations on that objects type. This will make you think a lot more about how objects systems provide secure and well dictated data flow. Your objects will be authored to respect these ideas.<p>The curse of consenting adults dictates that human readable code trumps control flow. The idea of inheriting from a dictionary in Python to Define your own class object makes for extremely powerful objects that are immediately designed to interface with the Python language. There however may be operations that can be applied to dictionaries that you may not want applied to your objects.<p>If you really want to understand object-oriented programming, then you should use both. You should find as many programming languages as possible and explore how their idioms paint the color of your code.<p>I expect this isn't a preferred answer, but the real message is if you pick one and learn it, don't stop there. It will take you time to become comfortable enough to Warrant breaking into another language.<p>That all being said, python and ruby are easier as a programming languages (in general) than many Alternatives. So if you have to learn programming at the same time as object-oriented programming they aren't bad choices.
I don't know if it's best, but I took on OOP in little bites:<p>- ECMAScript 5<p>Mixins, scopes, instance variables, and instantiation.<p>As a bonus, but not OOP, callbacks. It's a straight-forward language that's available abundance.<p>- Python<p>For it's class inheritance being easy to navigate. Instance variables, instantiation, method resolution order (MRO), mixins.<p>- C++<p>This is the hardest language I can think of. It does <i>everything</i> OOP, and more, including allowing for a lot of stuff that's not legible.<p>Despite that, it's a solid language.<p>Something that goes great with constraining the many features of C++ are <a href="https://google.github.io/styleguide/cppguide.html" rel="nofollow">https://google.github.io/styleguide/cppguide.html</a> or <a href="https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines" rel="nofollow">https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines</a>.<p>I think ES5 and Python are used very often and in terms of bang for the buck, give they cover a lot of the bread and butter OOP concepts.
Ruby and Objective-C both have a strong Smalltalk lineage. You typically use the C part of Objective-C to perform basic operations like arithmetic and function calling -- if you know C already, it may be a more comfortable starting point, but it doesn't show off the power you get when <i>every</i> value is an object (and you can do things like add new numeric types while the system is running: <a href="http://lists.squeakfoundation.org/pipermail/squeak-dev/1998-October/025066.html" rel="nofollow">http://lists.squeakfoundation.org/pipermail/squeak-dev/1998-...</a>).