开发者

A simple question about type coercion in C++

开发者 https://www.devze.com 2023-01-01 13:10 出处:网络
Given a function prototype, and a type definition: int my_function(unsigned short x); typedef unsigned short blatherskite;

Given a function prototype, and a type definition:

int my_function(unsigned short x);
typedef unsigned short blatherskite;

Is the following situation defined by standard:

int main(int argc, char** argv) {
  int result;
  blatherskite b;

  b=3开发者_如何学Go;
  result = my_function(b);
}

Do I get type coercion predictably via the function prototype?


If your question is really about whether the types of the argument and the parameter match, then the answer is yes. typedef does not introduce a new type, it only creates alias for an existing one. Variable b has type unsigned int, just like the parameter, even though b is declared using typedef-name blatherskite.

Your example is not very good for demonstrating that though. All integral types are convertible to each other in C++, so (ignoring range issues) the code would have defined behavior even if blatherskite designated a different type (a new type). But it doesn't. So this is also perfectly valid

void foo(unsigned int* p);
...
blatherskite *pb = 0;
foo(pb); // <- still valid


No type coercion is needed. The typedef is just an alias for the same type, so you're passing an unsigned short to a function that takes an unsigned short.

0

精彩评论

暂无评论...
验证码 换一张
取 消