C++省略返回类型
C++ omitting return type
这是我的测试代码,我没有给函数一个返回值,但是为什么这段代码可以通过编译器呢?我想知道如果我不像下面这样为一个函数提供显式返回类型,编译器将生成什么?
这是测试代码,谢谢。
#include <iostream>
#include <vector>
using std::vector;
vector<vector<int> > testReturn(){
int test = 5;
}
int main(){
testReturn();
return 0;
}
您不能总是信任编译器,因为不同的编译器在编译时具有不同的检查条件。如果您没有返回需要返回的函数,即使编译成功,结果也是未定义的。这就是程序崩溃的原因。您应该始终尝试避免这种情况。
这是一个不正确的代码,会产生未定义的行为。
这样的代码(带有返回类型位而没有实际返回语句的函数)确实使用某些编译器在某些变体中进行编译。但是,这只意味着编译器中存在一个错误,它应该给出警告/错误。
我没有给函数一个返回值,但是为什么这段代码可以通过编译器传递?
在 C 中提供 return
值是可选的。此规则也"迁移"到C++,添加到一长串未定义的行为(即允许编译无效程序的情况)中。C++值得称赞的是,编译器确实以相当明确的术语警告您此类情况。
我想知道如果我不像下面这样为一个函数提供显式返回类型,编译器将生成代码是什么?
编译器不会生成任何用于处理返回值的代码。无论 CPU 寄存器和右大括号处的内存的任意状态是什么,这就是将要"返回"的状态。尝试将任意值解释为返回值会导致崩溃。
代码不编译,因为返回类型testRunner
是整数向量的向量。
所以归还它!
相关文章:
- 如何获取std::result_of函数的返回类型
- 奇怪的结构&GCC&clang(void*返回类型)
- 如何建立使用模板函数的lambda函数的尾部返回类型
- 为什么与常规GCC不同,即使有"学究性错误",MinGW-GCC也能容忍丢失的返回类型
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 函数作为模板参数,是否对返回类型强制约束
- C++中函数的向量返回类型引发错误
- 检查函数返回类型是否与STL容器类型值相同
- 为什么返回类型中需要typename?C++
- <Windows>为什么 std::thread::native_handle 返回类型为"long long unsigned int"的值,而不是 void*(又名 HANDLE)?
- 警告:在函数返回类型 [-Wignore 限定符] 时忽略类型限定符
- 为什么 c++(g++) 不允许模板返回类型和函数名称之间有空格?
- 为什么返回类型的'const'限定符对标有 __forceinline/内联的函数没有影响?
- 推导 std::vector::back() 的返回类型
- 在 c++ 中将函数返回类型指定为模板参数
- 使用 SWIG 更改生成的 CS 函数中的返回类型
- QtQuick - qml:28:错误:未知方法返回类型:自定义类型
- 基于返回类型的转换和过载扣除
- 当返回类型声明为 ListNode 时,我们是否可以返回 false<T>*