3

我想以这种形式显示一个字符串:"in 3 days 00:15:07" or "in 00:15:07" in case days is 0

所以我写了一些代码如下

#include<stdio.h>

#define LEASE_TIME_USING_DAYS "in %d days %c%d:%c%d:%c%d\n"
#define LEASE_TIME_NOTUSING_DAYS "in %c%d:%c%d:%c%d\n"

int main(){
    int seconds, minutes, hours, days;
    char *leasetime;

    /* Just for test */
    seconds = 7;
    minutes = 15,
    hours = 0;
    days = 3;
    /*End just for test*/

    char prefixseconds, prefixminutes, prefixhours;
    if(seconds<10) prefixseconds=48; else prefixseconds=0;
    if(minutes<10) prefixminutes=48; else prefixminutes=0;
    if(hours<10) prefixhours=48; else prefixhours=0;
    if(days>0) asprintf(&leasetime,LEASE_TIME_USING_DAYS, days, prefixhours, hours, prefixminutes, minutes, prefixseconds, seconds);
    else asprintf(&leasetime,LEASE_TIME_NOTUSING_DAYS, prefixhours, hours, prefixminutes, minutes, prefixseconds, seconds);

    printf("lease time = %s\n", leasetime);
    printf(LEASE_TIME_USING_DAYS, days, prefixhours, hours, prefixminutes, minutes, prefixseconds, seconds);
}

我在控制台中得到这个输出:

lease time = in 3 days 00:
in 3 days 00:15:07

我不知道为什么创建的带有 asprintf 的字符串(第一个显示消息)会以这种方式显示。我希望它像第二条显示消息的结果。

有谁知道我哪里出错了?

4

1 回答 1

2

如果您更改secondshours大于 10,您会看到问题仍然存在。

When prefixhoursis 0 您尝试将其打印为字符 ( %c) 但这不会发生,因为 0 被视为字符串的空终止符。

结果,根据您在字符串中注入的零,字符串会被终止(在它打印出您期望的内容之前)。


@RustyX 的解决方案是这样做:

if(seconds<10) prefixseconds=48; else prefixseconds='0';
if(minutes<10) prefixminutes=48; else prefixminutes='0';
if(hours<10) prefixhours=48; else prefixhours='0';

而不是你现在所做的(这样空终止符就不会被注入到字符串中)。请注意,您应该将数据类型保留为问题中变量的数据类型)。


正如@xing 提到的:

改变这个:

%c%d:%c%d:%c%d

对此:

%02d:%02d:%02d

你会没事的,这样做:

asprintf(&leasetime,LEASE_TIME_USING_DAYS, days, hours, minutes, seconds);

02确保您将获得所需的填充。

于 2017-08-26T11:22:24.587 回答