将 CHAR16 变量添加到字符串

Adding CHAR16 variable to String

我是C语言新手,正在尝试修改和编译一个EDK2 EFI程序。

我要更改的程序部分有一个函数 MsgLog,它接受一个 Char16 * 变量并使用它写入日志文件。

当前代码有这个

MsgLog("SomeText ...%r\n", Status);

状态是一个 EFI_STATUS,可以是“成功”或“未找到”。即,您可以在日志文件中获得以下内容:

SomeText ...Success

SomeText ...Not Found

我想将其更改为:

SomeText ...Success : ABC

SomeText ...Not Found : XYZ

我已经将 : ABC : XYZ 加载到 Char16 * 变量中(必须是 Char16 * 以匹配用于设置它的函数的其他限制)

然后我尝试了各种选项将其附加到字符串中,例如

MsgLog("SomeText ...%r%s\n", Status, myVariable);

MsgLog("SomeText ...%r%r\n", Status, myVariable);

但我最终得到了

SomeText ...Success<null string>

SomeText ...Not Found<null string>

我不确定我应该使用什么格式占位符,或者我是否应该或如何将 myVariable 转换为其他一些合适的格式,希望得到一些指导。

请注意,这是一个更广泛的程序,我正在更改其中的一小部分,我没有定义不同变量类型的范围。

编辑:添加了上下文

原始工作代码

EFI_STATUS Funct_A()
{
    EFI_STATUS Status;

    //Funct_B returns EFI_SUCCESS or EFI_NOT_FOUND
    Status = Funct_B();

    MsgLog("SomeText ...%r\n", Status);

问题代码

EFI_STATUS Funct_A()
{
    EFI_STATUS Status;
    CHAR16     *myVariable = NULL;

    //Funct_B returns EFI_SUCCESS or EFI_NOT_FOUND
    Status = Funct_B();


    // From some header file, I see "#define SPrint UnicodeSPrint". Not 100% sure it is the relevant one
    // From other code implementations, I know SPrint takes "CHAR16" as first variable. 
    if (!EFI_ERROR (Status)) {
        SPrint (myVariable,  255, L" : ABC");
    } else {
        SPrint (myVariable,  255, L" : XYZ");
    }

    MsgLog("SomeText ...%r%r\n", Status, myVariable);
    // MsgLog is a bit of a rabbit's warren and I can't provide all the background but it expects "CHAR16".

SPrint (myVariable, 255, L" : ABC"); 是错误的。 myVariableNULL - 您不能写入 NULL 指针。如果要使用 SPrint,则必须实际为字符串分配内存。有关详细信息,请查看您对指针和 snprintf 标准 C 函数的了解。 SPrint 的第二个参数实际上是分配内存的大小——你没有分配内存,所以 255 只是无效的。

CHAR16 myVariable[255];
SPrint(myVariable, sizeof(myVariable), L" : ABC");

但在你的情况下,这没有意义。首先,不需要使用 SPrint - 你不使用格式化字符串。一个简单的 StrCpy(即标准 wcscpy/strcpy 的替代方案)就足够了。但是也就是说,您根本不需要任何内存,只需使用指向字符串文字的指针即可。

const CHAR16 *myVariable = NULL;
if (!EFI_ERROR (Status)) {
    myVariable = L" : ABC";
} else {
    myVariable = L" : XYZ";
}
// or simpler
myVariable = !EFI_ERROR (Status) ? L" : ABC" : L" : XYZ";