c-error:pthread rw_lock中"{"标记之前应为表达式



所以我有一个数据结构中的节点的代码,这个节点有一个读写锁在使用pthread_rwlock_t rwlock=pthread_RWLLOCK_INITIALIZER之前;

问题是由于某种原因,它给出了一个错误,说它在PTHREAD_RWLOCK_INITIALIZER之前应该有一个表达式,我不明白它是什么,因为我知道我没有遗漏任何表达式;

代码:

#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include "state.h"
#include <pthread.h>
typedef struct inode_t {    
type nodeType;
union Data data;
// ******************NEW ATTRIBUTE THAT INLCUDES THE LOCK *******************************
pthread_rwlock_t lock;
} inode_t;
void inode_table_init() {
for (int i = 0; i < INODE_TABLE_SIZE; i++) {
inode_table[i].nodeType = T_NONE;
inode_table[i].data.dirEntries = NULL;
inode_table[i].data.fileContents = NULL;
// ****************** NEW *******************************
// Initializes the lock
pthread_rwlock_init(&inode_table[i].lock ,NULL);
inode_table[i].lock = PTHREAD_RWLOCK_INITIALIZER;
}
}
int inode_create(type nType) {
/* Used for testing synchronization speedup */
insert_delay(DELAY);
for (int inumber = 0; inumber < INODE_TABLE_SIZE; inumber++) {
if (inode_table[inumber].nodeType == T_NONE) {
inode_table[inumber].nodeType = nType;

pthread_rwlock_init(&inode_table[inumber].lock ,NULL);
inode_table[inumber].lock = PTHREAD_RWLOCK_INITIALIZER;
if (nType == T_DIRECTORY) {
/* Initializes entry table */
inode_table[inumber].data.dirEntries = malloc(sizeof(DirEntry) * MAX_DIR_ENTRIES);

for (int i = 0; i < MAX_DIR_ENTRIES; i++) {
inode_table[inumber].data.dirEntries[i].inumber = FREE_INODE;
}
}
else {
inode_table[inumber].data.fileContents = NULL;
}
return inumber;
}
}
return FAIL;
}

这个函数做什么并不重要,重要的是我在初始化锁的行中出现了一个奇怪的错误

错误:

fs/state.c: In function ‘inode_table_init’:
fs/state.c:34:31: error: expected expression before ‘{’ token
inode_table[i].lock = PTHREAD_RWLOCK_INITIALIZER;
^
fs/state.c: In function ‘inode_create’:
fs/state.c:81:41: error: expected expression before ‘{’ token
inode_table[inumber].lock = PTHREAD_RWLOCK_INITIALIZER;

任何帮助都将不胜感激。

您不需要这些赋值。来自POSIX规范:

在默认读写锁属性合适的情况下,宏PTHREAD_RWLOCK_INITIALIZER可用于初始化静态分配的读写锁。除了不执行错误检查之外,该效果等效于通过调用参数attr指定为NULLpthread_rwlock_init()进行的动态初始化。

您只能在变量初始化中使用它,而不能在赋值中使用它。由于它相当于以前在线路上的呼叫,即使它有效,它也是多余的。

最新更新