Maison  >  Article  >  développement back-end  >  php小笔记 函数传值细节分析 php 函数返回值 php 数组 php date函

php小笔记 函数传值细节分析 php 函数返回值 php 数组 php date函

WBOY
WBOYoriginal
2016-07-29 08:52:041152parcourir

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教程有兴趣的朋友有所帮助。

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn