| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3012 人关注过本帖
标题:求大佬解疑 为什么空间分配失败
只看楼主 加入收藏
桔梗老板
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: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10607
专家分:43186
注 册: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
快速回复:求大佬解疑 为什么空间分配失败
数据加载中...
 
   



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

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