Java の次を探して Python、Ruby、Scala、Kotlin といろいろ試していたら、何もしないうちに 1か月も経ってしまいました。
このまま迷っていても仕方ないので Python を使うことに決めました。といってもこれといった決め手がなく、モヤモヤ感が拭い去れないです。
Python はシンプルかつコードの見た目が良いのですが、Python 2 → 3 の激変っぷりに、主要な Python プロダクトが付いてこない(付いていく気がない?)ので、Python の未来が不安です。
Ruby は書くのは楽しいですが、読むのはつらいです。自分の知らない書き方がいっぱいありすぎて、全然わかりません。修業しないとダメでしょうか。
Scala はコンセプトが素晴らしいのですが、実際書いてみたら型推論や、def のカッコ有り無しの差とかが良くわからん…。Scala の何がダメということはないですが、どうも性に合いません。
Kotlin はシンプルで素敵なのですが、マイナーなせいかネットにも情報が少なく、ハマったら死にそうなので諦めました。
ひとまず主要な部分だけ移植してみようと思って PyCharm を起動したら、試用期間が切れていて起動しませんでした。ぬわー。
言い訳して辞めてしまわないように PyCharm の Personal License を購入して、退路を断ちました。ライセンスは購入するとすぐにメールで送られてきますので、特に待つこともなく使えます。
支払いにはクレジットカードが使えて、お値段は 99$です。高くもなく安くもない、絶妙な値段です。
初めて触れたオブジェクト指向言語が C++ で、その次が Java だったためか、クラス宣言時にアクセス制限が厳格に決まり、コンパイル時または実行時に型チェックがあるのは当然だと思っていました。
そのためカプセル化とは public, protected, private を正しく宣言することであり、class A を取る関数に A と継承関係にない class B を渡せば、コンパイル時にエラーか、実行時に例外が発生するものだと思っていました。
しかし Python や Ruby は C++ と同じオブジェクト指向言語に分類されますが、この辺りの考え方が全く違います。
アクセス制限はなく、カプセル化は実質存在しません。Python であれば先頭にアンダースコアのついた変数、メソッドにはアクセスしてはいけない、というルールがあるだけで、簡単に壊せますし、チェックもされません。
型チェックも行わない(※)ので、class A を取る関数に継承関係にない class B を渡してもエラーは起きません。もし class A と class B が同じメソッド名を実装していれば実行時に例外すら発生しません。ダックタイピングというんでしたっけ?
(※)インタプリタやコンパイラがチェックしないという意味です、自分で型チェックしようと思えばチェック可能です。
静的型付けとか動的型付けといわれてもピンと来ないですが、両方触ってみたら何となくわかった気になれます。印象としては神経質な静的型付け、大雑把な動的型付けって感じです。
どちらが良い悪いというものではないです。
個人的には静的型付けに慣れているのもあって、事前チェックが多い方がミスが減って好ましいです。とはいえ、試作や小物ツールを書くときチェックがうるさすぎて、適当に書きたくても書けないことも多いんで、チェックすりゃ良いってものでもありません…。
中学時代〜高校にかけて、初学者向けの本で BASIC、C を学んでから、高校生になって、数学 C の BASIC の章を見つけました。
そのとき、数学の記号と、プログラミング言語の記号は意味が違うのに、なぜ同じ数学Cの教科書で説明されているのだろう?と疑問に思った記憶があります。
たとえは良くないかもしれませんが、数学の教科書なのに突然、物理や化学の話が書いてあるような違和感がありました。
高校の授業では大抵 BASIC は習いませんので、数学 C を先に学んだ人はどう感じるか?を確認できないのが残念ですが…。
メモ: 技術系?の話は Facebook から転記しておくことにした。
管理者: Katsuhiro Suzuki(katsuhiro( a t )katsuster.net)
This is Simple Diary 1.0
Copyright(C) Katsuhiro Suzuki 2006-2021.
Powered by PHP 5.2.17.
using GD bundled (2.0.34 compatible)(png support.)