<?php
/**
* Created by PhpStorm.
* User: YANGHY
* Date: 2020/4/12
* Time: 20:36
*/
/**
* 1.变量
* 变量名严格区分大小写,以字母或下滑线为开头,例如$x,x代表规范的变量名称。
* 变量名称不能以数字开头。
* 变量名称只能包含字母数字字符和下划线(A-z、0-9 以及 _),例如包含 # @ ! 等特殊字符将报错。
* 变量的类型不用指定,根据上下代码自动分配,例如 $name = 10; $name = "hello";
*
*/
$name = "hello";
//下划线开头
$_name ="world";
echo $name." ".$_name;
/**
* 变量的销毁
* unset($x), 其中$x指代变量
* 释放空间,相当于删除
*/
$age = 12;
echo "未销毁变量前输出: ".$age; //未销毁变量前输出: 12
unset($age);
echo "销毁变量后输出: ".$age; // Undefined variable
/**
* 变量的类型, php本身就是弱语言类型,不用声明类型
* var_dump($x) 其中$x表示任意变量(引用),作用:可输出其类型和值
* 1.四种标量类型: 整形(int) 浮点型(float) 字符串(string) 布尔型(bool,true或false)
*/
$int = 12;
$float = 3.14;
$str ="hello";
$bool = True;
var_dump($int); //int(12)
var_dump($float); //float(3.14)
var_dump($str); // string(5) "hello"
var_dump($bool); // bool(true)
/*
* 2. 两种复合类型
* 数组(array)和对象(object)
*/
// 索引数组
$arr1 = ["数据1","数据2","数据3"];
/**
array(3) {
[0]=>
string(7) "数据1"
[1]=>
string(7) "数据2"
[2]=>
string(7) "数据3"
}
*/
var_dump($arr1);
foreach ($arr1 as $a){
echo $a."\n";
}
//array() 函数用于创建数组
$arr2 = array("data1","data2","data3");
foreach ($arr2 as $a2){
echo $a2."\n";
}
//关联数组
$arr3 = array("name"=>"yang","age"=>12,"sex"=>"0");
/**
array(3) {
["name"]=>
string(4) "yang"
["age"]=>
int(12)
["sex"]=>
string(1) "0"
}
*/
var_dump($arr3);
foreach ($arr3 as $key=>$val){
echo $key.":".$val."\n";
}
// 多维数组
$MultiArray=array(
array("name"=>"gogo","age"=>10,"sex"=>"0"),
array("name"=>"lili","age"=>12,"sex"=>"1"),
array("name"=>"dodo","age"=>14,"sex"=>"1")
);
/**
array(3) {
[0]=>
array(3) {
["name"]=>
string(4) "gogo"
["age"]=>
int(10)
["sex"]=>
string(1) "0"
}
[1]=>
array(3) {
["name"]=>
string(4) "lili"
["age"]=>
int(12)
["sex"]=>
string(1) "1"
}
[2]=>
array(3) {
["name"]=>
string(4) "dodo"
["age"]=>
int(14)
["sex"]=>
string(1) "1"
}
}
*/
var_dump($MultiArray);
// 遍历多维数组(这里是二维数组)
foreach ($MultiArray as $arr){
foreach ($arr as $key=>$val){
echo $key.":".$val."\n";
}
}
// 对象
class Dog {
var $name;
var $age;
function toPrint(){
echo "我的名字是: ".$this->name;
}
}
$obj = new Dog();
$obj->name = "大黄";
$obj->age = 10;
echo $obj->toPrint();
var_dump($obj);
/**
* 3.两种特殊类型
* 资源类型(resource) 例如打开文件资源
* NUll类型
*/
$file = fopen("C:\\Users\\YANGHY\\Desktop\\123.xlsx","r");
var_dump($file); // resource(5) of type (stream)
$null = NULL;
var_dump($null); // NULL
/**
* 字符串中,若涉及单双引号的使用,若要使其没有语义,即为普通字符,则使用转义字符"\"
* 例如 $a = 'test\'byyang';
*/
$a = 'test\'byyang';
echo $a;
/**
* 定界符的使用
* 形如 <<<www(任意三个字母) .......... www;
* 输出的字符串格式保持原格式
* 在定义一些简单字符串时,单引号的效率较高
*/
$b = <<<www
infoasalkdada
dasfjkseljfirejgier
dksfks
www;
echo $b;
/**
八个魔术常量:
__LINE__ :返回文件中的当前行号。也可写成__line__。
__FILE__:返回当前文件的绝对路径(包含文件名)。
__DIR__:返回当前文件的绝对路径(不包含文件名),等价于 dirname(__FILE__)。
__FUNCTION__:返回当前函数(或方法)的名称。
__CLASS__:返回当前的类名(包括该类的作用区域或命名空间)。
__TRAIT__:返回当前的trait名称(包括该trait的作用区域或命名空间)。
__METHOD__:返回当前的方法名(包括类名)。
__NAMESPACE__:返回当前文件的命名空间的名称。
*/
//echo __FILE__; // 当前文件名
//echo __LINE__; // 当前行数
//// 不区分大小写
//echo __file__;
//echo __line__;
/**
预定义常量
内核预定义常量:是在PHP的内核中就定义好了的常量。区分大小写。
PHP_VERSION:返回PHP的版本。
PHP_OS:返回执行PHP解释器的操作系统名称。
PHP_EOL:系统换行符,Windows是(\r\n),Linux是(\n),MAC是(\r)。
标准预定义常量:PHP默认定义的常量。区分大小写。
M_PI:返回圆周率π的值。
*/
//echo PHP_VERSION."\n";
//echo PHP_OS."\n";
//echo PHP_EOL;
//echo M_PI;
/**
PHP 中的许多预定义变量都是"超全局的",这意味着它们在一个脚本的全部作用域中都可用。在函数或方法中无需执行 global $variable, 就可以访问它们。
超全局变量是在全部作用域中始终可用的内置变量。
$GLOBALS:global全局变量,是一个包含了所有全局变量的组合数组,全局变量的名称就是该组合数组的键。
$_GET:HTTP GET 变量,通过 URL 参数传递给当前脚本的变量的数组。
$_POST:HTTP POST 变量,通过 HTTP POST 方式传递给当前脚本的变量的数组。
$_COOKIE:HTTP Cookies 变量,通过 HTTP Cookies 方式传递给当前脚本的变量的数组。
$_SESSION:session 变量,当前脚本可用的 SESSION 变量的数组。
$_REQUEST:HTTP Request 变量,默认情况下包含了 $_GET,$_POST 和 $_COOKIE 的数组。
$_FILES:HTTP 文件上传变量,通过 HTTP POST 方式上传到当前脚本的项目的数组。
$_SERVER:服务器信息变量,包含了诸如头信息(header)、路径(path)、以及脚本位置(script locations)等信息的数组。这个数组中的项目由 Web 服务器创建。
$_ENV:环境变量,通过环境方式传递给当前脚本的变量的数组。
以下预定义变量都是非全局的:
$php_errormsg:前一个错误信息,$php_errormsg 变量包含由 PHP 生成的最新错误信息。这个变量只在错误发生的作用域内可用,并且要求 track_errors 配置项是开启的(默认是关闭的)。
$HTTP_RAW_POST_DATA:包含 POST 提交的原始数据。
$http_response_header:HTTP 响应头,$http_response_header 数组与 get_headers() 函数类似。当使用HTTP包装器时,$http_response_header 将会被 HTTP 响应头信息填充。
$argc:传递给脚本的参数数目,包含当运行于命令行下时传递给当前脚本的参数的数目。脚本的文件名总是作为参数传递给当前脚本,因此 $argc 的最小值为 1,这个变量仅在 register_argc_argv 打开时可用。
$argv:传递给脚本的参数数组,包含当运行于命令行下时传递给当前脚本的参数的数组。第一个参数总是当前脚本的文件名,因此 $argv[0] 就是脚本文件名,这个变量仅在 register_argc_argv 打开时可用
*/