3

这是我正在处理的代码的一部分:

void update_log(char *name, pthread_t ID, char *status, char *update)
{
    time(&rawtime);
    time_str = asctime(localtime(&rawtime));
    time_str[strlen(time_str) - 1] = 0;
    fprintf(log_file, "[%s]  [%12s]  [%u]  [%s]  %s\n", time_str, name, (unsigned int)ID, status, update);
}  

输出是:

[Sat Mar  9 21:36:20 2013]  [        main]  [197777152]  [OK]  ******
[Sat Mar  9 21:36:20 2013]  [update_table]  [172680960]  [OK]  **********
[Sat Mar  9 21:36:22 2013]  [update_table]  [172680960]  [OK]  ******
[Sat Mar  9 21:36:25 2013]  [        main]  [197777152]  [OK]  ****************

有没有办法让name变量的输出看起来像这样(所以它仍然需要 12 个块并且仍然在括号中):

[Sat Mar  9 21:36:20 2013]  [main]          [197777152]  [OK]  ******
[Sat Mar  9 21:36:20 2013]  [update_table]  [172680960]  [OK]  **********
[Sat Mar  9 21:36:22 2013]  [update_table]  [172680960]  [OK]  ******
[Sat Mar  9 21:36:25 2013]  [main]          [197777152]  [OK]  ****************

我正在考虑在fprintf()函数之前为名称变量添加括号,但是在 C 中是否有一种简单的方法可以在字符串的开头添加一个字符?

谢谢。

4

3 回答 3

3

这对我来说似乎很容易。

#include <stdio.h>

int main()
{
    char buffer[16];

    sprintf(buffer,"[%s]", "main");
    printf("[0] %-14s [2]\n", buffer);

    sprintf(buffer,"[%s]", "update_table");
    printf("[0] %-14s [2]\n", buffer);

    sprintf(buffer,"[%s]", "main");
    printf("[0] %-14s [2]\n", buffer);

    return 0;
}

输出

[0] [main]         [2]
[0] [update_table] [2]
[0] [main]         [2]
于 2013-03-10T06:51:53.323 回答
2

您可以先将括号添加到名称变量的开头和结尾,然后%12s像您所做的那样打印名称,但左对齐而不是右对齐(这是默认值)

您可以使用 strcat 在开头和结尾添加括号。请参阅: 如何在 C 中连接 const/literal 字符串?

此链接显示如何左对齐:(参见标志表) http://www.cplusplus.com/reference/cstdio/printf/

于 2013-03-10T06:55:02.953 回答
1

我没有看到任何简单的方法,但是您可以从中制作另一个字符串:

void update_log(char *name, pthread_t ID, char *status, char *update)
{
    time(&rawtime);
    time_str = asctime(localtime(&rawtime));
    time_str[strlen(time_str) - 1] = 0;

    size_t len = strlen(name);
    char real_name[len + 3];
    real_name[0] = '[';
    strncpy(real_name + 1, name, sizeof(real_name));
    real_name[len + 1] = ']';
    real_name[len + 2] = 0;

    fprintf(log_file, "[%s]  [%12s]  [%u]  [%s]  %s\n", time_str, real_name, (unsigned int)ID, status, update);
}
于 2013-03-10T06:51:15.837 回答