- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
此函数应该将字典加载到 trie 中。我想知道字典文件有多大,这样我就可以一次调用
所有内存。这样做的原因是所有内存都靠近在一起,因此可以利用有助于加快搜索速度的硬件。我也找到了 2 种方法的建议。其中之一是您将在我的代码中看到的 sys/stat.h
的使用。
当我运行这段代码时,我收到一个“段错误”,我知道这意味着我正在尝试访问我没有权限的内存。通过使用 GDB 我发现段错误发生在第 116 行(又名:读取“else if (cur->children[key] == NULL)”的行)我发现 key 中的值在那时间是 12。起初我认为问题出在我对 calloc
或 sys/stat.h
的使用上,因为这是我对它们了解最少的两件事利用。然而,我对它们的研究越多,这种可能性就越小。如果不是其中之一,那么我什至不知道该去哪里找。
下面只是我认为相关的代码:
#include <stdlib.h>
#include <stdbool.h>
#include <stdio.h>
#include <ctype.h>
#include <string.h>
#include <sys/stat.h>
#include "dictionary.h"
typedef struct node
{
bool end[26];
struct node* children[26];
} node;
node* start;
int key;
int last;
int dic_count;
bool load(const char* dictionary)
{
struct stat s;
stat(dictionary, &s);
int size = s.st_size;
dic_count = 0;
int z = 1;
FILE* dic = fopen(dictionary, "r");
if (dic == NULL)
{
return false;
}
start = calloc(size, sizeof(node));
if (start == NULL)
{
return false;
}
int l = 0;
int d;
node* cur = &start[0];
while (0 != (d = fgetc(dic)))
{
int d = fgetc(dic);
if (l > 0)
{
last = key;
}
l = 1;
key = d - 'a';
if (d == '\n')
{
cur->end[last] = true;
cur = &start[0];
dic_count++;
}
else if (cur->children[key] == NULL)
{
node* new = &start[z];
cur->children[key] = new;
z++;
if (cur->children[key] == NULL)
{
return false;
}
cur = cur->children[key];
}
else
{
cur = cur->children[key];
}
}
return true;
}
非常感谢任何帮助。
最佳答案
您确定您的文件包含二进制 0 吗?如果您尝试读取文件末尾,请针对 EOF 测试 fgetc
结果,而不是 0。否则您的循环永远不会终止。
除此之外,您只处理每个第二个字符。
按要求扩展:
来自 man fgetc
:
fgetc(), getc() and getchar() return the character read as an unsigned char cast to an int or EOF on end of file or error
您可能将它与 fgets
返回值混淆了。
while ((ch = fgetc(fp)) != EOF)
安然无恙。同样,可能造成混淆的原因是
while (!feof(fp))
现在,关于未处理的字符:你写了
while (0 != (d = fgetc(dic)))
{
int d = fgetc(dic);
代码读取 while
表达式中的一个字符,将其与 0 进行比较,然后读取(下一个)字符。第一个字符丢失。
关于c - 段错误加载字典。它是由 calloc、sys/stat.h 还是其他原因引起的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26264055/
这个问题已经有答案了: Do I cast the result of malloc? (29 个回答) 已关闭 8 年前。 有什么区别: int *array; array = (int*) cal
我是一名初学者 C 程序员,我认为情况会是这样,但如果可能的话,我希望得到一些肯定。 如果它们相同,为什么不只取一个参数呢? 最佳答案 calloc(a, b) 和 calloc(b, a) 之间没有
这个问题在这里已经有了答案: Is calloc(4, 6) the same as calloc(6, 4)? (7 个答案) 关闭 3 个月前。 calloc(10,4) 和 calloc(1,
所以calloc()通过向操作系统询问一些虚拟内存来工作。操作系统与 MMU 协同工作,并巧妙地以虚拟内存地址进行响应,该地址实际上映射到 copy-on-write, read-only page
在玩 hashmap 玩具示例的实现时(为了好玩)我发现了一个奇怪的行为,calloc 没有像预期的那样将我想要的整个内存块初始化为零。如果整个内存块都清零,则以下代码应该不会产生任何输出: #inc
我想创建一个封装动态分配数组的结构。它看起来像这样: typedef struct IntArray { int *field; size_t length; } IntArray;
我正在开发一个 C 项目,事实证明,在特定时刻,我调用了 calloc() 函数,它分配了一个已在使用中的内存块。这怎么可能?我检查了我的内存分配使用情况,每次调用 malloc/calloc 时,我
在我的程序中,calloc() 不适用于超过 38 的大小,但小于此数字则可以完美运行。在本例中,我想分配 128 个 int,然后释放它。 怎么了? #include #include #inc
我的main函数有这个: int main() { // double minW, minL, width, length; unsigned tileCap = 10; auto
首先,这是我见过的最奇怪的错误。我不知道发生了什么事。任何人都可以就正在发生的事情提供任何帮助,我们将不胜感激。 我正在编写一个 C 程序,该程序将文件读入动态分配的 block 并在这些 blo
calloc 是否分配返回连续的内存位置?如果是,如果不可用,它会做什么? 最佳答案 Does calloc allocate returns contiguous memory location?
这句话是什么意思? //allocated memory for Device info (*PppsCoreStructure)->psDeviceDetails=(sDeviceDetails *
这是我的代码: #include #include int main(){ int n=10; char *s= calloc(2,sizeof(char)); sprintf(s,"%d",n)
我在 Tiva C launchpad (ARM Cortex M4) 上分配内存时遇到问题,我想做的是在某个时候动态分配指向另一个结构内部结构的指针 calloc() 返回一个指针,该指针的值与存储
我是 C 的新手。 我知道这是正确的: char* Str; Str = (char*)calloc(Str_Len, sizeof(char)); ,但为什么这是不正确的? char* Str; *
我遇到了某种指针冲突, 基本上,在我做的一个函数中, a = calloc(1,28); // gives me 0x100100d10 然后很快在我做的一个子函数中, b = calloc(1,16
这是一段代码。N=70000 或更多时,代码会继续执行 STEP1 并因段错误而崩溃。相反,如果我把例如N=50000,calloc返回NULL,程序退出返回2。那么为什么 N=70000 callo
查看刚刚提出的这个问题:Inconveniences of pointers to static variables那么,这样做会被视为不良做法吗? char* strpart(char* strin
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Is NULL always zero in C? C 标准为 calloc() 规定了以下内容: The
清零内存有什么优势(即 calloc() 优于 malloc())?无论如何,您不会将值更改为其他值吗? 最佳答案 有两个阵营:一个说在声明变量时初始化变量有助于发现错误。这个阵营中的人确保他们声明的
我是一名优秀的程序员,十分优秀!