ホームページ >バックエンド開発 >PHPチュートリアル >PHP は依存関係の挿入をシミュレートします。コメントされたコードがエラーを報告するのはなぜですか? 長い間考え、Baidu を追加した後でも、まだ理解できません。

PHP は依存関係の挿入をシミュレートします。コメントされたコードがエラーを報告するのはなぜですか? 長い間考え、Baidu を追加した後でも、まだ理解できません。

WBOY
WBOYオリジナル
2016-06-20 12:29:401185ブラウズ

详细代码如下:
//模拟实现依赖注入
header("content-type:text/html;charset=utf-8");
interface Car{
public function getBrand();
パブリック関数 run();
}
クラス BMWCar implements Car{
private $myBrand="宝马";
public function getBrand(){
return $this->myBrand;
}
public function run(){
echo "
".$this->myBrand." は実行中です"."
";
}
}
class Human{
private $car;
public function getCar(){
return $this->car;
}
public function setCar(Car $car){
$this->car=$car;
}
public function myCarRun(){
$this->car->run();
}
}

interface BeanFactory{
public function getBean($id);
}
class ApplicationContext implements BeanFactory{
private $beans=array();
public function __construct(){
$xmlstr=simplexml_load_file('beans.xml');
print_r($xmlstr);
エコー "
";
//$xml=new SimpleXMlElement('beans.xml',0,true);
foreach ($xmlstr->bean as $key => $value) {
$id=$value['id'];
$class=$value['class'];
$reflect=new ReflectionClass("$class");
$instance=$reflect->newInstanceArgs();

foreach ($value as $key1 => $value1) {
if($key1=='property'){
$propertyName=$value1['name '];
$bean=$value1['bean'];
if(!isset($value1['bean'])){
$methodName='set'.ucfirst($propertyName);
$method=$reflect->getMethod($methodName);
$method->invoke($instance);
}
else{
var_dump($this->beans);
$propertyBean=$this->beans["$bean"];
//$propertyBean=$this->beans[$bean]; //これら 2 つの書き込みメソッドの結果は実際には異なります。 Why
🎜> echo $methodName; 🎜> $instance->$methodName($propertyBean);
インスタンス; $context=new ApplicationContext();
$car=$context->getBean('c'); ->run();
$human=$context->getBean ('human');

に相当します。 XML ファイルの内容へ


" class="Human">

いつもとても混乱していると思いますが、誰かが助けてくれる、そして私もこの問題はさらに調査する価値があると思います











ディスカッションへの返信 (解決策) )

エラーが報告された場合、$bean の値は何ですか? ここから問題を見つけることができます。

わかりました。以前、echo $bean; を使用してそれを検出したところ、Bean コンテナーの ID に対応する c がブラウザーに表示されました。それから、私は常にそれが正しいと思っていましたが、単に echo gettype を実行するだけです。 ($bean) ; 出力は Object であることがわかりましたが、実際にはオブジェクトは配列のキーとして使用できないため、間違いはここにあります

実際には、すでに var_dump($this-> ;豆);
なぜ彼の結果を見なかったらどうなるでしょうか?

$propertyBean=$this->beans[$bean];

$this->beans[$this->bean]; に変更されました🎜>

$propertyBean=$this->beans[$bean];

$this->beans[$this->bean]; に変更されました>

実際には、これを変更する必要はありません。つまり、$bean はクラス オブジェクトであり、$this->beans は配列であり、オブジェクトを変更することはできません。

実際、すでに var_dump($this->beans); の結果を見てみましょう。

もちろん、正しいものが返されるので、それを読みました。また、出力は bean.xml の対応する ID でもありますが、実際には $bean が返されます。 object オブジェクト、もっと厳密にして echo gettype($bean)

を使用するべきでした。そうですね。役に立たない

見ているのは var_dump( $this->beans);

使用しているのは $propertyBean=$this->beans[ $bean]; です。 >var_dump($bean); の場合 ($this->beans は独自定義の属性なので、妥当性をチェックする必要はまったくありません)

このようなレポートが表示されます
object( SimpleXMLElement)#7 (1) {

[0]=> string(1) "c"

}

$propertyBean=$this->beans["$bean"];通常の理由は、彼が __toString メソッド

を定義しているためです。

名前が似ていると間違いを犯しやすくなります。

var_dump($this->beans); は配列

var_dump($beans); です。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。