0

私はOOP接続の効率について疑問に思っていました。構造例を以下に示します。各クラスはフォルダとクラス名で区切られています。例えば:

/mysql/mysql.class.php //holds general connect and disconnect functions
/mysql/query.class.php //holds all the queries made to the db (uses basic mysql ^ )
/library/application.class.php //holds all the algorithms (uses queries to db ^ )

アルゴリズムの実行に関しては、接続を要求application.class.phpするquery.class.php(クエリが必要な場合)mysql.class.php

これらの2つの方法のどちらが正しいですか(もしあれば、または両方)?これを行うためのより簡単で効率的な方法はありますか?

これが2つのことを行う同じ方法です(どちらがより効率的ですか??)

require_once('/mysql/mysql.class.php ');
require_once('/mysql/query.class.php ');

$mysqlClass = new MYSQL();
$queryClass = new Query();

class Application {                
  public function getVar() {         
    $param = foo;         
    $db = $mysqlClass->connect(); //connection to mysql
    $queryClass->callsomequerymethod($db, $param); //pass the db connection to function
  } 
} 

VS

class Application {     
  private $db;      
  public function __construct(DatabaseConnection $db, QueryClass $queryclass){
    $this->db = $db;     
  }           
  public function getVar() {         
    $param = foo;         
    $db = $this->db;
    $queryclass->callsomequerymethod($db, $param);
  } 
} 
4

1 に答える 1

0

効率についてコメントすることはできませんが、変数はグローバル名前空間にあるのではなく、変数を使用するクラス内で適切にスコープされているため、2番目の方法の方が適しています。

私が行うさらなる変更はrequire、コンストラクター内のステートメントを移動して、それらを使用するクラス(あなたの場合Application)がインスタンス化されたときにのみそれらのファイルが含まれるようにすることです。

于 2012-08-06T14:29:44.830 に答える