一、printf()
printf()函数优点在于可以格式化输出!
printf()是一个函数,输出字符串,而print是一个语言结构,总是返回true(1),而echo也是语言结构,返回无效。
$total = 12.4
如果用echo时,是这样:
echo “Total amount is $total.”;
输出:Total amount is 12.4.
换回printf则为这样表达:
printf(“Total amount is %s.”,$total);
输出:Total amount is 12.4.
可以看出%s用变量$total代替。
事实上,printf()的表达式是这样:
string sprintf ( string $format [, mixed $args [, mixed $… ]] )函数里面第一参数是格式化字符串,里面可以有n个%(转换说明),每个转换说明将按顺序被一个个重新格式化的参数代替,%后面至少带一参量–type(类型码),表示一定含义,请看参量表:
类型码 含义
b 解释为整数并作为二进制输出
c 解释为整数并作为字符表示输出(ASCII码)
d 解释为整数并作为整数输出
e 解释为浮点数输出
f 解释为双精度并作为浮点数输出
o 解释为整数并作为八进制数输出
s 解释为字符串并为字符串输出
u 解释为无符号整数输出
g 解释自动选择合适的表示法
p 解释为指针的值
x 解释为整数并作为带有小写字母a-f的十六进制数输出
X 解释为整数并作为带有大写字母A-F的十六进制数输出
例子1:
$n = 43951789;
$u = -43951789;
$c = 65; // ASCII 65 is ‘A’
printf(“%%b = ‘%b’\n”, $n); // %b = ‘10100111101010011010101101’,二进制输出
printf(“%%c = ‘%c’\n”, $c); // %c = ‘A’,作为ascii字符输出, 与chr()函数一样
printf(“%%d = ‘%d’\n”, $n); // %d = ‘43951789’,整数
printf(“%%e = ‘%e’\n”, $n); // %e = ‘4.39518e+7’,科学记数法
printf(“%%u = ‘%u’\n”, $n); // %u = ‘43951789’,无符号数,正 *(下面说明有符号、无符号数)
printf(“%%u = ‘%u’\n”, $u); // %u = ‘4251015507’,无符号数,负
printf(“%%f = ‘%f’\n”, $n); // %f = ‘43951789.000000’,双精度浮点数
printf(“%%o = ‘%o’\n”, $n); // %o = ‘247523255’,八进制
printf(“%%s = ‘%s’\n”, $n); // %s = ‘43951789’,字符串
printf(“%%x = ‘%x’\n”, $n); // %x = ’29ea6ad’,十六进制,小写字母
printf(“%%X = ‘%X’\n”, $n); // %X = ’29EA6AD’,十六进制,大写字母
printf(“%%+d = ‘%+d’\n”, $n); // %+d = ‘+43951789’,在一个正整数上作+
printf(“%%+d = ‘%+d’\n”, $u); // %+d = ‘-43951789’,在一个负整数上作+
每个转换说明遵守同样的格式,如下:
%[‘padding_character][-][width][.precision]type所有的转换说明都是以%开始,如果想打印一个%符号,必须用%%。
参数’padding_character(填充字符)是可选,它将被用来填充变量直至所指定的宽度,该参数的作用就在变量前面填充,.默认的填充字符是一个空格,如果指定0或者空格,就不需要 ‘单引号作为前缀,其他字符就必须指定 ‘ 作为前缀。
参数 – 是可选,它指左对齐,默认是右对齐。
参数width是指被替换的变量的长度。
参数precision表示以小数点开始,它指明小数点后要显示的位数。
说明:
(1). 可以在”%”和字母之间插进数字表示最大宽度。
①例如: %3d 表示输出3位整型数, 不够3位右对齐。
②%9.2f 表示输出宽度为9的浮点数, 其中小数位为2, 整数位为6, 小数点占一位, 不够9位右对齐。
③%8s 表示输出8个字符的字符串, 不够8个字符右对齐。
④如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。
⑤浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出;
⑥小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。
⑦若想在输出值前加一些0, 就应在场宽项前加个0。
例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度为4位。
⑧如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度, 小数点前的数字代表最小宽度。
例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。
(2). 可以在”%”和字母之间加小写字母l, 表示输出的是长型数。
①例如: %ld 表示输出long整数
②%lf 表示输出double浮点数
(3). 可以控制输出左对齐或右对齐, 即在”%”和字母之间加入一个”-” 号可说明输出为左对齐, 否则为右对齐。
①例如: %-7d 表示输出7位整数左对齐
②%-10s 表示输出10个字符左对齐
(4). 一些特殊规定字符
①\n 换行
②\f 清屏并换页
③\r 回车
④\t Tab符
⑤\xhh 表示一个ASCII码用16进表示,
其中hh是1到2个16进制数
例子2:
$year = 2011;
$month = 3;
$day = 15;
$isodate = sprintf(“%04d-%02d-%02d”, $year, $month, $day); //#1,%04d表示四位整数,如果变量不够四位,左边的空位(原始数字右对齐)将用0代替。echo $isodate;
输出:2011-03-15,
#1
的地方可以改为:$isodate = sprintf(“%’15d-%02d-%02d”, $year, $month, $day);
//%’15d表示五位整数,不够倍数用1这个符号代替,输出:12011-03-15(因为2011不够五位)。还可以改成:$isodate =
sprintf(“%’1-6d-%02d-%02d”, $year, $month, $day);
//%’1-6d表示6位数,不够的右空位1代替(原始四位数左对齐),输出:201111-03-15。
例子3:
$total = 201.1;
$myint = 201.44651;
$string = ‘i love you!’;
printf(“Total amount is %6.2f”,$total); //输出:Total amount is 201.10,小数点两位,不够位数右对齐,用默认空格代替空位。
printf(“Total amount is %7.2f”,$total); // Total amount is 201.10,不够位数,在浮点型中按实际数字输出。
printf(“Myint is %1.2f”,$myint); // Myint is 201.45,保留两位小数,四舍五入最小数点最后一位,整数部份最少一位,按实际输出。
printf(“The strings is %1.2s”,$total); // The strings is 20,1.2表示输出长度最小为1,最多为了2。
printf(“The strings is %3.5s”,$string); // The strings is i lov,输出字数为3。
例子4:
$s = ‘monkey’;
$t = ‘many monkeys’;
printf(“[%s]\n”, $s); // [monkey],按实际输出
printf(“[%10s]\n”, $s); // [ monkey],原字符串右对齐,左边不够位数用空格填
printf(“[%-10s]\n”, $s); // [monkey ],加’-‘,左对齐,右位不够位数用空格填
printf(“[%010s]\n”, $s); // [0000monkey],右对齐,不够位数在字符串中用0填
printf(“[%’#10s]\n”, $s); // [####monkey],用特别字符填不足位
printf(“[%10.10s]\n”, $t); // 输出字数为10,把多余字截掉
二、sprintf()string sprintf ( string format [, mixed args [, mixed …]] )
Returns a string produced according to the formatting string format .
跟printf相似,但不打印,而是返回格式化后的文字,其他的与printf一样。
三、vprintf()输出格式化字符串
int vprintf ( string $format , array $args )
根据 format (sprintf() 函数文档中有相关描述)参数指定的格式,在一个格式化字符串中显示多个值。
作用与 printf() 函数类似,但是接收一个数组参数,而不是一系列可变数量的参数。
vprintf(“%04d-%02d-%02d”, explode(‘-‘, ‘1988-8-1’)); // 1988-08-01
四、vsprintf()返回格式化字符串
string vsprintf ( string $format , array $args )
作用与 sprintf() 函数类似,但是接收一个数组参数,而不是一系列可变数量的参数。
根据 format (sprintf() 函数文档中有相关描述)参数指定的格式,在一个字符串中返回一系列值。
print vsprintf(“%04d-%02d-%02d”, explode(‘-‘, ‘1988-8-1’)); // 1988-08-01
*五、有符号数|无符号数在C/C++里面不同类的数据是不能比较的,要从低级类型转换为高级类型 。
比如char 和 int 比较 要转换为int ,
比如int 和float 比较 要转换为float ,
关于有符号数和无符号数 机器中表示数都用二进制表示。二进制的最高位表示符号:1为负,0为正,而无符号数则不存在符号位-1的最高为1 ,而5的最高为0,比较大小时候转换为无符号数,所以转换后-1大于5。
main( ){
unsigned a=32768;
printf(“a=%d\n”,a);
}
答案是 a=-32768。
首先,unsigned是表示一个变量(或常数)是无符号类型。signed表示有符号。
unsigned & signed I
无符号数的数值范围0-65535,有符号数的数值范围在-32768- +32767之间.所以有符号运算比无符号运算耗资源。? 无符号数32768的二进制形式为1000 0000 0000 0000。
在转换为有符号数时。由于最高位表示符号数,因此可以理解其为一个负数。负数采用2的补码(two’s complement)表示。“要把内存中以补码形式存放的二进制码转换成十进制的负数步骤如下:
1.先对各位取反
2.将所得的二进制数转换成十进制数
3.因为最高位为1,因此在所得的十进制数前面加负号
4.对所求得的数再减1,即可
?按照上面的步骤:各位先取反,0111 1111 1111 1111 ;再转为十进制数,32767;再在所得的数前加负号,-32767;再减1,即为-32767-1=-32768.。
unsigned & signed Ⅱ
main(){
int b=-2;
printf(“b=%u”,b);
}
答案是b=65534。
其具体步骤为:
先取-2的绝对值2的原码:0000 0000 0000 0010
将其转换为反码:1111 1111 1111 1101
加1补码:1111 1111 1111 1110
十进制形式就是无符号数:65534