writef和printf函数的学习程序

和C函数的格式相同。

只是printf和writef中的 s 意思不一样

不知道C语言中是否有用 * 号来表示宽度和精度。
D语言中,可以用*号来表示。它需要对应个数字,像 %d一样要对应一个数字。

("%*d", 5, 1) 相当于 ("%5d", 1) 表示宽度
("%.*d", 5, 1) 相当于 ("%.5d", 1) 表示精度

正好,char[] 表示的是长度和字符串。
和 %*s %.*s 吻合
所以可以用在printf函数中表示D语言的一个char[] 类型
不知道这2种形式有没有啥区别,但只是都能正常显示。

附上代码:

[code]
import std.stdio;
import std.string;
import std.c.string;

class A
{
}

void main()
{
char[] str;

str = "abcde";

str ~= "\0";
printf("string(%d) '%s'\n", strlen(cast(char*)str), cast(char*)str);
writefln("string(%d) :%s", str.length, str);

str = "edcba";
printf("string(%d) '%s'\n", strlen(cast(char*)str), toStringz(str));
writefln("string(%d) :%s", str.length, str);
writefln("%s", str);

// 区别
printf("the string is '%.*s'\n", "aaaaaaaaaaaaa我");
printf("the string is '%*s'\n", "aaaaaaaaaaaaa我");

int a = 456;
printf("d: %d %05d %+d |%-5d| |%5d| |% d| |% d|"\n, a, a, a, a, a, a, -a); // 十进制
writef("d: %d %05d %+d |%-5d| |%5d| |% d| |% d|"\n, a, a, a, a, a, a, -a); // 十进制
printf("*: |%*d| |%-*d| |%.*d| |%*.d|"\n, 5, a, 5, a, 5, a, 5, a);
writef("*: |%*d| |%-*d| |%.*d| |%*.d|"\n, 5, a, 5, a, 5, a, 5, a);

printf("u: %u %05u %+u |%-5u| |%5u|"\n, a, a, a, a, a); // 十进制无符号
//writef("u: %u %05u %+u |%-5u| |%5u|"\n, a, a, a, a, a); // 十进制无符号
//
printf("o: %o %#o"\n, a, a); // 八进制
writef("o: %o %#o"\n, a, a); // 八进制

printf("x: %X %x %#x %#X %05x |%-5x|"\n, a, a, a, a, a, a); // 十六进制
writef("x: %X %x %#x %#X %05x |%-5x|"\n, a, a, a, a, a, a); // 十六进制

float f = 2.1, f2 = 2222222, f3 = 0.1111111111;
printf("f: %f |%.3f| |%5f| |%3.5f| |%5.3f|"\n, f, f2, f3, f, f); // 浮点数
writef("f: %f |%.3f| |%5f| |%3.5f| |%5.3f|"\n, f, f2, f3, f, f); // 浮点数

float e = 2.1, e2 = 2222222, e3 = 0.1111111111;
printf("e: %e |%.3e| |%5e| |%3.5e| |%5.3e|"\n, e, e2, e3, e, e); // 指数
writef("e: %e |%.3e| |%5e| |%3.5e| |%5.3e|"\n, e, e2, e3, e, e); // 指数

printf("g: %g |%.3g| |%5g| |%3.5g| |%5.3g|"\n, e, e2, e3, e, e); // 十六进制
writef("g: %g |%.3g| |%5g| |%3.5g| |%5.3g|"\n, e, e2, e3, e, e); // 十六进制

printf("a: %a |%.3a| |%5a| |%3.5a| |%5.3a|"\n, e, e2, e3, e, e); // 不懂
writef("a: %a |%.3a| |%5a| |%3.5a| |%5.3a|"\n, e, e2, e3, e, e); // 不懂

// * 号作为宽度标志和精度标志
printf("*: |%*f| |%-*f| |%.*f| |%*.f| |%*.*f|"\n, 5, e, 5, e, 5, e, 5, e, 8, 3, e);
writef("*: |%*f| |%-*f| |%.*f| |%*.f| |%*.*f|"\n, 5, e, 5, e, 5, e, 5, e, 8, 3, e);

A aa = new A;
int[] ab = [1, 2, 3];
writef("s: %s %s %s %s %s %s", true, -10, -2.0001, "abc", aa, ab);

}

[/code]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在STM32L431RCT6中,可以通过重定向printf函数来将输出重定向到USART串口。具体步骤如下: 1. 在usart.c文件的/* USER CODE BEGIN 1 */部分添加重定向代码,并包含<stdio.h>头文件。 2. 在usart.c和main.c文件中添加#include "stdio.h"头文件。 3. 实现重定向的函数fputc或__io_putchar,这个函数将字符发送到USART。可以使用HAL_UART_Transmit函数来发送字符。 4. 在重定向函数中,调用HAL_UART_Transmit函数将字符发送到USART。 5. 返回发送的字符。 下面是一个示例代码片段,用于在STM32L431RCT6上实现重定向printf函数到USART1: /* USER CODE BEGIN 1 */ #ifdef __GNUC__ /* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf set to 'Yes') calls __io_putchar() */ #define PUTCHAR_PROTOTYPE int __io_putchar(int ch) #else #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f) #endif /* __GNUC__ */ PUTCHAR_PROTOTYPE { /* Place your implementation of fputc here */ /* e.g. write a character to the USART1 and Loop until the end of transmission */ HAL_UART_Transmit(&huart1, (uint8_t *)&ch, 1, 0xFFFF); return ch; } /* USER CODE END 1 */ 然后,你可以在代码中使用printf函数来将输出重定向到USART1串口。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [STM32L431RCT6的串口通信(重定向实现printf打印功能)](https://blog.csdn.net/weixin_53331739/article/details/131349893)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值