打印

烦躁烦躁,sprintf函数结果不对

[复制链接]
1891|11
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
cjseng|  楼主 | 2018-8-5 16:10 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
沙发
xuyaqi| | 2018-8-5 16:22 | 只看该作者
怎么知道结果不对。

使用特权

评论回复
板凳
cjseng|  楼主 | 2018-8-5 17:18 | 只看该作者
xuyaqi 发表于 2018-8-5 16:22
怎么知道结果不对。

正确结果应该是:“ICON(155,59,8,1,9,1);”
可现在是:“ICON(155,59,8,1,12,0);”

使用特权

评论回复
地板
xuyaqi| | 2018-8-5 20:22 | 只看该作者
cjseng 发表于 2018-8-5 17:18
正确结果应该是:“ICON(155,59,8,1,9,1);”
可现在是:“ICON(155,59,8,1,12,0);”

你看的是SBUF数组的值吗?

使用特权

评论回复
5
xuyaqi| | 2018-8-5 21:37 | 只看该作者
本帖最后由 xuyaqi 于 2018-8-6 09:57 编辑

你选memory model:为compact 或者 large 编译就正常啦。 compact 或者 large 可以传递40个字节参数,small只有15个字节参数。

使用特权

评论回复
6
cjseng|  楼主 | 2018-8-6 15:24 | 只看该作者
本帖最后由 cjseng 于 2018-8-6 15:27 编辑
xuyaqi 发表于 2018-8-5 21:37
你选memory model:为compact 或者 large 编译就正常啦。 compact 或者 large 可以传递40个字节参数,small ...

你这个方法完全有效。
只是我没有扩展XDATA,不知道有没有影响。

使用特权

评论回复
7
xuyaqi| | 2018-8-6 16:02 | 只看该作者
cjseng 发表于 2018-8-6 15:24
你这个方法完全有效。
只是我没有扩展XDATA,不知道有没有影响。

那可以不用XDATA,用small分两次传。

使用特权

