- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的问题如下:我有一个名为 Environment
的结构,其中包含一个 Obstacle
结构列表。我无法从代码中手动创建的现有 Obstacle
列表中分配此 environment.obstacles
。
我有以下定义:
struct PointGPS {
double longitude;
double latitude;
} typedef PointGPS;
struct Obstacle {
int id;
PointGPS position;
double radius;
} typedef Obstacle;
struct Environment {
Obstacle *obstacles;
PointGPS destination;
} typedef Environment;
我正在使用以下函数来实例化我的值:
PointGPS createPoint(double longitude, double latitude) {
PointGPS point;
point.latitude = latitude;
point.longitude = longitude;
return point;
}
Obstacle createObstacle(int id, double radius, PointGPS position) {
Obstacle obstacle;
obstacle.id = id;
obstacle.radius = radius;
obstacle.position = position;
return obstacle;
}
Environment createEnvironment(PointGPS destination, Obstacle *obstacles) {
Environment environment;
environment.destination = destination;
environment.obstacles = obstacles;
return environment;
}
在我的 main
函数中,我创建了一个障碍列表:
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#define NELEMS(x) (sizeof(x) / sizeof((x)[0]))
int main() {
PointGPS pointGps1 = createPoint(49.202538, 6.918930);
PointGPS pointGps2 = createPoint(49.202650, 6.925839);
PointGPS destination = createPoint(49.202660, 6.925849);
Obstacle obstacle1 = createObstacle(1, 10, pointGps1);
Obstacle obstacle2 = createObstacle(2, 30, pointGps2);
Obstacle *obstacles[2];
obstacles[0] = &obstacle1;
obstacles[1] = &obstacle2;
// environment is global
environment = createEnvironment(destination, *obstacles);
// The two following methods allow me to print the id of the first element
printf("%d\n", environment.obstacles->id);
printf("%d\n", environment.obstacles[0].id);
// But I cant access to the values -for exemple the id field- of the following obstacles
printf("%d\n", environment.obstacles[1].id);
}
我想将此列表提供给我的环境
。但它无法分配或指向正确的值。通过 environment.obstacles
中的一些障碍物的 id
测试总是从内存中返回一些随机整数值。
我尝试了以下尝试:
1)
// environment is global
environment = createEnvironment(destination, *obstacles);
2)
environment.obstacles = (Obstacle *)malloc(sizeof(Obstacle *) * NELEMS(obstacles));
environment.obstacles[0] = *obstacles[0];
environment.obstacles[1] = *obstacles[1];
3)
environment.obstacles = (Obstacle *)malloc(sizeof(Obstacle *) * NELEMS(obstacles));
environment.obstacles[0] = createObstacle(obstacles[0]->id, obstacles[0]->radius, createPoint(obstacles[0]->position.longitude, obstacles[0]->position.latitude));
environment.obstacles[1] = createObstacle(obstacles[1]->id, obstacles[1]->radius,
createPoint(obstacles[1]->position.longitude, obstacles[1]->position.latitude));
所有这些尝试都失败了,返回的值如 -2144113376
,甚至没有在我的 environment
变量中创建长度 = 2 的数组。
我很确定我遗漏了一些明显的东西,因为我对这种语言的经验为零,但我无法弄清楚。我该如何继续?
更新 1:
此语法允许我使用方法 n°1 访问第一个障碍:
printf("%d\n", environment.obstacles->id)
但是我无法访问第二个障碍。执行 printf("%d\n", environment.obstacles[1]->id);
返回此错误:
Member reference type 'Obstacle' (aka 'struct Obstacle') is not a pointer, did you mean to use '.'?
并且执行 printf("%d\n", environment.obstacles[1].id);
仍然返回随机值。
更新 2:
根据要求,我编辑了结构、函数和主要文件。
更新 3:
这是一个可测试的代码,可以执行我的帖子中尝试的操作。 https://onlinegdb.com/S1342WPsN如果我在我的计算机上运行代码,在尝试访问第一个字段之后的字段时,我仍然有随机值。但如果我在网站内运行代码(参见链接),它似乎提供了正确的值。
最佳答案
数组和指针之间存在混淆。 main
函数中的 obstacles
是指向 Obstacle
结构的指针数组。您可能想要定义一个 Obstacle
结构数组,使用 obstacle1
和 obstacle2
的副本进行初始化,并将其传递给 createEnvironment
。将数组作为参数传递实际上是传递指向其第一个元素的指针。
修改后的版本:
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#define NELEMS(x) (sizeof(x) / sizeof((x)[0]))
int main() {
PointGPS pointGps1 = createPoint(49.202538, 6.918930);
PointGPS pointGps2 = createPoint(49.202650, 6.925839);
PointGPS destination = createPoint(49.202660, 6.925849);
Obstacle obstacle1 = createObstacle(1, 10, pointGps1);
Obstacle obstacle2 = createObstacle(2, 30, pointGps2);
Obstacle obstacles[2];
obstacles[0] = obstacle1;
obstacles[1] = obstacle2;
// environment is global
environment = createEnvironment(destination, obstacles);
// The two following methods allow me to print the id of the first element
printf("%d\n", environment.obstacles->id);
printf("%d\n", environment.obstacles[0].id);
// This one should print the id of the second element
printf("%d\n", environment.obstacles[1].id);
return 0;
}
另请注意,您的 tyedef
定义在 C 中不是惯用的。typedef
关键字通常排在第一位:
typedef struct PointGPS {
double longitude;
double latitude;
} PointGPS;
关于c - 包含结构数组的结构不能由相同类型列表中的值分配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55929764/
如标题所示,ans_list是一个答案列表,ans_index是一个数字(答案在词汇表中的索引,但与atm无关) 这里生成的 tree.anslist 是什么? (例如,仅针对第一个),忽略迭代。 f
我目前将用户的输入存储在逗号分隔的列表中,如下所示: Userid | Options 1 | 1,2,5 用户在一个数组形式中勾选一组选项,然后用逗号连接起来 1,2,5 然后 MySQ
我目前将用户的输入存储在逗号分隔的列表中,如下所示: Userid | Options 1 | 1,2,5 用户在一个数组形式中勾选一组选项,然后用逗号连接起来 1,2,5 然后 MySQ
我想知道如何完全展平列表和包含它们的东西。除其他外,我想出了一个解决方案,它可以将具有多个元素的东西滑倒并将它们放回原处,或者在滑倒后将具有一个元素的东西拿走。 这与 How do I “flatte
我想知道如何完全展平列表和包含它们的东西。除其他外,我想出了一个解决方案,它可以将具有多个元素的东西滑倒并将它们放回原处,或者在滑倒后将带有一个元素的东西拿走。 这与 How do I “flatte
这个问题已经有答案了: Convert nested list to 2d array (3 个回答) 已关闭 7 年前。 java中有没有快捷方式可以转换 List> 到 String[][] ?
我在排序时遇到问题 List> 。我创建了一个自定义比较器,在其中编写了对数据进行排序的代码。 public class CustomComparator implements Comparator
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Java Generics: Cannot cast List to List? 我只是想知道为什么下面的java代
试图想出一个 LINQy 方法来做到这一点,但我什么也没想到。 我有一个对象列表<>,其中包含一个属性,该属性是逗号分隔的字母代码列表: lst[0].codes = "AA,BB,DD" lst[1
假设我有这些任务: points = [] point = (1, 2) 我怎么会这样做: points += point 它工作得很好,并且给了我点 = [1, 2]。但是,如果我这样做: poin
如何在 scala 中将 List[Task[List[Header]]] 类型转换为 Task[List[Header]]。 我有一个方法返回 Task[List[Header]] 并多次调用 do
如何在 Java 中查找二维列表的元素? 我有一个参数为 List> 的函数我想知道如何找到这个列表的行和列。 最佳答案 如果你喜欢 List> obj 然后你就可以像这样访问 obj.get(cur
分配 List到 List工作正常。 分配 List>到 List>不编译。 代码 public class Main { public static void main(String[] a
我正在用 Java 编写一个方法,该方法必须接收并迭代 Serializable 的 List。 有什么区别: public void myMethod(List list) { } 和 public
我看到很多人想用 mvvm 更新网格/列表/树的一部分,但他们不想刷新整个列表。 对于所有遇到此问题的人,我做了以下示例。 希望这对你有用。 最佳答案 这是一个简单的例子。整个代码中最重要的是: Bi
我正在为现有的 C++ 库编写包装器,该库使用列表,其中 T 是自定义结构。我被建议使用 vector 而不是列表,但我试图避免修改库。 为了更好地理解这个场景,我做了一个简单的应用程序,使用一个列表
List list List list 这两种声明有什么区别吗? 谢谢, 最佳答案 是的。 List可以包含所有派生自 Base 的不同事物的混合物. List包含同质项(从某种意义上说,它们必须全部
有人可以尽可能详细地解释以下类型之间的区别吗? List List List 让我更具体一点。我什么时候想使用 // 1 public void CanYouGiveMeAnAnswer(List l
我有一个元组列表,每个元组都是一对列表。所以我的数据看起来像: mylist = [(['foo', 'bar'], ['bar', 'bar']),(['bar', 'bar'],['bar', '
也许是一个时髦的标题,但我遇到了以下问题: 给定一个类型为 (a * b) list 的列表,我想创建一个类型为 (a * b list) list 的新列表。一个例子: 给定列表 let testL
我是一名优秀的程序员,十分优秀!