- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
这是我从一些旧的 Java 代码创建的一个简单的 C 程序(我的第一个 C 程序,所以很好 ;))。这比相应的 Java 代码运行得快得多,但 Java 允许我在它崩溃之前更精确(我也在 Java 中使用 longs)。
令我惊讶的是,直到输入超过 170,000,000,Java 代码才崩溃。 C 代码无法处理超过 1,050,000 的任何内容。有什么建议可以让这个 C 代码在不需要一些疯狂的库的情况下运行得更好吗?谢谢!
#include <stdio.h>
#include <string.h> /* lets me use memset */
#include <stdlib.h> /* home of strtoull */
/* segfault 11 after 1047993 (Not anymore!!) */
unsigned long long getnext( unsigned long long x );
unsigned long long getnext( unsigned long long x )
{
if (x == 1) { return 1; }
if (x % 2 == 0) { return x/2; }
return (3 * x + 1);
}
int main(int argc, char *argv[])
{
int argind;
for ( argind = 0; argind < argc; argind++ )
{
unsigned long long intrange;
intrange = strtoull(argv[argind], NULL, 10);
/** Improper allocation of memory. Fixed directly below. Thanks Marcus!
* unsigned long long lengths[intrange+1];
* memset(lengths, 0, sizeof(lengths));
*/
unsigned long long *lengths= malloc((intrange+1) * sizeof(unsigned long long)); /* ptr points to mem. location of lengths array. */
memset(lengths, 0, (intrange+1) * sizeof(unsigned long long));
unsigned long long longestlen[2];
unsigned long long seqindex;
unsigned long long origdex;
longestlen[0] = 0;
longestlen[1] = 0;
for (origdex = 2; origdex <= intrange; origdex++)
{
seqindex = origdex;
while ( seqindex > 1 )
{
lengths[ origdex ] += 1;
seqindex = getnext(seqindex);
if ( seqindex <= intrange )
{
if ( lengths[ seqindex ] > 0)
{
lengths[ origdex ] = lengths[ origdex ] + lengths[ seqindex ];
if ( lengths[origdex] > longestlen[1] ) { longestlen[0] = origdex; longestlen[1] = lengths[origdex]; }
seqindex = 1;
continue;
}
}
}
}
if(longestlen[0] > 0 ){ printf("Longest Collatz sequence for first %llu positive integers found at %llu with length %llu. \n", intrange, longestlen[0], longestlen[1]); }
}
return 0 ;
}
最佳答案
如果你让你的程序通过调试器运行(在我的例子中:
gcc -o collatz -g collatz.c
gdb --args collatz 2000000
$run
...segfault at memset(lengths,0,sizeof(lengths))...
),当您尝试访问长度时,您会发现您的段错误发生了!
关键是你为数组做动态内存分配是错误的;这在 C 中有点棘手(这就是为什么我通常建议来自其他语言的人学习现代 C++ 而不是 C)。
你应该这样做
unsigned long long *lengths = malloc(...);
给你新分配的内存。
此外,sizeof(lengths)
是错误的,因为那将是指向数组开头地址的指针的大小。请改用 sizeof(unsigned long long)
。当然,您的代码必须读取 memset(lengths, 0, sizeof(unsigned long long)*(intrange+1))
以设置 intrange+1
倍数unsigned long long
占 0
字节的字节数。
有关malloc
的详细信息,如果您在具有man
的系统上,则可以使用man malloc
;通常,您必须在使用后“释放”使用 malloc
分配的内存。在你的情况下,程序终止时它会自动完成,但对于更复杂的软件,不会调用 free(ptr)
你通过 type *ptr = malloc(.. .)
在您不再需要该内存之后就是内存泄漏。
同样,这是一个非常典型的 C 语言问题。如果您使用 C++ 编写代码,您将能够使用诸如 std::vector
之类的东西来为您提供具有自动构造和值填充功能的可变大小数组,而几乎不会对性能造成任何影响,它将在离开声明它的范围时自动释放。
关于java - Collatz 和其他序列 : how to get more precision easily and avoid segfault?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30818027/
所以我需要一个简单的分配器来分配(有时使用清零)并随后从映射内存池中释放 4K block 。然而,在实现这个之后,在测试时我发现在释放一两个 block 之后,如果我尝试分配一个 block ,程序
我的任务是用 C 编写一个程序。该程序应该能够检查参数并创建与我提供的参数一样大的数组。我必须用随机数填充数组。到目前为止工作正常。稍后我的任务是使用指针对数组进行排序。第一件事是我不太明白指针是如何
我对 C 很陌生(仍然)所以如果我误解了一些基本的东西,请耐心等待 我有一个简单的程序,它应该将文件作为字符串读取,然后将该字符串拆分成行 - 将结果存储到 n 个字符串数组中。但是,当我运行以下代码
我在工作中使用的应用程序之一遇到了一个奇怪且烦人的问题。该应用程序是用 C++ 编写的,当应用程序终止(主函数返回或调用 exit)时,它会因段错误而崩溃。段错误似乎是由 basic_string 类
我使用 python swig 包装的 C++ 库。在它的 __init__.py 文件中,它 sets在导入包含实现代码的共享对象文件之前,使用 dlopen 标志 RTLD_GLOBAL。 这会导
我在这里遇到了段错误。我很困惑。请帮帮我。 f1 和 y 都是结构体节点的指针。我想把 y 的左转 f1 右转。 #include #include struct node{
我有一个在公共(public)结构中声明的数组,如下所示: uint16_t *registers; 在一个函数中,我正在检索一个字符字符串(存储在缓冲区中,请参阅下面的代码),其中包含以逗号分隔的数
我正在用 C 实现二叉搜索树。下面的代码工作正常,只是当我尝试从树中删除子树时得到 SEGFAULT: 源代码: #include #include struct node { int dat
struct vehicle *add_vehicle(struct vehicle *v){ struct vehicle *newcar = (struct vehicle*)malloc
我正在使用链接列表实现符号表,代码工作正常,但代码中存在内存泄漏, 我有以下结构 struct node { char* pcKey; void* pvValue; struct node
我正在尝试将字符串复制到数组并打印它。它适用于第一个 for 循环,但第二次出现 seg 错误。 main (int argc, char *argv[]){ int argcIndex; cha
自从我用 C 编写代码已经一年了,但我不明白为什么会出现段错误 // Assume all imports are made int printAgain(double** array, int si
这是我的代码。编辑:调用者包含在底部。 该函数读取数据文件,确定有多少行和列,然后将数据存储到 data_array 中。 int getdata(double* *data_array, int*
我认为有两组代码是等效的,但一组会导致段错误,而另一组则不会。我真的很困惑为什么会这样...... 我想创建一个查找函数 此代码确实有效: MyPair *> dummy(x, NULL);
希望有人能提供帮助。我可以毫无错误地编译,我没有发现任何语法错误,但是当我运行它时,它崩溃了。在启动时调试段错误。全面披露,这是作业。我不是要找人来编写这个代码,只是看看我的问题和我现有的代码,也许会
我正在尝试在OpenMP中并行化相当大的for-loop。大约有20%的时间运行正常,但其余时间会因各种段错误而崩溃,例如: *** glibc detected *** ./execute: dou
我有一个模板类 ISingleton class ISingleton { public: static T* getInstance() { lock_guard g
我正在为使用 LibSVM 的 Android 构建 NDK 应用程序。我在 XCode 中为我的 mac 构建了一个等价物(都是 C++) 我发现 Mac 可以高速准确地处理我给它的非常大的特征向量
我在 ARM linux 平台上有一个由简单代码引起的非常奇怪的崩溃。问题是它很少重现(一天一次),另一个问题是它在实际上无法重现的地方崩溃。 让我们从 C++ 代码开始。线程函数执行此操作:
我有这段代码 int main() { int *b = new int(8); cout<<" &b = "<
我是一名优秀的程序员,十分优秀!