二个参数:格式化字符串上。
((((和 都使用格式化字符串来指定串的格式,在格式串内部使用一些以
“17开头的格式说明符(8)来占据一个位置,在后边的变参列
表中提供相应的变量,最终函数就会用相应位置的变量来替代那个说明符,产生一个
调用者想要的字符串。格式化数字字符串 最常见的应用之一莫过于把整数打
印到字符串中,所以,在大多数场合可以替代 。如:
99把整数 123打印成一个字符串保存在 中。
.1".:99产生.:.
可以指定宽度,不足的左边补空格:
.1,"1,".:;<=99产生:.:;<=.
当然也可以左对齐:
.1,"1,".:;<=99产生:.:;<=.
也可以按照 进制打印:
.1,.;<=99小写 进制,宽度占 ,个位置,右对齐
.1,>.;<,99大写 进制,宽度占 ,个位置,左对齐
(((((这样,一个整数的 进制字符串就很容易得到,但我们在打印 进制内容时,
通常想要一种左边补 的等宽格式,那该怎么做呢?很简单,在表示宽度的数字前面
加个 就可以了。
.1,>.;<=99产生:.?=.
(((((上面以”1"7进行的 进制打印同样也可以使用这种左边补 的方式。
(((((这里要注意一个符号扩展的问题:比如,假如我们想打印短整数()的
内存 进制表示形式,在 @:平台上,一个 型占 个字节,所以我们自
然希望用 ;个 进制数字来打印它:
(((((A
((((.1;>.
((((产生“BBBBBBBB7,怎么回事?因为 是个变参函数,除了前面两个参数之
外,后面的参数都不是类型安全的,函数更没有办法仅仅通过一个“1>7就能得知当初
函数调用前参数压栈
时被压进来的到底是个 ;字节的整数还是个 字节的短整数,所以采取了统一 ;字节
的处理方式,导致参数压栈时做了符号扩展,扩展成了 :位的整数,打印时 ;个
位置不够了,就把 :位整数的 ,位 进制都打印出来了。如果你想看 的本来
面目,那么就应该让编译器做 扩展而不是符号扩展(扩展时二进制左边补 而不是
补符号位):
.1;>."
评论0
最新资源