联盟返回类型C

Duc*_*ong 2 c

在以下代码中,字符串"12345678901234567890"无法完全复制到union-type变量.这让我真的很困惑?

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <time.h>

typedef union
{
    int i;
    long l;
    float f;
    double d;
    void *v;
    char *s;
    char c;
 } UType;

UType NewUType_s(char *s)
{
     UType temp;
     strcpy(temp.s, s);      // If we print temp.s and s here, both of them are "12345678901234567890
     return temp;
}

int main()
{
    UType m;
    m = NewUType_s("12345678901234567890");
    printf("%s\n", m.s);

    return 0;
 }
Run Code Online (Sandbox Code Playgroud)

结果是:1234567890123456和一些特殊字符?

这个问题的解决方案可能是:

  • 解决方案1:malloc()用于m;

  • 解决方案2:将NewUType_s样式更改为指针功能UType *NewUType_s(char *s);,一切正常,

但是,有人知道上述程序没有正确结果的原因吗?

das*_*ght 5

这段代码的问题在于,写入未初始化的指针是未定义的行为:temp.s尚未分配一个可以复制字符串的内存块,因此strcpy写入您的程序不拥有的内存.

修复此代码非常简单:在复制之前分配内存,如下所示:

UType NewUType_s(char *s)
{
     UType temp;
     temp.s = malloc(strlen(s)+1);
     strcpy(temp.s, s);
     return temp;
}
Run Code Online (Sandbox Code Playgroud)

当然你需要free内存来避免内存泄漏.

  • @hyde:`strdup`是非标准的(它由POSIX定义,但不是由ISO C定义). (3认同)