求助,malloc分配内存问题

feiya121 2011-12-13 05:11:28

#include <stdio.h>
#include <stdlib.h>
#define N 250000000

int main()
{
int i;
double *x;

if(!(x = malloc(N * sizeof(double)) ))
printf("memory error \n");

free(x);
}



总是说内存错误,我有8G内存呀。为何会这样呢,如何解决呀?
...全文
240 18 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
18 条回复
切换为时间正序
请发表友善的回复…
发表回复
msrend 2011-12-14
  • 打赏
  • 举报
回复
支持11楼,楼主要注意细节。
赵4老师 2011-12-14
  • 打赏
  • 举报
回复
如果有一天,你老无所依,……哦不,你真需要比如64GB的数组的话,可以用文件读写模拟内存读写,用_lseeki64函数移动文件读写位置。
绿野耕夫 2011-12-14
  • 打赏
  • 举报
回复
malloc是从堆上分配内存,你确定你有8G内存就能有8G的堆吗?
「已注销」 2011-12-14
  • 打赏
  • 举报
回复
[Quote=引用 13 楼 feiya121 的回复:]

因为的确是需要一个大数组。信号频率是30MHz,然后取样频率是100MHz,这样很容易就要很大的内存来存数组。
[/Quote]

google earth的数据需要多大的内存?

你下载一个3D游戏看看,一般都10G左右,为什么仅仅1G内存的机器就可以跑?

「已注销」 2011-12-14
  • 打赏
  • 举报
回复
再者,在free时,要判断指针是否为空。因为free(NULL)是很bug的。。。

----

这个早不是bug了,而被写进了堆标准,堆可以接受free(0)
feiya121 2011-12-13
  • 打赏
  • 举报
回复
因为的确是需要一个大数组。信号频率是30MHz,然后取样频率是100MHz,这样很容易就要很大的内存来存数组。
TMAC10052120353 2011-12-13
  • 打赏
  • 举报
回复
寻址问题,如果开了PAE的话,可以到36G,楼主申请的太大了
自信男孩 2011-12-13
  • 打赏
  • 举报
回复
申请这么大的空间,你是不是想让系统崩溃吗?8G的内存不可能都给你用啊,malloc是在堆上申请的空间,你确定你的堆有这么大的空间吗?我估计一个程序也用不了这个大的一个空间吧。
jiutianc 2011-12-13
  • 打赏
  • 举报
回复
8g应该不会都分配给堆吧,会留出部分来
AnYidan 2011-12-13
  • 打赏
  • 举报
回复
什么东西都有个限度,

google virtual memory
狂且 2011-12-13
  • 打赏
  • 举报
回复
我猜猜猜哈, 你的应该是 64 位操作系统, 如果是 32 位的, 只能寻址到 4G.

8G分配不到, 因为操作系统要占用一些内存空间, 还有为硬件保留的内存. 所以你不可能分配到 8G.

因为 malloc() 分配的是堆里的. 即使你有8G. 毕竟你的程序归操作系统管. 你现在要占领操作系统的

空间. 他当然不愿意.

你可以试试 7G\6G . PS: 错了请指正. 谢谢.
iamnobody 2011-12-13
  • 打赏
  • 举报
回复
2G内存,申请不到是被限制了大小,也没办法的事啊。弄小点的吧。
turing-complete 2011-12-13
  • 打赏
  • 举报
回复
你这个内存要求是连续的,而实际上有没有连续的给你用,也不清楚。
hik_zty 2011-12-13
  • 打赏
  • 举报
回复
楼主,你要做的时夯实自己的基础

首先,定义指针时,要赋值,是好的习惯。

其次,malloc返回值是void * ,若希望其为double类型的指针,强制转换一下

再者,在free时,要判断指针是否为空。因为free(NULL)是很bug的。。。
yanghuatian 2011-12-13
  • 打赏
  • 举报
回复
建议LZ,可以找找计算机原理方面的书,在系统内存的分配上,是有一个规则的。如果知道这个,就能理解这个肯定是有一定限制的。简单说,关于内存分配或是数据存储分配,都是按照地址来划分的,在定义前,系统会自动分配一个大小,这就是一个限制,如果超出了,就会出错,当然不同的系统处理方法不同。
而一般常用的程序是不会出现那种情况的,即使出现也会有相应的解决办法。
君子美玉 2011-12-13
  • 打赏
  • 举报
回复
32位系统下,一个进程的虚拟空间是4G,linux下你一次最大能分配的堆空间是2.9G,windows是1.9G左右(可以改配置变成2.9G),如果你想用上8G内存的话,改装64位的操作系统就OK了
zhozhoyu 2011-12-13
  • 打赏
  • 举报
回复
原因:楼主分配的空间太大了,内存是操作系统维护的,再说堆大小肯定比8G小很多?
解决方法:分配小点,用多少就分配多少!
  • 打赏
  • 举报
