- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试读取具有这种格式的文件 instance|instruction...像这样 1 01 01 12 12 33,其中第一个数字是实例,之后是指令的编号。每行都有自己的 ID。所以在那个例子中,如果第一行的 id 是 1,那么下一行是 2,依此类推。
我想做的是按照我拥有的 PCB 结构这样的结构对这些信息进行分组。每行都有一个 ID 和一个队列,我在其中存储指令部分的每个编号。
我有一个结构,里面有一些变量和一个队列。问题是队列不工作。
typedef struct Queue
{
int sizeQueue;
int limit;
Node *head;
}Queue;
typedef struct PCB
{
int id;
int program_counter;
int size;
Queue pointer_instrucoes;
int instante;
}PCB;
typedef struct Node
{
PCB *element;
Node *next;
}Node;
主要是我调用带有队列的结构来存储一些值。
PCB *p=new_pcb(contador);
....
p->pointer_instrucoes->head=atoi(s2); //s2 is the some number of the //instruction
但我收到此错误:'->' 的类型参数无效(有'Queue {aka struct Queue}
MVCE:
主文件
#include <stdio.h>
#include <stdlib.h>
#include <string.h> //para o output
#include "queue2.h"
int le_ficheiro(char* filename) {
FILE *ficheiro=fopen(filename,"r");
size_t len=0;
char *line=NULL;
ssize_t read;
char *s1;//string antes do primeiro espaço
char *s2;//string depois do primeiro espaço
char *sp; //linha toda
if(ficheiro==NULL) {
exit(EXIT_FAILURE);
}
int contador=1; //onde comeca o id
while((read = getline (&line, &len,ficheiro))!=-1) //le de linha a linha
{
PCB *p=new_pcb(contador);
sp=strchr(line,' ');
if(!sp)
{
exit(EXIT_FAILURE);
}
s1=strndup(line,sp-line);
s2=sp+1;
p->instante=atoi(s1); //converte char to int
printf("Instante: %d\n",p->instante);
printf("Id: %d\n",p->id);
p.pointer_instrucoes.head=atoi(s2);
printf("%d\n",p->pointer_instrucoes->head);
printf("Retrieved line of length %zu:\n",read);
printf("%s\n",s2);
printf("Aqui : %c\n",line[0]);
contador++;
}
fclose(ficheiro);
if(line)
free(line);
free(s1);
exit(EXIT_SUCCESS);
}
int main()
{
char name[50];
printf("Name of the file: ");
scanf("%s",name);
le_ficheiro(name);
return 0;
queue2.h文件
#include <stdbool.h>
typedef struct PCB PCB;
typedef struct Node Node;
typedef struct Queue Queue;
typedef struct Queue
{
int sizeQueue;
int limit;
Node *head;
}Queue;
typedef struct PCB
{
int id;
int program_counter;
int size;
Queue pointer_instrucoes;
int instante;
}PCB;
typedef struct Node
{
PCB *element;
Node *next;
}Node;
PCB * new_pcb(int id);
Node * new_node(PCB * e);
Queue * new_queue(int limit);
队列2.c
#include <stdio.h>
#include <stdlib.h>
#include <stdio.h>
#include "queue2.h"
Node * new_node(PCB * e)
{
Node *n=malloc(sizeof(Node));
n->element=e;
n->next=NULL;
return n;
}
Queue * new_queue(int limit)
{
Queue *q=malloc(sizeof(Queue));
q->limit=limit;
q->head=NULL;
q->sizeQueue=0;
return q;
}
PCB * new_pcb(int id)
{
PCB *p = malloc(sizeof(PCB));
p->id=id;
p->pointer_instrucoes=0;
p->program_counter=0;
p->size=0;
return p;
}
输入示例:1 01 02 03 04 05
2 01 02 03 02 11
最佳答案
你的问题很初级,你需要花时间竞争 le_ficheiro
。对于初学者,您不能将 atoi(s2)
的结果分配给 p.pointer_instrucoes.head
。 head
不是 int
,它是一个指向 Node*
的指针。您违反了严格别名规则 C11 Standard - §6.5 Expressions (p6,7)并且可能有十几个其他人试图通过分配一个 int
作为其值来访问和修改 Node*
。
您调用未定义的行为 试图在不确定(未初始化)时访问 p->id
。
尝试使用 strchr(line, ' ')
手动将值与 line
分开会使生活变得比实际困难得多。您已经将所有值包含在 line
中,您可以使用 sscanf
在一次调用中将所有六个值解析为 int
并验证该行,例如
while ((read = getline (&line, &len,ficheiro)) != -1) //le de linha a linha
{
int a, b, c, d, e, f;
if (sscanf (line, "%d %d %d %d %d %d",
&a, &b, &c, &d, &e, &f) != 6) {
fprintf (stderr, "error: failed to parse line '%d'.\n",
contador);
continue;
}
PCB *p = new_pcb (contador);
if (!p) /* Validate EVERY Allocation */
exit (EXIT_FAILURE);
但是,在验证每个分配并避免可能调用未定义行为之前,您必须提供来自new_node、new_queue & new_pcb
的有意义的返回值,以指示成功/失败,例如
Node *new_node (PCB *e)
{
Node *n = malloc (sizeof *n);
if (!n) { /* Validate EVERY Allocation */
perror ("malloc-new_node");
return NULL; /* return NULL on failure */
}
n->element = e;
n->next = NULL;
return n;
}
Queue *new_queue (int limit)
{
Queue *q = malloc (sizeof *q); /* typo in declaration */
if (!q) {
perror ("malloc-new_queue");
return NULL;
}
q->limit = limit;
q->head = NULL;
q->sizeQueue = 0;
return q;
}
PCB *new_pcb (int id)
{
PCB *p = malloc (sizeof *p);
if (!p) {
perror ("malloc-new_pcb");
return NULL;
}
p->id = id;
p->pointer_instrucoes = 0;
p->program_counter = 0;
p->size = 0;
return p;
}
很明显,您完成了 le_ficheiro
的一部分,然后就放弃了。它远未完成,您的代码中甚至只使用了每行输入的数据值中的一个(其余的您尝试打印为文本只是为了查看您的 s2
指针指向的位置-- 但不进一步或有意义地使用这些值)
您甚至不调用 new_node
来创建一个 Node*
值,可以想象它可以分配给 p.pointer_instrucoes.head
.一步一步来。您需要在 le_ficheiro
中的某处调用 new_node
,这样您就有了一个可以分配给 p.pointer_instrucoes.head
的指针。它没有任何魔力,但您必须有条不紊地确保每个值和每个结构的每个成员在尝试使用它们之前都已创建并使用值正确初始化。
基本上你有一个 le_ficheiro
的外壳,你需要继续完成它,从一个更好的起始位置开始工作:
int le_ficheiro (char* filename)
{
FILE *ficheiro = fopen (filename,"r");
size_t len = 0;
ssize_t read = 0;
int contador = 1; //onde comeca o id
if (ficheiro == NULL) {
perror ("fopen-filename");
exit (EXIT_FAILURE);
}
while ((read = getline (&line, &len,ficheiro)) != -1) //le de linha a linha
{
int a, b, c, d, e, f;
if (sscanf (line, "%d %d %d %d %d %d",
&a, &b, &c, &d, &e, &f) != 6) {
fprintf (stderr, "error: failed to parse line '%d'.\n",
contador);
continue;
}
PCB *p = new_pcb (contador);
if (!p)
exit (EXIT_FAILURE);
p->instante = a;
printf ("Instante: %d\n", p->instante);
/* you must assign and allocate as necessary to use remaining
* values read from file HERE. Nowhere do you assign p->id
* before attempting to print, etc...
*/
printf ("Id: %d\n", p->id);
/* you cannot assign atoi(s2) to p.pointer_instrucoes.head.
* it expects type 'Node *', not int.
*/
// p.pointer_instrucoes.head = FIXME;
// printf ("%d\n", p->pointer_instrucoes->head);
contador++;
}
fclose(ficheiro);
free (line);
free(s1);
exit(EXIT_SUCCESS);
}
当您在编写函数时遇到困难时,不要放弃。请参阅 How to debug small programs和鸭子说话...真的,这很有帮助 :)
关于c - 错误 :invalid type argument of '->' (have 'Queue {aka struct Queue},我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50255778/
我有一个数组 items[] items[] 中的每一项都是一个结构体。 item 有键 id、date、value(即 item.id、item.date、item.value) 我想使用 Stru
我想存储 100 名员工。 RollNo,姓名,工资,时间(各种数据,我无法在这里解释,但你可以看下面的代码片段来理解 main() { struct day { int hour
这个问题在这里已经有了答案: storage size of ‘names’ isn’t known (3 个答案) 关闭 5 年前。 我正在尝试蓝牙编程,遇到了这个我不明白的问题。基本上,当我使用
这是一个奇怪的事情: 我有一个结构,它包含指向相同类型结构的指针和指向其他类型结构的指针,以及一些其他值。 struct animal { struct animal * father;
我有一个结构定义如下(名称不同) struct str1 { int field1; struct str2; } 我在一个函数中有一个*str1。我想要一个指向 str2 的指针。 所以
DISK_DETECTION_INFO is defined as有什么原因吗? typedef struct _DISK_DETECTION_INFO { DWORD Size
我正在尝试打包一个字符串和一个字符串的长度。 fmt = '
我在创建结构时遇到问题。 我的结构: public struct Device: Codable { let data: DeviceData let meta: Meta? } pu
struct Item { var name:String? var type:String? var value:Int? var tag:Int? } ... ..
// NewReaderSize returns a new Reader whose buffer has at least the specified 43 // size. If the ar
这个问题在这里已经有了答案: Sorting a vector of custom objects (14 个答案) 关闭 3 年前。 在下面的 C++ 片段中, 如何基于 TwoInts 结构中的
#include struct Header { unsigned long long int alignment; }; int main(void) { struct Heade
我有一个目前看起来像这样的结构(缩写为仅显示基本部分): typedef struct { uint32_t baudrate; ... some other internally u
对此没有太多解释,这就是我所拥有的: public struct PACKET_HEADER { public string computerIp; publi
我有以下代码: struct MyStruct{ data: &'a str, } fn get(S: &'a MyStruct) -> &'a str{ S.data } fn se
struct S1 { char c; int i; }; struct S3 { char c1; struct S1 s; double c2; }; 我正
我有一个名为 Parameter 的协议(protocol): protocol Parameter { var name: String { get } var unit: Unit
有 2 个 struct 定义 A 和 A。我知道 struct A 可以包含指向 struct A 的 POINTER 但我不明白为什么 struct A 不能包含struct A(不是指针) 最佳
我有以下代码: struct MyStruct{ data: &'a str, } fn get(S: &'a MyStruct) -> &'a str{ S.data } fn se
为了说明这一点,这里有一个小的不可变结构和一个更新它的函数: (struct timeseries (variable observations) #:transparent) (define (ad
我是一名优秀的程序员,十分优秀!