评论回复
8
linqing171| | 2018-8-6 21:29 | 只看该作者
int i=sprintf(sbuf,"ICON(%d,%d,%d,",x,y,pn);
sprintf(sbuf+i,",%d,%d,%d);",

使用特权

评论回复
9
linqing171| | 2018-8-6 21:57 | 只看该作者
printf
Summary#include <stdio.h>int printf (  const char *fmtstr       /* format string */  <[>, arguments ... <]>);   /* additional arguments */
DescriptionThe printf function formats a series of strings and numeric values and builds a string to write to the output stream using the putchar function. The fmtstr argument is a format string that may be composed of characters, escape sequences, and format specifications.
Ordinary characters and escape sequences are copied to the stream in the order in which they are interpreted. Format specifications always begin with a percent sign ('%') and require that additional arguments are included in the printf function call.
The format string is read from left to right. The first format specification encountered references the first argument after fmtstr and converts and outputs it using the format specification. The second format specification accesses the second argument after fmtstr, and so on. If there are more arguments than format specifications, extra arguments are ignored. Results are unpredictable if there are not enough arguments for the format specifications or if the argument types do not match those specified by fmtstr.
Format specifications have the following general format:
% <[>flags<]> <[>width<]> <[>.precision<]> <[>{b|B|l|L}<]> typeEach field in the format specification may be a single character or a number which specifies a particular format option.
The type field is a single character that specifies whether the argument is interpreted as a character, string, number, or pointer, as shown in the following table.
TypeArgument TypeInput Format
dintSigned decimal number.
uunsigned intUnsigned decimal number.
ounsigned intUnsigned octal number.
xunsigned intUnsigned hexadecimal number using "0123456789abcedf".
Xunsigned intUnsigned hexadecimal number using "0123456789ABCDEF".
ffloatFloating-point number formatted as
<[>-<]>dddd.dddd.
efloatFloating-point number formatted as
<[>-<]>d.dddde<[>-<]>dd.
EfloatFloating-point number formatted as
<[>-<]>d.ddddE<[>-<]>dd.
gfloatFloating-point number using either the e or f format, whichever is more compact for the specified value and precision.
GfloatFloating-point number using either the E or f format, whichever is more compact for the specified value and precision.
ccharA single character.
s*A string of characters terminated by a null character ('\0').
p*A generic pointer formatted as t:aaaa where t is the memory type and aaaa is the hexadecimal address.
Note
  • The optional characters l or L may immediately precede the type character to respectively specify long types for d, i, u, o, x, and X.
  • The optional characters b or B may immediately precede the type character to respectively specify char types for d, i, u, o, x, and X.
Characters following a percent sign that are not recognized as a format specification are treated as ordinary characters. For example, "%%" writes a single percent sign to the output stream.
The flags field is a single character used to justify the output and to print +/- signs and blanks, decimal points, and octal and hexadecimal prefixes, as shown in the following table.
FlagDescription
-Left justify the output in the specified field width.
+Prefix the output value with a + or - sign if the output is a signed type.
blank (' ')Prefix the output value with a blank if it is a signed positive value. Otherwise, no blank is prefixed.
#Prefixes a non-zero output value with 0, 0x, or 0X when used with o, x, and X field types, respectively.

When used with the e, E, f, g, and G field types, the # flag forces the output value to include a decimal point.

The # flag is ignored in all other cases.
The width field is a non-negative number that specifies the minimum number of characters printed. If the number of characters in the output value is less than width, blanks are added on the left (by default) or right (when the - flag is specified) to pad to the minimum width. If width is prefixed with a '0', zeros are padded instead of blanks. The width field never truncates the output. If the length of the output value exceeds the specified width, all characters are output.
The width field may be an asterisk ('*'), in which case an int argument from the argument list provides the width value. Specifying a 'b' in front of the asterisk specifies that the argument is an unsigned char.
The precision field is a non-negative number that specifies the number of characters to print, the number of significant digits, or the number of decimal places. The precision field can cause truncation or rounding of the output value in the case of a floating-point number as specified in the following table.
TypePrecision Field Meaning
d,u,o,x,XThe precision field specifies the minimum number of digits that are included in the output value. Digits are not truncated if the number of digits in the argument exceeds that defined in the precision field. If the number of digits in the argument is less than the precision field, the output value is padded on the left with zeros.
fThe precision field specifies the number of digits to the right of the decimal point. The last digit is rounded.
e,EThe precision field specifies the number of digits to the right of the decimal point. The last digit is rounded.
g,GThe precision field specifies the maximum number of significant digits in the output value.
sThe precision field specifies the maximum number of characters in the output value. Excess characters are not output.
c,pThe precision field has no effect on these field types.
The precision field may be an asterisk ('*'), in which case an int argument from the argument list provides the value. Specifying a 'b' in front of the asterisk specifies that the argument is an unsigned char.
Note
  • You must ensure that the argument type matches that of the format specification. You may use type casts to ensure that the proper type is passed to printf.
  • This function is implementation-specific and is based on the operation of the _getkey and putchar functions. These functions, as provided in the standard library, read and write characters using the microcontroller's serial port. Custom functions may use other I/O devices.
  • The total number of bytes that may be passed to this function is limited due to the memory restrictions imposed by the 8051. A maximum of 15 bytes may be passed in SMALL or COMPACT model. A maximum of 40 bytes may be passed in LARGE model.
Return ValueThe printf function returns the number of characters actually written to the output stream.
See Alsogets, printf517, puts, scanf, scanf517, sprintf, sprintf517, sscanf, sscanf517, vprintf, vsprintf
Example#include <stdio.h>void tst_printf (void) {  char a = 1;  int b  = 12365;  long c = 0x7FFFFFFF;  unsigned char x = 'A';  unsigned int y  = 54321;  unsigned long z = 0x4A6F6E00;  float f = 10.0;  float g = 22.95;  char buf [] = "Test String";  char *p = buf;  printf ("char %bd int %d long %ld\n",a,b,c);  printf ("Uchar %bu Uint %u Ulong %lu\n",x,y,z);  printf ("xchar %bx xint %x xlong %lx\n",x,y,z);  printf ("String %s is at address %p\n",buf,p);  printf ("%f != %g\n", f, g);  printf ("%*f != %*g\n", (int)8, f, (int)8, g);}
Copyright © Keil, An ARM Company. All rights reserved.

使用特权

评论回复
10
jackyid| | 2018-8-7 14:45 | 只看该作者
sbuf 定义时最好初始化为0
从c角度,看不出错误

使用特权

评论回复
11
cjseng|  楼主 | 2018-8-7 14:48 | 只看该作者
jackyid 发表于 2018-8-7 14:45
sbuf 定义时最好初始化为0
从c角度,看不出错误

我在STM32里这样用,一点儿问题也没有,用在51上就出错了。我试过了,用在51上,在small模式下,传递4个变量就没问题。

使用特权

评论回复
12
jackyid| | 2018-8-14 14:19 | 只看该作者
cjseng 发表于 2018-8-7 14:48
我在STM32里这样用,一点儿问题也没有,用在51上就出错了。我试过了,用在51上,在small模式下,传递4个 ...

没玩过51,只会纯C

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

63

主题

4242

帖子

46

粉丝