回复
操作系统是虚拟内存,~~~~
适合新手的教程,我自己也在学,以下是部分学习笔记 69 函数指针 70 动态内存分配 Dynamic memory pointer = new type pointer = new type [elements] 第一个表达式用来给一个单元素的数据类型分配内存。第二个表达式用来给一个数组分配内存。 例如: int * bobby; bobby = new int [5]; if (bobby == NULL) { // error assigning memory. Take measures. }; delete pointer; delete [ ] pointer; 在C语言中,为了动态分配内存,我们必须求助于函数库stdlib.h 因为该函数库在C++中仍然有效,并且在一些现存的程序仍然使用,所以我们下面将学习一些关于这个函数库中的函数用法。 函数malloc void * malloc (size_t nbytes); char * cp; cp = (char *) malloc (10); int * bobby; bobby = (int *) malloc (5 * sizeof(int)); 这一小段代码将一个指向可存储5个int型整数的内存块的指针赋给bobby,它的实际长度可能是 2,4或更多字节 数,取决于程序是在什么操作系统下被编译的。 int * bobby; bobby = (int *) calloc (5, sizeof(int)); malloc 和calloc的另一点不同在于calloc 会将所有的元素初始化为0。 它被用来改变已经被分配给一个指针的内存的长度。 void * realloc (void * pointer, size_t size); 参数pointer 用来传递一个已经被分配内存的指针或一个空指针,而参数size 用来指明新的内存长度。这个函数 给指针分配size 字节的内存。这个函数可能需要改变内存块的地址以便能够分配足够的内存来满足新的长度要 求。在这种情况下,指针当前所指的内存中的数据内容将会被拷贝到新的地址中,以保证现存数据不会丢失。函 数返回新的指针地址。如果新的内存尺寸不能够被满足,函数将会返回一个空指针,但原来参数中的指针 pointer 及其内容保持不变。 函数 free 这个函数用来释放被前面malloc, calloc 或realloc所分配的内存块。 void free (void * pointer); 注意:这个函数只能被用来释放由函数malloc, calloc 和realloc所分配的空间。 74 数据结构 76-78 结构指针(Pointers to structures) -> 这是一个引用操作符,常与结构或类的指针一起使用,以便引用其中的成员元素,这样就避免使用很多括号。例如,我们用: pmovie->title 来代替: (*pmovie).title 79 自定义数据类型(User defined data types) typedef existing_type new_type_name; typedef char C; typedef unsigned int WORD; typedef char * string_t; typedef char field [50]; 80 联合(Union) union mytypes_t { char c; int i; float f; } mytypes; 81 枚举Enumerations (enum) enum model_name { value1, value2, value3, . . } object_name; 例如,我们可以定义一种新的变量类型叫做color_t 来存储不同的颜色: enum colors_t {black, blue, green, cyan, red, purple, yellow, white}; 注意在这个定义里我们没有使用任何基本数据类型。换句话说,我们创造了一种的新的数据类型,而它并没有基 于任何已存在的数据类型:类型color_t,花括号{}中包括了它的所有的可能取值。例如,在定义了colors_t 列举 类型后,我们可以使用以下表达式: 84 类(Class) 类(class)是一种将数据和函数组织在同一个结构里的逻辑方法。定义类的关键字为class ,其功能与C语言中的struct类似,不同之处 是class可以包含函数,而不像struct只能包含数据元素。 类定义的形式是: class class_name { permission_label_1: member1; permission_label_2: member2; ... } object_name; 其中 class_name 是类的名称 (用户自定义的类型) ,而可选项object_name 是一个或几个对象(object)标识。Class的声明体中包含 成员members,成员可以是数据或函数定义,同时也可以包括允许范围标志 permission labels,范围标志可以是以下三个关键字中 任意一个:private:, public: 或 protected:。它们分别代表以下含义: ● private :class的private成员,只有同一个class的其他成员或该class的“friend” class可以访问这些成员。 ● protected :class的protected成员,只有同一个class的其他成员,或该class的“friend” class,或该class的子类(derived classes) 可以访问这些成员。 ● public :class的public成员,任何可以看到这个class的地方都可以访问这些成员。 如果我们在定义一个class成员的时候没有声明其允许范围,这些成员将被默认为 private范围。 以下是怎样读前面例子中出现的一些指针和类操作符 (*, &, ., ->, [ ]): ● *x 读作: pointed by x (由x指向的) ● &x 读作: address of x(x的地址) ● x.y 读作: member y of object x (对象x的成员y) ● (*x).y 读作: member y of object pointed by x(由x指向的对象的成员y) ● x->y 读作: member y of object pointed by x (同上一个等价) ● x[0] 读作: first object pointed by x(由x指向的第一个对象) ● x[1] 读作: second object pointed by x(由x指向的第二个对象) ● x[n] 读作: (n+1)th object pointed by x(由x指向的第n+1个对象) 由关键字struct和union定义的类 类不仅可以用关键字class来定义,也可以用struct或union来定义。 因为在C++中类和数据结构的概念太相似了,所以这两个关键字struct和class的作用几乎是一样的(也就是说在C++中struct定义的 类也可以有成员函数,而不仅仅有数据成员)。两者定义的类的唯一区别在于由class定义的类所有成员的默认访问权限为private,而 struct定义的类所有成员默认访问权限为public。除此之外,两个关键字的作用是相同的。 union的概念与struct和class定义的类不同, 因为union在同一时间只能存储一个数据成员。但是由union定义的类也是可以有成员函 数的。union定义的类访问权限默认为public。 94 操作符重载(Overloading operators) + - * / = < > += -= *= /= << >> <<= >>= == != <= >= ++ -- % & ^ ! | ~ &= ^= |= && || %= [] () new delete 96 this指针 97 静态成员(静态变量、静态函数)(Static members) 静态成员类直接访问,不属于类对象的成员 98 类之间的关系(Relationships between classes) 友元函数(Friend functions) 101 类的继承 记住,this 代表代码正在被执行的这一个对象的指针。 142 函数模块 154 出错处理 (Exception handling) 159 类型转换高级 (Advacned Class Type-casting) 163 typeid 164 预处理指令 168 标准函数库

70,023

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