1.php函数传递参数的方式,到底是传递变量的地址还是传递变量的值;
1.1定义一个类
class Penson{
public $age;
public $name;
}
//实例化一个对象
$zs=new Penson();
$zs->age=10;
1.2 分别定义一个字符串,数字,数组;
$str="string";
$num="0";
$myArray=(10,100,100);
1.3定义一个函数
funtion test($str,$num,$arr,$obj){
$str="change string";
$num=100;
$arr[0]=0;
$obj->age="100";
}
test($str,$num,$arr,$zs);
执行函数后分别打印:
echo $str; // string
echo $num; // 0
echo $arr[0]; // 10
echo $zs; // 100
结论:字符,数字,数组以参数的形式传入函数是复制一份值传递到函数里面的,而对象则是把指向对象的地址传递进函数里面,所以当函数执行完后,当前函数在内存的栈被回收,所以创建的变量也销毁,所以不会影响到外面的变量,但是对象传进去的是地址,在函数里面修改的实际上是通过传进来的地址去操作对象,对象不能直接访问,只能通过地址的方式,所以函数里面修改的对象在函数执行完毕后,其影响还在。
当然,如果你想其他类型的数据也像对象一样,传进函数的是地址,在函数修改外面的变量,这php也是可以做到的,只要传参的时候这样传递就可以了:
test(&$str,&$num,&$arr,$zs);
在变量前加上一个&符号,这样不管什么数据类型,在函数里面修改的都会影响到函数外面的变量。
2.mysqli_insert_id($con)
有时候我们insert into后需要知道当前insert的数据在数据库中自动生成的id,这个时候就可以用mysqli_insert_id()方法了,该方法带一个参数,该参数为执行inser的用的数据库连接,如果不加上返回内容会出现警告,但是也会插入成功。
3.在php中视图获取一个不存在的变量是可能会报错,比如:$_POST["select"],如果select不存在,则会报错,应该尽量用isset()方法判断变量是否存在,然后再进行操作
4.用mysql创建表的时候切记要设置编码:
CREATE
TABLE
message(
id
int
(10) auto_increment
PRIMARY
KEY
NOT
NULL
,
username
VARCHAR
(16)
NOT
NULL
,
message
VARCHAR
(32)
NOT
NULL
,
time
datetime
NOT
NULL
)
//下面这句是用来设置编码的,如果不设置可能会导致中文乱码在数据库中
ENGINE= MYISAM
CHARACTER
SET
utf8 ;
以上就介绍了php小笔记 函数传值细节分析,包括了php,函数方面的内容,希望对PHP教程有兴趣的朋友有所帮助。