#include “stdafx.h” #include<iostream> using namespace std; int Vac=3; int _tmain(int argc, _TCHAR* argv[]) { int Vac=10; Vac++; cout<<::Vac<<endl; cout<<Vac<<endl; return 0; }
输出:4 10
#include<iostream>
#include<string>
using namespace std;
string s1="hello";
int main()
{
string s2="world";
cout<<s1<<" "<<s2<<endl;//hello world
int s1=42;
cout<<s1<<" "<<s2<<endl;//42 world
cout<<::s1<<" "<<s2<<endl;//hello world
return 0;
}
这是程序员面试宝典里的一道题。
int i=1,j=2;
int k=i+++j;
cout<<k<<endl;//3
cout<<i<<endl;//2
cout<<j<<endl;//2
注意(++)和+的结合顺序,先执行i+j,完了再执行i++
#define product(x)(x*x)
int main()
{
int i=3,j,k;
j=product(i++);
cout<<i<<endl;//5
k=product(++i);
cout<<i<<endl;//7
cout<<j<<k<<endl;//9 49
return 0;
}
define的用法参考:程序员面试宝典
还有一个整数自动转换原则的题。参考:http://www.diybl.com/course/3_program/c/c_js/2007918/71846.html
有符号数与无符号数之间运算问题
以下实验均在virual c++6中运行通过
这个问题测试是否懂得C语言中的整数自动转换原则,有些开发者懂得极少这些东西。当表达式中存在有符号类型和无符号类型时所有的操作数都自动转换为无符号类型。因此,从这个意义上讲,无符号数的运算优先级要高于有符号数,这一点对于应当频繁用到无符号数据类型的嵌入式系统来说是丰常重要的。
首先进行一个实验,分别定义一个signed int型数据和unsigned int型数据,然后进行大小比较:
unsigned int a=20;
signed int b=-130;
a>b?还是b>a?实验证明b>a,也就是说-130>20,为什么会出现这样的结果呢?
这是因为在C语言操作中,如果遇到无符号数与有符号数之间的操作,编译器会自动转化为无符号数来进行处理,因此a=20,b=4294967166,这样比较下去当然b>a了。
再举一个例子:
unsigned int a=20;
signed int b=-130;
std::cout<<a+b<<std::endl;
结果输出为4294967186,同样的道理,在运算之前,a=20,b被转化为4294967166,所以a+b=4294967186
减法和乘法的运算结果类似。
如果作为signed int型数据的b=-130,b与立即数之间操作时不影响b的类型,运算结果仍然为signed int型:
signed int b=-130;
std::cout<<b+30<<std::endl;
输出为-100。
而对于浮点数来说,浮点数(float,double)实际上都是有符号数,unsigned 和signed前缀不能加在float和double之上,当然就不存在有符号数根无符号数之间转化的问题了。
发现这些细节都不清楚。
今天的文章程序员面试宝典_IT面试常问的技术问题分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/74941.html