发布网友 发布时间:2024-10-24 06:39
共5个回答
热心网友 时间:2024-11-06 19:11
printf("%d",0XA8) 是输出地址为0XA8对应的二进制到int型所占内存大小(一般为2字节)的一块内存区域中所存储的值。所以如果未初始化这段地址单元,只会输出随机数
printf("%s",'\\') 如果你只要输出一段字符串,就用printf("\\"). 格式化输出会输出对应的变量的内容,如果你一定要用格式化输出,就先把'\\'赋给字符串,再输出,但有点多余。
至于为什么只输出一个\,是因为C里面\是一个转义字符。你可以查一下转义字符的意思就知道了。
热心网友 时间:2024-11-06 19:13
关于printf的用法:
1 一般格式
printf(格式控制,输出表列)
例如:printf("i=%d,ch=%c\n",i,ch);
说明:
(1)“格式控制”是用双撇号括起来的字符串,也称“转换控制字符串”,它包括两种信息:
①格式说明:由“%”和格式字符组成,它的作用是将输出的数据转换
为指定的格式输出。
②普通字符,即需要原样输出的字符。
(2)“输出表列”是需要输出的一些数据,可以是表达式
(3) printf函数的一般形式可以表示为
printf(参数1,参数2,……,参数n)
功能是将参数2~参数n按参数1给定的格式输出
2 格式字符(9种)
(1)d格式符。用来输出十进制整数,有以下几种用法:
①%d,按整型数据的实际长度输出。
②%md,m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。
③%ld(%mld 也可),输出长整型数据。
例如:long a="123456";
printf("%ld",a);
( 2)o格式符,以八进制数形式输出整数。格式:%o,%mo,%lo,%mlo都可。
(3)x格式符,以十六进制数形式输出整数。格式:%x,%mx,%lx,%mlx都可。
(4)u格式符,用来输出unsigned型数据,即无符号数,以十进制数形式输出。格式:%u,%mu,%lu都可。
(5)c格式符,用来输出一个字符。格式:%c,%mc都可。
(6)s格式符,用来输出一个字符串。格式:%s,%ms,%-ms,%m.ns,%-m.ns都可。
(7)f格式符,用来输出实数(包括单、双精度),以小数形式输出。格式:%f,%m.nf,%-m.nf都可。
注意:单精度实数的有效位数一般为7位,双精度为16位。
(8)e格式符,以指数形式输出实数。格式:%e,%m.ne,%-m.ne都可。
(9)g格式符,用来输出实数,它根据数值的大小,自动选f格式或e格式(选择输出时占宽度较小的一种)。
3 说明
(1)除了X、E、G(用大写字母表示)外,其他格式字符必须用小写字母;
(2)“格式控制”字符串内可以包含转义字符;
(3)如果想输出字符“%”,则应该在“格式控制”字符串中用连续两个%表示,
如:
printf("%f%%",1.0/3);
prinf("%d" , 0XA8); 这里的0XA8是一个十六进制表示的地址,输出的是内存在这个地址存放的数据。
printf("%s", '\\'); \\位置要输入字符串的地址,而 '\\' 是字符常量。
热心网友 时间:2024-11-06 19:14
prinf("%d" , 0XA8); 这里的0XA8是一个十六进制表示的地址,内存在这个地方放了什么东西,谁也不知道,所以它会输出一个很大很奇怪的数字
而printf("%s", '\\'); 为什么是错的,因为后面的'\\'应该填入的是一个字符串的地址,你直接写上字符串,系统当然无法正确输出啊,要输出\\ 直接printf("\\\\");就ok了...
热心网友 时间:2024-11-06 19:12
0xA8是16进制数是10*16+8=168;\\加单引号是字符常量,%s是字符串
热心网友 时间:2024-11-06 19:09
第一个
ox 是十六进制 在十六进制中A是10 因此输出(10乘以16的一次方)+(8乘以16的零次方)=168
第二个
printf("%s",'\\');
你的意思应该是输出( \ ) 但是 %s 的意思是输出字符串 应该是
printf("%c",'\\');