标题:求大佬解疑 为什么空间分配失败
只看楼主
桔梗老板
Rank: 1
等 级:新手上路
帖 子:33
专家分:0
注 册:2019-3-25
结帖率:100%
已结贴  问题点数:10 回复次数:10 
求大佬解疑 为什么空间分配失败
程序代码:
#include<stdio.h>
#include<stdlib.h>
#define MAXSIZE 10 
typedef struct S
{
int *top;
int *base; 
int size;
}Stack,*stack;

int InitS(Stack **S)
{
(*S)->base=(int *)malloc(sizeof(int)*(MAXSIZE));
return 1;

}
int main()
{
Stack *S;
int e;
e=InitS(&S);
printf("%d\n",e);
return 0; 
}
搜索更多相关主题的帖子: 空间 分配 失败 int stack 
2019-05-21 23:30
HUMMER军
Rank: 2
等 级:论坛游民
威 望:1
帖 子:7
专家分:19
注 册:2019-5-5
得分:0 
着实没看明白你这程序写的是什么意思?且不说你的结构体typedef的用法,就说你的目标,你说空间分配失败,成功与失败的你是咋看出来的,你定义的InitS函数返回值你直接写了返回1,那么main函数里的e的值只能是1啊 你打印出来的结果也毋庸置疑是1 啊。。。

no code you say j8
no pics you say egg
2019-05-22 03:07
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:0 
int InitS(Stack *S)
{
    S->base=(int *)malloc(sizeof(int)*(MAXSIZE));
    return 1;

}
int main()
{
    Stack S;
    int e;
    e=InitS(&S);
    printf("%d\n",e);
    return 0;
}
2019-05-22 05:15
zhulei1978
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:53
帖 子:1351
专家分:1200
注 册:2006-12-17
得分:0 
你为什么要传地址过去呢,要传指针的话直接传指针的指针就好了吗,你这样传的是一个常数,是指针的地址

其实我就是改变社会风气,提高少女素质,刺激电影市道,提高年轻人内涵,玉树临风,风度翩翩的整蛊专家,我名叫古晶,英文名叫JingKoo!
2019-05-22 07:04
桔梗老板
Rank: 1
等 级:新手上路
帖 子:33
专家分:0
注 册:2019-3-25
得分:0 
回复 4楼 zhulei1978
程序代码:
#include <stdio.h>
#include <stdlib.h>

typedef struct _binode
{
    char data;
    struct _binode *lchild, *rchild;

} Binode;

void Create( Binode** ppb )
{
    int ch = getchar();
    if( ch==EOF || ch=='#')
    {
        *ppb = NULL;
    }
    else
    {
        *ppb = malloc( sizeof(Binode) );
        (*ppb)->data = ch;
        Create( &(*ppb)->lchild );
        Create( &(*ppb)->rchild );
    }
}

void Before( const Binode* pb )
{
    if( pb )
    {
        putchar( pb->data );
        Before( pb->lchild );
        Before( pb->rchild );
    }
}

int main( void )
{
    Binode* p;
    Create( &p );
    printf( "pre:" );
    Before( p );
    printf("\n");
}

那为什么这个可以咧 那个S和这里的ppb有区别吗?
2019-05-22 12:10
ANAPAEST
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2019-5-22
得分:0 
int InitS(Stack *S)
{
    S->base=(int *)malloc(sizeof(int)*(MAXSIZE));
    return 1;

}
int main()
{
    Stack S;
    int e;
    e=InitS(&S);
    printf("%d\n",e);
    return 0;

2019-05-22 19:37
ANAPAEST
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2019-5-22
得分:0 
2019-05-22 19:37
ANAPAEST
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2019-5-22
得分:0 
2019-05-22 19:37
lin5161678
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:45
帖 子:1136
专家分:3729
注 册:2011-12-3
得分:5 
*S是野指针不能 ->

https://zh.
2019-05-23 00:15
lin5161678
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:45
帖 子:1136
专家分:3729
注 册:2011-12-3
得分:0 
程序代码:
#include<stdio.h>
#include<stdlib.h>
#define MAXSIZE 10 
typedef struct S
{
int *top;
int *base; 
int size;
}Stack,*stack;

int InitS(Stack **S)
{
(*S) = malloc(sizeof *S);
(*S)->base=(int *)malloc(sizeof(int)*(MAXSIZE));
return 1;

}
int main()
{
Stack *S;
int e;
e=InitS(&S);
printf("%d\n",e);
return 0; 
}

https://zh.
2019-05-23 00:17



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-494864-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.047828 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved