Home  >  Article  >  Backend Development  >  foreach循环中$p[] = $MaterialType 的疑问

foreach循环中$p[] = $MaterialType 的疑问

WBOY
WBOYOriginal
2016-06-23 14:00:34957browse

class so_getMaterialType{	var $CreateTime = '';	var $IsDefault = '';	var $UpdateTime = '';}$p = array();$sql = 'SELECT * from tb where lid<50';$re_materialTypeID = $db->getAll($sql);foreach($re_materialTypeID as $key => $val){		$getMaterialType = new so_getMaterialType ;  //为什么每次循环都要新申请一遍,而不是放在循环外面申请一次即可??				$getMaterialType->CreateTime =  $val['CreateTime'];		$getMaterialType->IsDefault = $val['IsDefault'];		$getMaterialType->UpdateTime = $val['UpdateTime'] ;		$p[] = $getMaterialType ;}var_dump($p);return $p;	/*????????这种写法与上面差别是什么?????????????*/$getMaterialType = array();$getMaterialType[] = new so_getMaterialType ;$sql = 'SELECT * from tb where lid<50';$re_materialTypeID = $db->getAll($sql);foreach($re_materialTypeID as $key => $val){		$getMaterialType[$key]->CreateTime =  $val['CreateTime'];		$getMaterialType[$key]->IsDefault = $val['IsDefault'];		$getMaterialType[$key]->UpdateTime = $val['UpdateTime'] ;}var_dump($getMaterialType);return $getMaterialType;


回复讨论(解决方案)

我在用amf2.1.1 与flex通讯,产生的问题,调试过程中,传递这样类的数组总是有问题

第一段代码
$p 是一个含有若干个 so_getMaterialType 对象的数组

第二段代码
$getMaterialType 的第一个元素是 so_getMaterialType 对象,其余的是 stdClass 对象

显然你需要的是第一种写法的结果
因此可以

class so_getMaterialType {  var $CreateTime = '';  var $IsDefault = '';  var $UpdateTime = '';  function __construct($a) {    foreach($a as $k->$v) $this->$k = $v;  }}$p = array();$sql = 'SELECT * from tb where lid<50';$re_materialTypeID = $db->getAll($sql); foreach($re_materialTypeID as $key => $val) {   $p[] = new so_getMaterialType($val) ;}

比如循环了10次,第一种写法保存了so_getMaterialType的10个对象,第二种写法只保存了一个对象,所以第二种写法里得到的数组值是一样的。

这就好比下面这一段代码:

$value = 10;$array[0] = $value;$value=12;$array[1] = $value;print_r($array);

得到的结果必然是两个12

不好意思,上面的例子错了。只有在对象的赋值中才会有这种,因为对象本质上是一个指针

终于和flex通了一个函数,谢谢楼主。

比如循环了10次,第一种写法保存了so_getMaterialType的10个对象,第二种写法只保存了一个对象,所以第二种写法里得到的数组值是一样的。

这就好比下面这一段代码:

$value = 10;$array[0] = $value;$value=12;$array[1] = $value;print_r($array);

得到的结果必然是两个12

第15行:
 $getMaterialType = new so_getMaterialType ;  //为什么每次循环都要新申请一遍,而不是放在循环外面申请一次即可??         
你的意思是,如果只申请一次new so_getMaterialType 那么数组p中的每个类对象都是一样的值,对吧,我在跟踪过程中的确是这样的,
 $p[] = $getMaterialType ; 这里,p[] 理解成数组的指针? ,指向10个类对象,对么?

 $getMaterialType = new so_getMaterialType ;

关键字new会生成一个内存空间,该内存的地址赋给$getMaterialType,即$getMaterialType是一个指向前面内存空间的地址。所以,对象$getMaterialType就是指针。

$p[] = $getMaterialType ;

因为第一种写法没有改变$getMaterialType的值,所有p[]里所有元素指向同一块内存地址,数据当然也就一样了。
而第二种写法中,每次都会生成一个新的内存空间,并把地址赋给$getMaterialType,所以p[]中元素指向的是不同的内存空间。

简单来说:
只有$getMaterialType =  ×××才会改变$getMaterialType值,$getMaterialType->属性 = ×××不会改变$getMaterialType的值

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn