- 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/
例如,如果我的程序名称是 test.c 然后对于以下运行命令,argc = 2 而不是 4。 $test abc pqr* *xyz* 最佳答案 尝试运行: $ echo abc pqr* *xyz*
我正在尝试使用一个容器来显示TextField,但是该容器不喜欢我的操作顺序。这是我的代码: Widget build(BuildContext context) { return Scaffol
我有以下代码: class MetricGoogleGateway extends AMetricGateway{ constructor(id, name, token) {
我像这样调用下面的对象方法。 new Cout( elem1 ).load( 'body' ) new COut( elem1 ).display( 'email' ) 我一次只使用一个实例。因为我一
我正在尝试使用 C++11 中的可变参数函数模板,并通过如下代码了解了基本思想: void helper() { std::cout void helper( T&& arg ) {
在学习 ExtJS 4 时,我发现在定义一个新类时,在 initComponent 中方法可以使用 this.callParent(arguments) 调用父类的构造函数. 我想知道这个 argum
使用 XCode 9,Beta 3。Swift 4。 statsView.createButton("Button name") { [weak self] Void in //stuff st
以下代码将打印1: (function (arguments) { console.log(arguments); }(1, 2)); 实际上,arguments 对象已被覆盖。是否可以恢复函
/** * @param $name * @return Response * @Route ("/afficheN/{name}",name="afficheN") */ public fu
我习惯使用Scala scopt用于命令行选项解析。您可以选择参数是否为 .required()通过调用刚刚显示的函数。 如何定义仅在定义了另一个参数时才需要的参数? 例如,我有一个标志 --writ
所以这是我的代码: def is_valid_move(board, column): '''Returns True if and only if there is an o
我试图在这里运行此代码: threads = [threading.Thread(name='ThreadNumber{}'.format(n),target=SB, args(shoe_type,m
在静态类型函数编程语言(例如 Standard ML、F#、OCaml 和 Haskell)中,编写函数时通常将参数彼此分开,并通过空格与函数名称分开: let add a b = a + b
function validateArguments(args) { if(args.length 2) { throw new RangeError("Invalid amo
我正在使用 Django 1.5 并尝试将参数传递到我的 URL。当我使用前两个参数时,下面的代码工作正常,使用第三个参数时我收到错误。我已经引用了新的 Django 1.5 更新中的 url 用法,
我刚刚开始使用 ember js 并且多次被这个功能绊倒 有人可以简要介绍一下 this._super() 的使用,并解释 ...arguments 的重要性 谢谢 最佳答案 每当您覆盖类/函数(例如
这个问题在这里已经有了答案: How to fix an "Argument passed to call that takes no arguments" error? (2 个答案) 关闭 3
我正在创建一个简单的登录注册应用程序。但是我遇到了错误,我不知道如何解决,请帮忙!这是我的代码: // // ViewController.swift // CHLogbook-Applicati
我是 Swift 的初学者。我尝试创建一个表示 Meal 的简单类。 它有一些属性和一个返回可选的构造函数 但是当我尝试测试它或在任何地方实例化它时,我得到的只是一个错误。似乎无法弄清楚发生了什么。
我有一个在特殊环境下运行其他程序的系统程序: cset shield -e PROGRAM .现在要运行一个 java 程序,我输入了 cset shield -e java PROGRAM ,但这不
我是一名优秀的程序员,十分优秀!