关于返回和参数类型的混乱
Confusion about return and parameter types
我真的是C 的新手,只是在尝试一些代码,而我似乎没有得到任何代码:
#include<iostream>
using namespace std;
int f (const long& i) {
return i+1;
}
void g (long& i) {
f (i);
}
int main () {
long la = 0;
int a = 0;
int b = f (a);
long c = f (7);
la = f (la);
cout << "la = " << la << " a = " << a << endl;
cout << "b = " << b << " c = " << c << endl;
}
所以我没有得到的:为什么函数f接受类型int的变量?A显然不是很长的,但它仍然接受。我不明白。另外,由于f的返回类型是int,它是否会自动从长时间到int施放返回结果?我真的不明白这里发生了什么。
使用所谓的常规算术转换用于参数。类型int
的对象被隐式转换为long
类型,因为类型long
的等级大于类型int
的等级。这是类型long
的对象,可以容纳int
类型的任何值。
至于返回类型,因此可以获得无效的结果,因为不需要类型int
的对象可以容纳long
类型的值。
考虑到,如果您不希望该函数接受类型INT作为参数的对象,则可以用删除的类型int
的参数定义相应的函数。
例如
#include <iostream>
int f (const long& i) {
return i+1;
}
int f( const int & ) = delete;
int main()
{
int a = 0;
f( a );
return 0;
}
程序不编译,因为带有类型int
参数的函数定义为已删除。
c 允许某些类型之间的隐式转换。所有数值内置类型均可互相转换,因此编译器可以自由进行INT/Long/Short/Short/Long及其未签名的等效之间的任何转换。有关类型转换的更多信息,请参见CPPReference
相关文章:
- 扩展C++生成的代码的模板参数类型名称
- 如何在 c++ 中定义接受不同参数类型的函数向量?
- 在 C++ 中运行时调用模板时,是否可以切换模板的参数类型?
- 将函数参数类型声明为 auto
- 将函数的参数 - 签名从使用 'std::function<T>' 转换为模板参数类型
- 在 C++17 中调用具有不同参数类型的构造函数
- 具有先前参数类型匹配的参数包
- 我想知道为什么"std::unique_ptr<int> foo(新 int)"是合法的,因为"std::<int>unique_ptr"要求输入参数类型应该是"int"?
- 将可变参数类型列表的扩展打包为复杂类型的初始值设定项列表 - 合法吗?
- MSVC 错误:4 个重载中的任何一个都无法转换所有参数类型
- 使用constexpr + auto作为返回和参数类型的奇怪类型推导
- 如何从第一个参数推断第二个参数类型?
- C++模板函数中,指定回调函子/lambda 的参数类型,同时仍允许内联?
- 如何用不同的参数类型和数字回调函数
- C++stoi:这两个重载都无法转换所有参数类型
- 为什么std::{container}::template不能推导其参数类型
- 为模板参数类型中的新对象分配内存
- 为指向成员模板参数的指针推导额外模板参数类型的紧凑方式
- 使用std::conditional中的模板来确定函数参数类型
- C++中的短参数类型