它没有编译,我不确切地知道我做错了什么。当我尝试做的时候:
(ultimo->siguiente)=nnodo;
编译器不允许我。两者都不起作用:
scanf("%d", &(nnodo->dni));
PD:baja和modif函数仍未完成,但它们不应与主程序发生任何冲突。
编译器输出(Visual Studio 2010):
错误2错误C2037:'siguiente'左边指定未定义的struct / union'str'c:\ documents和settings \ emiliano \ desktop \ asdc.c 52 1 abm
错误3错误C2037:'dni'左边指定未定义的struct / union'str'c:\ documents和settings \ emiliano \ desktop \ asdc.c 55 1 abm
4 IntelliSense:不允许指向不完整类类型的指针c:\ documents and settings \ emiliano \ desktop \ asdc.c 52 3 abm
5 IntelliSense:不允许指向不完整类类型的指针c:\ documents and settings \ emiliano \ desktop \ asdc.c 55 15 abm
我想我正确地做了typedef,但我真的不知道。
#include <stdio.h>
#include <stdlib.h>
typedef struct stru* pstru;
typedef struct{
int dni;
pstru siguiente;
}stru;
pstru alta(pstru ultimo);
pstru baja(pstru ultimo);
pstru modif(pstru ultimo);
int menu(pstru ultimo);
int main(){
pstru ultimo;
ultimo=(pstru)malloc(sizeof(stru));
menu(ultimo);
return 0;
}
int menu(pstru ultimo){
int opc;
printf("Para alta (1), para baja (2), para modif (3), para salir (4)\n");
scanf("%d", &opc);
switch(opc){
case 1:
ultimo=alta(ultimo);
break;
case 2:
ultimo=baja(ultimo);
break;
case 3:
ultimo=modif(ultimo);
break;
case 4:
return 0;
}
menu(ultimo);
return 0;
}
pstru alta(pstru* ultimo){
pstru nnodo;
nnodo=(pstru)malloc(sizeof(stru));
(ultimo->siguiente)=&nnodo;
printf("Ingrese DNI\n");
scanf("%d", &(nnodo->dni));
ultimo=nnodo;
return ultimo;
}
pstru baja(pstru ultimo){
return ultimo;
}
pstru modif(pstru ultimo){
return ultimo;
}
答案 0 :(得分:0)
您正在执行导致alta
函数中未定义行为的内容。
首先,您尝试将stru **
分配给stru *
。由于类型不同,编译器不允许这样做。
导致未定义行为的部分是您正在使用&nnodo
,即获取本地变量的地址并尝试存储它。这不会起作用,因为局部变量在堆栈上,当函数返回时,编译器会回收堆栈以供其他变量和函数使用。
答案 1 :(得分:0)
在C中,你做不到:
typedef struct stru* pstru;
typedef struct
{
int dni;
pstru siguiente;
} stru;
您已经定义了一个未标记的结构类型并将其称为stru
,但typedef struct stru *pstru;
引用了一个不同的标记结构类型struct stru
,这是不完整的。
您可能需要:
typedef struct stru *pstru;
typedef struct stru
{
int dni;
pstru siguiente;
} stru;
这应该没有问题编译。
在C ++中,你不需要第二个typedef
;你可以简单地写一下:
typedef struct stru *pstru;
struct stru
{
int dni;
pstru siguiente;
};
将定义类型stru
。