パスワードを忘れた? アカウント作成
この議論は賞味期限が切れたので、アーカイブ化されています。 新たにコメントを付けることはできません。

PHP、5.3 系のサポート終了が迫るも移行進まず」記事へのコメント

  • 5.4の新機能の為に移りましょうよ

    traitがとても便利
    似非多重継承ができるのでオブジェクト指向言語としてなんとか許せるレベルになった感じ?(フレームの元?)
    trait型とかは使えないけど、まあ、PHPだし
    abstractメソッドとかは持てるし
    色々なクラスで使うメソッドをメンバで持たなくていいので記述がすっきり
    嬉しすぎてデバッグ系のメソッドまとめたtraitとか、メソッド結果キャッシュするtraitとか、
    DB結果編集によく使うメソッドまとめたtraitとかTool系のクラスを沢山traitに移植した
    privateフィールド名が被るとエラるのでtraitのprivateフィールドにベタな名前つけない点だけ注意
    (useで

    • by Anonymous Coward

      > 動かなくても殆どのケースでちょっと修正程度の事が殆ど
      この「ちょっと修正」をしたくないからみんな移らないんだよね。

      • by Anonymous Coward on 2013年03月26日 21時35分 (#2350730)

        しかもPHPの場合は「ちょっと修正」しなければならない場所を検出するのが、
        超めんどくさい。そこが最大の障害と言ってもいいくらいに。

        まず「コンパイル」がないから、コンパイル時のエラーでは変更点やバグを検出できないし、
        実行時エラーも一度実行しただけでは出るとは限らず、全パスの全ての組み合わせを
        網羅的に実行してようやくエラーが出る有様。

        さらに酷い時は関数や演算子の動作が変更されていて、実行したら結果は
        変われど、実行時エラーが出ずにすんなり動いてしまうことも。

        その結果、変更する部分が仮に本当に少しだけだったとしても、新バージョンへの
        移植とデバッグにかかるコストが膨大になる。

        親コメント
        • by Anonymous Coward

          PHP界隈には自動テストの習慣ってないんでしょうか?
          それとも、最先端のWeb開発ではテストを自動化するという流れはもう廃れてしまったのでしょうか?

          • by Anonymous Coward

            ないわけではないけれど、日本だと、
            「人月単価が安いから ≒ 低スキル技術者を使えるから」
            がPHPを採用する最大の理由だから。
            ユニットテストだなんて、そんな『高度なスキル』を駆使できる会社の方が珍しいかも。
            #そういう意味ではPHPは「最先端のWeb開発」じゃなくて、「時代遅れのWeb開発」なのです。

            そういう職場ではMVCフレームワークどころか、共通モジュールの切り分けさえ
            せずに、ガチガチに結合した単一のPHPファイルで書く人も多い。結果として
            テスト不可能なコードが量産されるので、ユニットテストどころの騒ぎでは無い。

            かといってPHPではフレームワークを使うと、今度はそのフレームワークが
            「フレームワーク Ver1はPHP5.0から5.2.xまでしか動きません。

          • by Anonymous Coward

            自分が作ったコード部分ならまだしも、他者が作ったライブラリやフレームワークについては、
            ユニットテストがあろうとなかろうと、変更する部分を検出することは困難。

            かりに判明しても、ライブラリがPHPの新しいバージョン用には提供されてなくて、差し替えようにも
            代替となるライブラリが存在しなくて、移行は断念せざるをえなかったり。運良く代替ライブラリが
            見つかっても、互換ではないために差し替えのコストがかなり高く付いたり。

            • by Anonymous Coward

              ライブラリやフレームワークについては、それぞれの開発者が検証をするのでは?
              言語のバージョンアップから検証が終わるまでのタイムラグはあるかもしれませんが、だからと言って利用されている現場それぞれで個別に検証するのはさすがに無駄過ぎるでしょう。

              • by Anonymous Coward

                >ライブラリやフレームワークについては、それぞれの開発者が検証をするのでは?
                理想としてはそうだと思う。
                でもPHP界隈における現実は違う。

                開発/サポートが打ち切られてPHP新バージョン用には提供されてなかったり、
                新しいバージョンで動くライブラリはあるけど互換性がありませんだったりは珍しくない。
                ライブラリの開発者だって、次々と互換性のない変更の入るPHP言語にウンザリしてるんでしょう。

                結果として結局は互換性の無いライブラリ間の移植作業や、
                ライブラリの独自カスタマイズが必要になる。

                >利用されている現場それぞれで個別に検証するのはさすがに無駄過ぎるでしょう。
                まったくその通りだと思います。

                それがPHPのバージョン間の移行コストが激しく高くなる原因の一つですね。
                #だからPHPなんて糞言語を採用するなとあれほど……。 orz

※ただしPHPを除く -- あるAdmin

処理中...