- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为 Conway 的生命游戏开发 C 实现,我被要求使用以下 header :
#ifndef game_of_life_h
#define game_of_life_h
#include <stdio.h>
#include <stdlib.h>
// a structure containing a square board for the game and its size
typedef struct gol{
int **board;
size_t size;
} gol;
// dynamically creates a struct gol of size 20 and returns a pointer to it
gol* create_default_gol();
// creates dynamically a struct gol of a specified size and returns a pointer to it.
gol* create_gol(size_t size);
// destroy gol structures
void destroy_gol(gol* g);
// the board of 'g' is set to 'b'. You do not need to check if 'b' has a proper size and values
void set_pattern(gol* g, int** b);
// using rules of the game of life, the function sets next pattern to the g->board
void next_pattern(gol* g);
/* returns sum of all the neighbours of the cell g->board[i][j]. The function is an auxiliary
function and should be used in the following function. */
int neighbour_sum(gol* g, int i, int j);
// prints the current pattern of the g-board on the screen
void print(gol* g);
#endif
我添加了注释来帮助解释每一位的含义。
gol.board
是一个2级整数数组,包含x和y坐标,即board[x][y]
,每个坐标可以是1 (活着)或 0(死亡)。
这只是一些背景信息,我正在尝试编写我的第一个函数 create_default_gol()
,它将返回一个指向 gol
实例的指针,其中包含20x20 板。
然后,我尝试遍历 20x20 板的每个坐标并将其设置为 0
,运行此程序时出现段错误(核心转储)
。
下面的代码是我的 c 文件,其中包含核心代码和 main()
函数:
#include "game_of_life.h"
int main()
{
// Create a 20x20 game
gol* g_temp = create_default_gol();
int x,y;
for (x = 0; x < 20; x++)
{
for (y = 0; y < 20; y++)
{
g_temp->board[x][y] = 0;
}
}
free(g_temp);
}
// return a pointer to a 20x20 game of life
gol* create_default_gol()
{
gol* g_rtn = malloc(sizeof(*g_rtn) + (sizeof(int) * 20 * 20));
return g_rtn;
}
这是我想要实现的第一个功能,能够生成每个坐标都为 0(死)状态的 20x20 板。
请随意批评我的代码,我正在寻找确定为什么会出现段错误,以及我是否在 create_default_gol()
函数中正确分配内存。
谢谢!
最佳答案
类型 int **board;
意味着 board
必须包含一个指针数组,每个指针都指向每行的开头。您现有的分配忽略了这一点,只分配 *g_rtn
加上板中的 int
。
假设您必须坚持使用类型 int **board;
,分配主板的规范方法是:
gol* g_rtn = malloc(sizeof *g_rtn);
g_rtn->size = size;
g_rtn->board = malloc(size * sizeof *g_rtn->board);
for (int i = 0; i < size; ++i)
g_rtn->board[i] = malloc(size * sizeof **g_rtn->board);
这段代码涉及很多小的malloc block 。您可以将板的行和列压缩为单个分配,但是您还需要设置指向每行开头的指针,因为 board
必须是指向 int 的指针数组。
此方法的另一个问题是对齐。对齐。保证 malloc
结果对于任何类型都是对齐的;但是 int
可能比 int *
具有更严格的对齐要求。我的以下代码假设它没有;如果您想要可移植,那么您可以添加一些编译时检查(或运行它并查看它是否中止!)。
所需的内存量是最后两次 malloc 的总和:
g_rtn->board = malloc( size * size * sizeof **g_rtn->board
+ size * sizeof *g_rtn->board );
然后第一行将在行指针结束后开始(强制转换是必要的,因为我们要将 int **
转换为 int *
,并且使用 void *
意味着我们不必重复单词 int
):
g_rtn->board[0] = (void *) (g_rtn->board + size);
其他行中每行都有 size
个整数:
for (int i = 1; i < size; ++i)
g_rtn->board[i] = g_rtn->board[i-1] + size;
请注意,这比仅使用一维数组并对偏移量进行算术要复杂得多,但规定您必须有两级间接访问板。
而且这比“规范”版本更复杂。在此版本中,我们以代码复杂性为代价换取了减少 malloc 数量的好处。如果您的程序通常只分配一个板或少量板,那么这种权衡也许不值得,并且规范版本会给您带来更少的麻烦。
最后 - 正如您在问题中尝试做的那样,可以在单个 malloc 中分配 *g_rtn
和板。然而,我的建议(根据经验)是,将董事会分开会更简单。如果棋盘是游戏对象的单独分配,它会使您的代码更清晰,并且您的对象更易于使用和更改。
关于c - 段错误(核心转储)[康威的生命游戏],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23195637/
我已经使用 vue-cli 两个星期了,直到今天一切正常。我在本地建立这个项目。 https://drive.google.com/open?id=0BwGw1zyyKjW7S3RYWXRaX24tQ
您好,我正在尝试使用 python 库 pytesseract 从图像中提取文本。请找到代码: from PIL import Image from pytesseract import image_
我的错误 /usr/bin/ld: errno: TLS definition in /lib/libc.so.6 section .tbss mismatches non-TLS reference
我已经训练了一个模型,我正在尝试使用 predict函数但它返回以下错误。 Error in contrasts<-(*tmp*, value = contr.funs[1 + isOF[nn]])
根据Microsoft DataConnectors的信息我想通过 this ODBC driver 创建一个从 PowerBi 到 PostgreSQL 的连接器使用直接查询。我重用了 Micros
我已经为 SoundManagement 创建了一个包,其中有一个扩展 MediaPlayer 的类。我希望全局控制这个变量。这是我的代码: package soundmanagement; impo
我在Heroku上部署了一个应用程序。我正在使用免费服务。 我经常收到以下错误消息。 PG::Error: ERROR: out of memory 如果刷新浏览器,就可以了。但是随后,它又随机发生
我正在运行 LAMP 服务器,这个 .htaccess 给我一个 500 错误。其作用是过滤关键字并重定向到相应的域名。 Options +FollowSymLinks RewriteEngine
我有两个驱动器 A 和 B。使用 python 脚本,我在“A”驱动器中创建一些文件,并运行 powerscript,该脚本以 1 秒的间隔将驱动器 A 中的所有文件复制到驱动器 B。 我在 powe
下面的函数一直返回这个错误信息。我认为可能是 double_precision 字段类型导致了这种情况,我尝试使用 CAST,但要么不是这样,要么我没有做对...帮助? 这是错误: ERROR: i
这个问题已经有答案了: Syntax error due to using a reserved word as a table or column name in MySQL (1 个回答) 已关闭
我的数据库有这个小问题。 我创建了一个表“articoli”,其中包含商品的品牌、型号和价格。 每篇文章都由一个 id (ID_ARTICOLO)` 定义,它是一个自动递增字段。 好吧,现在当我尝试插
我是新来的。我目前正在 DeVry 在线学习中级 C++ 编程。我们正在使用 C++ Primer Plus 这本书,到目前为止我一直做得很好。我的老师最近向我们扔了一个曲线球。我目前的任务是这样的:
这个问题在这里已经有了答案: What is an undefined reference/unresolved external symbol error and how do I fix it?
我的网站中有一段代码有问题;此错误仅发生在 Internet Explorer 7 中。 我没有在这里发布我所有的 HTML/CSS 标记,而是发布了网站的一个版本 here . 如您所见,我在列中有
如果尝试在 USB 设备上构建 node.js 应用程序时在我的树莓派上使用 npm 时遇到一些问题。 package.json 看起来像这样: { "name" : "node-todo",
在 Python 中,您有 None单例,在某些情况下表现得很奇怪: >>> a = None >>> type(a) >>> isinstance(a,None) Traceback (most
这是我的 build.gradle (Module:app) 文件: apply plugin: 'com.android.application' android { compileSdkV
我是 android 的新手,我的项目刚才编译和运行正常,但在我尝试实现抽屉导航后,它给了我这个错误 FAILURE: Build failed with an exception. What wen
谁能解释一下?我想我正在做一些非常愚蠢的事情,并且急切地等待着启蒙。 我得到这个输出: phpversion() == 7.2.25-1+0~20191128.32+debian8~1.gbp108
我是一名优秀的程序员,十分优秀!