前言
不仅是PHP,大部分编程语言的函数或者叫方法,都可以用return来定义方法的返回值。从函数这个叫法来看,本身它就是一个计算操作,因此,计算总会有个结果,如果你在方法体中处理了结果,比如进行了持久化保存,那么这个函数就不用返回任何内容。而计算的结果是要给外部使用的,这时候就要将计算结果进行返回了。

return关键字

  1. function testA($a, $b)
  2. {
  3. echo $a + $b;
  4. }
  5. var_dump(testA(1, 2)); // NULL
  6. function testB($a, $b)
  7. {
  8. return $a + $b;
  9. }
  10. var_dump(testB(1, 2)); // 3
  11. function testC($a, $b)
  12. {
  13. return;
  14. echo $a + $b; // 后面不会执行了
  15. }
  16. var_dump(testC(1, 2)); // NULL

不用return或者直接return;都会返回NULL,return会阻断方法体中后续代码的执行。如果要返回多个值,只能使用数组组装数据。

  1. function testD($a, $b)
  2. {
  3. return [
  4. $a + $b,
  5. $a * $b,
  6. ];
  7. }
  8. var_dump(testD(1, 2)); // [3, 2]

返回值类型声明
关于返回值这一块还是比较好理解的。下面才是重头戏,在PHP7的新特性中,返回值声明是非常亮眼的一道风景

  1. function testE($a, $b) : bool
  2. {
  3. if($a+$b == 3){
  4. return TRUE;
  5. }else{
  6. return NULL;
  7. }
  8. }
  9. var_dump(testE(1, 2)); // true
  10. var_dump(testE(1.1, 2.2)); //TypeError: Return value of testE() must be of the type bool, null returned

如上例所示,如果返回值不是bool类型,那么将直接报TypeError的错误。

那么定义了返回值类型声明有什么好处呢?我们在PHP方法参数的那点事儿 有介绍过类型声明的好处,这里就不过多赘述了,不管是参数类型声明还是返回值类型声明,都是一样的。

  1. function testF($a, $b): array
  2. {
  3. return [
  4. $a + $b,
  5. $a * $b,
  6. ];
  7. }
  8. var_dump(testF(1, 2)); // [3, 2]
  9. interface iA{
  10. }
  11. class A implements iA
  12. {}
  13. class B extends A
  14. {
  15. public $b = 'call me B!';
  16. }
  17. function testG(): A
  18. {
  19. return new B();
  20. }
  21. function testH(): B
  22. {
  23. return new B();
  24. }
  25. function testI(): iA
  26. {
  27. return new B();
  28. }
  29. var_dump(testG()); // B的实例
  30. var_dump(testH()); // B的实例
  31. var_dump(testI()); // B的实例

同样,数组和类类型都是可以声明定义的。不过除此之外,返回值声明还可以定义void。它的作用其实就是声明返回值为NULL,不能直接写:NULL,而只能用:void来进行声明。

  1. function testJ(): void
  2. {
  3. echo "testJ";
  4. // return 1;
  5. }
  6. var_dump(testJ());

更多相关文章

  1. Sqlserver 表类型和表变量介绍
  2. sql将时间类型转换为字符串类型汇总
  3. 解决无法在unicode和非unicode字符串数据类型之间转换的方法详解
  4. android Uri获取真实路径转换成File的方法
  5. Android(安卓)MIME类型结构
  6. SQL Server数据类型char、nchar、varchar、nvarchar的区别浅析
  7. sql使用cast进行数据类型转换示例
  8. MSSQL报错:参数数据类型 text 对于 replace 函数的参数 1 无效的
  9. SQL Server页类型汇总+疑问汇总

随机推荐

  1. 如何将“u00e9”转换为一个utf8字符,在mys
  2. MYSQL从同一个表中选择标记关联的id
  3. 【整理】更改MSSQL默认字符集
  4. MySQL(三)——数据行 操作
  5. 求sql【复制同一表记录,但有两个字段需要
  6. [Python] - No.1 使用python3连接Mysql
  7. 从另一个表中的列更新列值
  8. 减去两个SELECT语句以产生单个结果?
  9. Python: Sqlite3简单封装实例
  10. 使用id替换存储在xml数据中的值