c - 错误: expected declaration specifiers or ‘...’ before ‘lessthen_predictable_t?

标签 c

按照本教程操作: http://www.jamesmolloy.co.uk/tutorial_html/7.-The%20Heap.html

我有以下错误:

source/ordered_array.c: In function ‘insert_ordered_array’:
source/ordered_array.c:43:67: error: expected identifier before ‘[’ token
source/ordered_array.c:43:67: error: too few arguments to function ‘array->less_than’
make: *** [obj/ordered_array.o] Error 1

来 self 的编译器。我没有得到任何信息,因为我完全按照教程进行操作。

以下是关联的文件:

ordered_array.h:

// ordered_array.h -- Interface for creating, inserting and deleting
//                    from ordered arrays.
//                    Written for JamesM's kernel development tutorials.

#ifndef ORDERED_ARRAY_H
#define ORDERED_ARRAY_H

#include "common.h"

/**
   This array is insertion sorted - it always remains in a sorted state (between calls).
   It can store anything that can be cast to a void* -- so a u32int, or any pointer.
**/
typedef void* type_t;
/**
    A predicate should return nonzero if the first argument is less than the second.  Else 
    it should return zero.
**/
typedef s8int (*lessthan_predicate_t)(type_t,type_t);
typedef struct
{
    type_t *array;
    u32int size;
    u32int max_size;
    lessthan_predicate_t less_than;
} ordered_array_t;

/**
   A standard less than predicate.
**/
s8int standard_lessthan_predicate(type_t a, type_t b);

/**
   Create an ordered array.
**/
ordered_array_t create_ordered_array(u32int max_size, lessthan_predicate_t less_than);
ordered_array_t place_ordered_array(void *addr, u32int max_size, lessthan_predicate_t  less_than);

/**
   Destroy an ordered array.
**/
void destroy_ordered_array(ordered_array_t *array);

/**
   Add an item into the array.
**/
void insert_ordered_array(type_t item, ordered_array_t *array);

/**
   Lookup the item at index i.
**/
type_t lookup_ordered_array(u32int i, ordered_array_t *array);

/**
   Deletes the item at location i from the array.
**/
void remove_ordered_array(u32int i, ordered_array_t *array);

#endif // ORDERED_ARRAY_H

ordered_arrays.c:

// ordered_array.c -- Implementation for creating, inserting and deleting
//                    from ordered arrays.
//                    Written for JamesM's kernel development tutorials.

#include "ordered_array.h"

s8int standard_lessthan_predicate ( type_t a, type_t b )
{
return ( a < b ) ? 1:0;
}

ordered_array_t create_ordered_array ( u32int max_size, lessthan_predicate_t less_than     )
{
ordered_array_t to_ret;
to_ret.array = ( void* ) kmalloc ( max_size * sizeof ( type_t ) ) ;
memset ( to_ret.array, 0, max_size*sizeof ( type_t ) );
to_ret.size = 0;
to_ret.max_size = max_size;
to_ret.less_than = less_than;
return to_ret;
}

ordered_array_t place_ordered_array ( void *addr, u32int max_size, lessthan_predicate_t   less_than )
{
ordered_array_t to_ret;
to_ret.array = ( type_t *) addr;
memset ( to_ret.array, 0, max_size*sizeof ( type_t ) );
to_ret.size = 0;
to_ret.max_size = max_size;
to_ret.less_than = less_than;
return to_ret;
}

void destroy_ordered_array ( ordered_array_t *array )
{
// kfree ( array -> array );
}

void insert_ordered_array ( type_t item, ordered_array_t *array )
{
ASSERT ( array -> less_than );
u32int iterator = 0;
---------------------------------------Faulting Line------------------------------------
while ( iterator < array -> size && array -> less_than ( array ->[iterator], item )    )
----------------------------------------------------------------------------------------

    iterator++;
if ( iterator == array -> size ) // just add at the end of the array.
    array -> array [array -> size++] = item;
else
{
    type_t tmp = array -> array[iterator];
    array -> array[iterator] = item;
    while ( iterator < array -> size )
    {
        iterator++;
        type_t tmp2 = array -> array[iterator];
        array -> array[iterator] = tmp;
        tmp = tmp2;
    }
    array -> size++;
}
}

type_t lookup_order_array ( u32int i, ordered_array_t *array )
{
ASSERT ( i < array -> size );
return array -> array [i];
}

void remove_ordered_array ( u32int i, ordered_array_t *array )
{
while ( i < array -> size )
{
    array -> array[i] = array -> array[i+1];
    i++;
}
array -> size--;
}

知道我为什么会收到编译错误吗?

最佳答案

lessthen_predictable_t 未在任何地方定义。

数组 ->[迭代器] 是错误的。猜测它可能应该是 array->array[iterator]

关于c - 错误: expected declaration specifiers or ‘...’ before ‘lessthen_predictable_t?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10097921/

相关文章:

c - 如何在 python 中使用 struct 模块解压缩字节?

c - GCC 中的 -D__USE_FIXED_PROTOTYPES__ 有什么用?

c - C语言编程中使用结构体时出现错误

c - 在 C 中,我的函数输出总是 0.000000。是不是因为两个输入都是int?

c - 重用 linux 抽象命名空间套接字

使用 const 转换调用带有 const 矩阵参数的 c 函数

C 判断 "un-flattened"第i个元素在n维数组中的 "flattened"位置

c - fork() 会创建别名吗?

javascript - 将 SQL 行拆分为两行并正确构建

c++ - 如何将多个包裹一起寄送?