- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我收到如下错误
$ gcc -o app llistdriver.c llistlib.c -Wall
llistdriver.c:7: warning: return type defaults to `int'
llistdriver.c: In function `printinsts':
llistdriver.c:15: warning: control reaches end of non-void function
llistlib.c: In function `insert':
llistlib.c:25: warning: statement with no effect
llistlib.c:41: warning: control reaches end of non-void function
/tmp/ccqYmK3M.o:llistdriver.c:(.text+0x157): undefined reference to `_search'
collect2: ld returned 1 exit status
我无法弄清楚为什么会收到此错误消息,因为我已经编写了一个包含链接列表方法的库文件。
int search( struct node *front, int val)//
{
while(front != NULL)
{
if( front->modmark == val ) //this is to find the value
return 1; // found it
front=front->next;
}
return 0; // Not found
}
我认为它提示主文件中的唯一引用
case 5:
printf("please enter a search value?\n");
scanf("%i",&mark);
choice = search(first,mark);//here
if (choice == -1)
{
printf("the modmark was not found\n");
}
else
{
printf("the first occurence of the mark is at the %i th index of the list",choice);
};
break;
first 和 mark 是这样定义的变量
struct node *first;
int mark = 0;
对此的任何帮助将不胜感激,我花了几个小时尝试调试此错误。编写 C 代码是我目前生活中的烦恼。
Ps我已经检查了lliSTLib.c文件和llistdriver.c文件中包含的所有#include“lliSTLib.h”。
好吧,也许这会让事情变得更清楚
//lliSTLib.c - 实现 liSTLib.h 文件中定义的函数的库 #包括 #包括 #include“lliSTLib.h”
void initialise(struct node **ps)
{
printf("initialise function\n");
*ps = NULL; //initialise list to empty
}
int insert(struct node **fn)
{
printf("insert function\n");
struct node *newnode;
newnode = (struct node*) malloc(sizeof (struct node)); //make new node and give it memory
if (newnode == NULL) //if fsiled return to the program saying it failed
return -1;
if (*fn == NULL) // for the first of the list
{
newnode -> next == NULL; // sets the next value to nothing
printf("what mark do you want to enter\n");
scanf("%i",&newnode -> modmark); // this gets the modmark
*fn = newnode; //the head of the list is set to the new node
}
else
{
newnode -> next = *fn; // sets the newnodes next value to the head node
printf("what mark do you want to enter\n");
scanf("%i",&newnode -> modmark); // gets the modmark
*fn = newnode; // the head becomes the new node
printf("%p %i",newnode,newnode->modmark); // just for debugging
}
}
void traverse(struct node *ps)
{
if (ps != NULL) // if the current node is null
{
printf("%p - %i\n",ps,ps -> modmark);
traverse(ps -> next);
}
else
{
printf("your list is empty\n");
}
}
void delete(struct node **dn)
{
printf("delete function\n");
struct node *delnode;
delnode = *dn; //sets the head node so that it can be deleted later
if (delnode != NULL)
{
*dn = delnode -> next; // sets the head to the next node
free(delnode); //deletes the previous head node
}
}
void finish(struct node **ps) //this function goes through the list and removes all items
{
printf("finish function\n");
struct node *finishnode;
finishnode = *ps;
while (finishnode != NULL)
{
*ps = finishnode -> next;
free(finishnode);
finishnode = *ps;
}
int search(struct node *front,int val)
{
while(front != NULL)
{
if( front->modmark == val ) // Assuming struct node has val member which you are trying to compare to
return 1; // found it
front=front->next;
}
return 0; // Not found
}
}
然后llistdriver.c文件是
#include <stdio.h>
#include <stdlib.h>
#include "llistlib.h"
printinsts()
{
printf("Enter:- \n");
printf("\t0 to exit\n");
printf("\t1 to initialise list\n");
printf("\t2 to insert item at front of list\n");
printf("\t3 to delete item from front of list\n");
printf("\t4 to traverse list\n");
printf("\t5 to search through the list\n");
}
int main()
{
int choice;
struct node *first;
int mark = 0;
printinsts();
scanf("%d",&choice);
while (1)
{
switch (choice)
{
case 0 : finish(&first);
exit(0);
break;
case 1 : initialise(&first);
break;
case 2 : if (insert(&first)== -1)
{
printf("insert not successful");
choice = 0;
};
break;
case 3 : delete(&first);
break;
case 4 : traverse(first);
break;
case 5:
printf("please enter a search value?\n");
scanf("%i",&mark);
choice = search(first,mark);
if (choice == -1)
{
printf("the modmark was not found\n");
}
else
{
printf("the first occurence of the mark is at the %i th index of the list",choice);
};
break;
default : printf("Invalid choice of %d \n", choice);
}; // end of switch
printinsts();
scanf("%d", &choice);
} // end of while
}
头文件 lliSTLib.h 读取为
struct node {
int modmark;
struct node *next;
};
void initialise(struct node **ps);
int insert(struct node **fn);
void traverse(struct node *ps);
void delete(struct node **dn);
void finish(struct node **ps);
int search(struct node *front,int val);
我还没有在任何代码中发现明显的问题
最佳答案
只需将 lliSTLib.h
包含在 lliSTLib.c
文件中,如下所示:
#include“lliSTLib.h”
并使用以下命令进行编译:
gcc -o app llistdriver.c lliSTLib.c
希望这有帮助...
关于c - 为什么我在 C 中实现单链表时遇到 undefined reference 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13984765/
我想在 java 中声明一个对象,就像在 C++ 中指向指针的指针,让我给你看一个例子: //*** At the application startup //Initialize a setting
考虑这段代码, struct A {}; struct B { B(const A&) {} }; void f(B) { cout << "f()"<
我正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试过的
我目前正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试
这个问题在这里已经有了答案: Add managed DLL dependencied to unmanaged C++ project (1 个回答) 关闭 6 年前。 我有这样一个场景: 使用
这是一个常见问答的集合,这也是一个社区维基,所以每个人都被邀请参与维护它。。正则表达式正在遭受给我ZE代码类型的问题和没有解释的糟糕答案。此参考旨在提供指向质量问答的链接。。此参考适用于以下语言:PH
我正在尝试在方案中模拟堆栈。我正在使用 DrScheme 并选择语言 R5RS。我需要创建 pop、push 和 peek 的函数。但我无法弄清楚如何通过引用传递。我已经阅读了一些关于盒子的信息,但是
我陷入了这个错误。我将代码部署在生产服务器上,它在端口 80 上运行。当我尝试登录管理页面时。如图所示,它给了我 403 错误。 可能是什么原因?我的 Django 代码或 nginx 配置有问题吗?
这是一段简单的 C++ 代码: A foo(){ A a; // create a local A object return a; } void bar(const A & a_r){ }
我正在使用从 torrenteditor 获取的 php 脚本来创建 torrent 文件,但是当我使用指定的方法创建新的 torrent 文件时,torrent 文件被创建但我收到很多通知。,就像这
MySQL: REFERENCES vs FOREIGN KEY + REFERENCES 我认为 REFERENCES 是更冗长的 FOREIGN KEY REFERENCES 语法的某种速记语法。
我想使用基于另一个方法引用的方法引用。这有点难以解释,所以我给你举个例子: Person.java public class Person{ Person sibling; int a
Java/C# 语言律师喜欢说他们的语言通过值传递引用。这意味着“引用”是在调用函数时复制的对象指针。 同时,在 C++ 中(以及在 Perl 和 PHP 中更动态的形式),引用是某个其他名称(或动态
当我需要实现递归 lambda 时,通常我这样做: auto factorial = [](auto& self, int n) -> int { return n == 0 ? 1 : n
我目前正在研究 DDD ,需要一些启发。 我有两个实体 Temple TempleVariant Temple(听筒)包含基本信息(名称,描述等),并具有n个变体,它们具有技术描述(CAD绘图,尺寸,
在 Grails 中 belongsTo允许一个域类与另一个域类建立级联关系。使用belongsTo时有两种类型的关系:引用和无引用。 Reference 在拥有的对象上创建属性,而 No Refer
我正在使用 AWS 和 Django Rest Framework 开发 Web 应用程序。(Django:v1.8,DRF:v3) 我一直在为 POST 多部分表单请求获取 django.reque
我按照下面的定义公开了 WCF 端点, 当我在 .NET 3.5 中添加“服务引用”时,我们在代理中获得了以下类,这非常好: [Syst
我在玩 constexpr 引用时产生了这种感觉。但问题本身与 constexpr 无关,只是被它揭示。 我们知道有“指向const的指针”,也有“const指针”。顺便说一句,由于后者的使用比前者少
我有 2 种类型的 refences,它们中的每一种都可以正常工作。 我尝试使用每一个并在 project build 中得到相同的结果。 请向我解释 COM 引用和引用之间的区别。 谢谢你。 最佳答
我是一名优秀的程序员,十分优秀!