php的语句
1.php流程语句
1.php代码执行从上到下
2.条件语句 if else 和 switch
案例:
$name=56;
if($name>56) echo "hello world";
条件语句的画图解析:

if else 条件语句(主要针对范围)
switch 条件语句(主要针对具体的值)
案例:
$name=1;
switch($name){
case 1:
echo "1";
break;
case 2:
echo "2";
break;
}
4.循环语句:
for
案例:
for($i=0;$i<3;$i++){
echo $i;
}
while
案例:
while($i<5){
echo $i;
$i++;
}
do while
do{
echo "$i";
$i++;
}
while($i<5);
for each 针对关联数组
案例:
$arr=array("name"=>"zhang","age"=>12);
foreach($arr as $key=>$value){
echo $key;
}
注意:while和do while的区别:
while 先判断后执行
do while 先执行后判断;
js中的数组,本质是对象;
php中没有json格式。但是对于前端来说要 json格式
php提供了一个方法叫 json_encode() 将数据转化为json格式;
php数组:
1.普通数组:$arr=[1,2,3,4];
另一种写法:$arr=array(1,2,3,4);
2.关联数组:
$arr=array("name"=>"zhang","age"=>18);
3.多维数组:
两种情况:
1.$arr=[1,2,3,[4,5,6,[12,45]],7,8,9]; 普通函数的多维数组;
2.$arr=array("name"=>array("zhang","li","wang'),"age"=>array(12,24,36)); 关联数组的多为数组;
多维数组的遍历: (利用递归的特性)
function fn($arr){
foreach($arr as $key=>$value){
if(is_array($value)){
fn($value);
}
else{
echo $value."<br />";
}
}
}
fn($arr);
两个方法:
获取数组长度的方法:count();
判断一个变量是不是数组:is_array();
函数:php的自定义函数和内置函数;
使用关键字function定义函数;
function fn(){} fn()
函数调用的时候,会开辟内存空间,有栈和堆,调用完毕后内存就会被销毁,销毁的顺序,先进后出;
画图解析函数:
代码:
function fn(){
function ff(){
echo "hello world";
}
ff();
}
fn();
画图:

称之为:函数作用域;
四个关键字:global local static parameter
global全局变量都会存在$GLOBALS的超全局变量里面 , $GLOBALS的本质是一个数组;
函数参数;
1.参数传值:
function fn($a){
echo $a;
}
fn(56);
2.默认参数:
function fn($a=23){
echo $a;
}
fn();
3.引用传参:将地址传进去;
函数内部,如果修改了这个地址里的值,函数外也会跟着改
$n=20;
function fn(&$n){
$n++;
echo $n+2;
}
fn($n);
echo $n;
如果传的有默认参数和普通参数同时传,主要注意顺序问题。
在js中函数自身有一个arguments的属性,实参构成的数据集合;
argument的方法:
func_num_args() 获取实参的个数;
func_get_arges() 获取实参构成的集合 因为是数组,输出的时候要用 var_dump();
func_get_age(index) 必填参数,获取具体的某个参数;
递归:
函数内部调用函数本身:
function test($n){
echo $n;
if($n>0){
test($n-1);
}
else{
echo "==="
}
echo $n;
}
test(3); 得到的答案:3210===0123;
画图解析:

php的语句的更多相关文章
- python第六天 函数 python标准库实例大全
今天学习第一模块的最后一课课程--函数: python的第一个函数: 1 def func1(): 2 print('第一个函数') 3 return 0 4 func1() 1 同时返回多种类型时, ...
- whdxlib
1 数据库系统实现 实 验 指 导 书 齐心 彭彬 计算机工程与软件实验中心 2016 年 3 月2目 录实验一.JDBC 应用程序设计(2 学时) ......................... ...
- 【.net 深呼吸】细说CodeDom(2):表达式、语句
在上一篇文章中,老周厚着脸皮给大伙介绍了代码文档的基本结构,以及一些代码对象与CodeDom类型的对应关系. 在评论中老周看到有朋友提到了 Emit,那老周就顺便提一下.严格上说,Emit并不是针对代 ...
- 将表里的数据批量生成INSERT语句的存储过程 增强版
将表里的数据批量生成INSERT语句的存储过程 增强版 有时候,我们需要将某个表里的数据全部或者根据查询条件导出来,迁移到另一个相同结构的库中 目前SQL Server里面是没有相关的工具根据查询条件 ...
- mysql学习之 sql语句的技巧及优化
一.sql中使用正则表达式 select name,email from user where email Regexp "@163[.,]com$"; sql语句中使用Regex ...
- SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少.但我 ...
- MySQL 系列(三)你不知道的 视图、触发器、存储过程、函数、事务、索引、语句
第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...
- Oracle 数据库语句大全
Oracle数据库语句大全 ORACLE支持五种类型的完整性约束 NOT NULL (非空)--防止NULL值进入指定的列,在单列基础上定义,默认情况下,ORACLE允许在任何列中有NULL值. CH ...
- MyBatis源码分析(二)语句处理器
StatementHandler 语句处理器,主要负责语句的创建.参数的设置.语句的执行.不负责结果集的处理. Statement prepare(Connection connection, Int ...
- 一条Sql语句分组排序并且限制显示的数据条数
如果我想得到这样一个结果集:分组排序,并且每组限定记录集的数量,用一条SQL语句能办到吗? 比如说,我想找出学生期末考试中,每科的前3名,并按成绩排序,只用一条SQL语句,该怎么写? 表[TScore ...
随机推荐
- 解决ERROR - unregister mbean error javax.management.InstanceNotFoundException: com.alibaba.druid:type=
https://blog.csdn.net/chengsi101/article/details/72627062 https://www.cnblogs.com/gradven/p/6323195. ...
- Js判断字符的种类
Js判断字符的种类:unicode范围: 48-57:0-9 数字字符 65-90:A-Z 大写字母 97-122: a-z 小写字母 19968-40869:汉字 其他字符 实例:输出 ...
- 【mybatis源码学习】调试mybatis的第一个程序
[一].基础知识准备 mybatis-config.xml配置文件的结构 MyBatis配置文件中大标签configuration下子标签包括: configuration |--- properti ...
- OpenGL编程-第一个程序-画出一个正方形
账号是:qq876....... pwd:bky.13....................... 程序如下 #include <GL/glut.h> // #pragma comm ...
- golang for 循环变量取内存地址
前几天提交的代码进行测试的时候发现变量无法赋值,原始代码如下: for _, asset := range dspInfo.native.Assets { var resAsset protocol. ...
- Scalable MySQL Cluster with Master-Slave Replication, ProxySQL Load Balancing and Orchestrator
MySQL is one of the most popular open-source relational databases, used by lots of projects around t ...
- is_null, empty, isset的区别
参考博客: http://www.jb51.net/article/24666.htm http://www.jb51.net/article/36223.htm is_null, empty, is ...
- try catch 用法实例
- 【转】ImageView.ScaleType属性
原文网址:https://blog.csdn.net/Buaaroid/article/details/49360779 ImageView的Scaletype决定了图片在View上显示时的样子,如进 ...
- mysql之 OPTIMIZE TABLE整理碎片
来看看手册中关于 OPTIMIZE 的描述: OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ... 如果您已经删除 ...