zoukankan      html  css  js  c++  java
  • PHP学习之输出字符串(echo,print,printf,printr和vardump)

    下面一一进行介绍。
    1. echo
    echo 是PHP的一个关键字,它没有返回值。在写法上,它可以省略小括号。如下代码:
    复制代码 代码如下:

    echo 'Test String';
    echo('Test String');

    2. print
    print 也是PHP的一个关键字,它有返回值,一般返回true,返回false的情况应该没有。在写法上,它和echo一样,可以省略小括号。如下代码:
    复制代码 代码如下:

    print 'Test String';
    print('Test String');

    3. printf
    printf可以像C语言的printf一样,格式化输出一个字符串。它的格式和C语言差不多,都是以%开头。其说明符定义如下。
    b 参数为整数,显示其二进制
    c 参数为整数,显示对应ASCII字符
    d 参数为整数,显示其十进制
    f 参数为双精度,显示为浮点数
    e 参数为双精度,显示为科学计数型
    g 参数为双精度,显示为浮点数或科学计数型
    o 参数为整数,显示其八进制
    s 参数为字符串,显示为字符串
    u 参数为无符号整数,显示其十进制
    x/X 参数为整数,显示其十六进制(分别为大小写显示)
    % 输出%要说明的是:
    f,e默认小数点后六位,g在超过六位(加小数点)时,会四舍五入,如果四舍五入之后的值小于1000000会直接输出,大于的1000000的话会显示成科学计数型。f在值大于1.2e23输出的结果是不对的。
    以上除%以外,其它的都可以指定输出总位数(小数点、E都算一位),并可以指定0或空格为补位符,还可以指定补位在左还是在右。
    f,e可以指定小数点后位数。
    如 %5d 表示输出总位数为5,不足左补空格; %05d 表示输出总位数为5,不足左补0; %05.1f 表示输出总位数为5,不足左补0,小数点后1位; %-05.1f 表示输出总位数为5,不足右补0,小数点后1位;
    示例代码:
    复制代码 代码如下:

    printf("%7.2f", 1.2); // " 1.20"
    printf("%-07.2f", 1.2); // "1.20000"

    4. sprintf
    sprintf和格式转换和printf一样,两者区别在于printf直接输出,而sprintf返回一个格式化后的字符串。
    5. print_r和var_dump
    print_r和var_dump都能输出数组和对象,但print_r对布尔型的输出不太明显;var_dump输出比较详细,一般调试时用得多。
    如下代码:
    复制代码 代码如下:

    $v = new test();
    print_r($v);
    var_dump($v);
    class test {
    public $num = 1;
    public $str = "222";
    public $bln = true;

    结果为:
    复制代码 代码如下:

    test Object
    (
    [num] => 1
    [str] => 222
    [bool] => 1
    )
    object(test)#1 (3) {
    ["num"]=>
    int(1)
    ["str"]=>
    string(3) "222"
    ["bool"]=>
    bool(true)
    }

    参考资料:
    PHP程序设计,2003,第四章 字符串,输出字符串

    php学习之数据类型之间的转换代码

    复制代码 代码如下:


    /*数据类型之间相互转换
    * 一种是强制转换
    * setType(变量,类型); //int,integer,float,double等等。
    * 这个函数将原变量的类型改变,用var_dump();可以查看变量
    *
    * 在赋值前使用(类型)的形式,不会改变原变量的类型
    * $a=(int)"123abc";
    *
    * $变量=intval(变量或值);
    * $变量=floatval(变量或值);
    * $变量=stringval(变量或值);
    *
    * 注意:整型在内存中占4个字节 2.147e9
    * 浮点型在内存中占8个字节
    *
    *
    * 一种是自动转换(最常用方式),变量会更具运行环境自动转换

    * 与变量和类型有关的一些常用函数
    * isset();//判断一个变量是否存在,值如果是null也表示空。
    * empty();//判断一个变量是否为空 "",null
    * unset();//删除一个变量
    * setType();//设置一个变量类型
    * getType();//获取一个变量类型 var_dump();获取类型和值
    *
    * 变量类型测试函数
    * is_bool();//判断是否为布尔型
    * is_int() is_integer() is_long()//判断是否是整型
    * is_float(), is_double() is_real()//...
    * is_array()
    * is_object()
    * is_resource()
    * is_null()
    * is_scalar()//判断是否是标量
    * is_numberic()//判断是否是任何一种数字,或数字字符串
    * is_callable()//判断是否是有效的函数名

    * 常量的声明与使用
    * 1.常量是一个简单值的标识符
    * 2.常量定义后不能再改变它的值,也不能使用unset()或其他的函数取消
    * 3.常量可以不用理会变量范围的规则而在任何地方都可以定义和访问
    * 4.常量使用define("常量名",值);
    * 5.常量名在声明和使用时都不使用"$"
    * 6.常量名称习惯都使用大写
    * 7.常量的值只能用标量类型(int,float,bool,string)
    * 8.常量一定要在声明时就给值
    * 9.defined("常量");//判断常量是否存在
    *
    * 预定义常量和魔术常量
    * echo __FILE__;//输出当前文件名称目录_魔术常量
    * echo CASE_LOWER;//输出固定的值_预定义常量
    *

    */
    //这个函数将原变量的类型改变,用var_dump();可以查看变量
    $str="100.12345abc";
    setType($str,int);
    var_dump($str);

    //在赋值前使用(类型)的形式
    $str="100.12345abc";
    $a=(int)$str;
    var_dump($a);//输出int(100)
    var_dump($str);//输出值不变,"100.12345abc"
    //如果字符串不是以数字开头,则转换成0

    //不同类型运算
    $a=10;
    $b="100abc";
    $c=true;
    $d=12.34;
    $sum=$a+$c;//布尔型自动转换成1,结果为11
    $sum=$a+$b;//结果为110
    $sum=$a+$b+$c;//结果为111
    $sum=$a+$b+$c+$d;//结果为123.34,因为浮点型内存空间大,小内存转大内存。

    //判断是否是数组
    $a=array("one","two",1,3,6,8);
    if(is_array($a)){
    print_r($a);//打印数组
    }else{
    echo $a;
    }

    //定义常量,使用常量
    define("home","this is a home");
    $a=100;
    function demo()
    {
    global $a;//因为$a是全局变量所以要用全局标记调用
    echo $a;
    echo home;//常量可以不用理会范围,直接访问或者定义
    }
    demo();

    //判断常量是否存在
    if(defined("home")
    {
    echo home;
    }
    else
    {
    define("home","this is a home");
    }

  • 相关阅读:
    win和linux简单排查思路
    应急响应概述
    S2-057复现
    七十二:内网安全-域横向CS&MSF联动及应急响应初始
    七十一:内网安全-域横向网络&传输&应用层隧道技术
    七十:内网安全-域横向内网漫游Socks代理隧道技术
    六十九:内网安全-域横向CobalStrike&SPN&RDP
    六十八:内网安全-域横向PTH&PTK&PTT哈希票据传递
    信息泄露漏洞详解
    文件上传漏洞详细解析
  • 原文地址:https://www.cnblogs.com/M-D-Luffy/p/3909281.html
Copyright © 2011-2022 走看看