我在Visual C ++中完美地运行了以下代码顺序搜索
#include<iostream>
using namespace std;
int seqSearch(int list[], int length, int item)
{
int index = length-1;
if (index < 0)
return -1;
if (list[index] == item)
return (index);
else seqSearch(list, index, item);
} // end seqSearch
int main ()
{
int const length = 10;
int item;
int list[10] = { 2, 3, 4, 5, 20, 40, 80, 45, 99, 0};
cout << "Please enter the value to be searched: ";
cin>> item;
if (seqSearch(list, length, item) == -1) cout << "Item not found." << endl;
else cout <<"Item found at position: " << seqSearch(list, length, item) << " of list *Note: (first index of list start at 0)" << endl;
system("pause");
return 0;
}
但在Dev-C ++中它始终显示结果0,我试图调试并看到索引是正确的,但为什么它显示0?为什么我们在VC ++和Dev-C ++之间存在这种差异?
答案 0 :(得分:5)
函数int seqSearch
有一个代码路径,else seqSearch(list, index, item);
没有返回任何内容。将此更改为else return seqSearch(list, index, item);
可以解决问题。
现在深入挖掘。
来自n2960草稿:
§6.6.3/ 2
离开函数末尾相当于没有值的返回;这会导致值返回函数中的未定义行为。
因此,根据标准,这是一种未定义的行为。
深入挖掘:
检查所有代码路径以确定它们是否都返回是一项困难的操作,并且不需要实现来检查它。
这是架构和calling convention依赖。请尝试以下代码:
#include <iostream>
int fun (int v)
{
int a = v;
}
int main ()
{
std::cout << fun(5) << std::endl;
}
在不同的编译器上,函数fun
返回0
或传递给它的任何值。基本上它可以返回最后一次计算表达式的值。
答案 1 :(得分:3)
正确的方法定义应该是
int seqSearch(int list[], int length, int item)
{
int index = length-1;
if (index < 0)
return -1;
if (list[index] == item)
return (index);
else return seqSearch(list, index, item);
}
你错过了退货声明。理想情况下,编译器应警告您,但我不太熟悉Dev-Cpp使用的版本。