技术派-程序员常见基础面试题
1、请问:下面表达式是true还是false?
double a = 0.8;
double b = 0.7;
double c = 0.6;
bool flag = (a-b) == (b-c);
是用纯数学思维去思考,a-b=0.1,b-c=0.1,两者是相等的,因为数学表述是最精确最严谨的。但是,物理元件上是用有限的64位存储位去存储double型的,存的是近似值。固定格式:1个sign位,11个阶码位,52个有效位。
我们再把这三个数的二进制形式转换出来(注意计算机用的是补码形式)
0.8=1100 1100 1100 1100.......无限循环...需要截断
0.7=10 1100 1100 1100............无限循环...需要截断
0.6=1001 1001 1001 1001 ....无限循环...需要截断
然后一直算到保留52位,然后你再算,你会发现,两者相减,误差相差3.1*10^(-16)。
所以:答案应该是false
2、请问:下面表达式是true还是false?
float a = 0.125f;
double b = 0.125;
bool flag1 = 0==(a-b) ;
bool flag2 = 0.0==(a-b) ;
由于受到上面题目的迷惑,所以这一题一下子就在true和false摇摆不定了。特别这里一个是float,一个是double,float固定格式是1位sign+8位阶码位,23个有效位。
其实,万变不离其宗,看二进制。
0.125=(0.001)B,有限不循环数,它是精确数,而不是近似值。
(0.001)B-(0.001)B=(0.00)B,也是精确值。
而且,0.0与0,所有存储位也全部都是0.
所以,这两个表达式,其实都是true。
3、表达式 1.0/0,请问下面结果应该选择谁?
A: 编译出错,0不能做分母, B: Infinity C: NAN(Not a number)
不同语言不同编译器的实现细节不一样,如果是C++语言用微软的msvc的编译器,编译时就会报错,提示被零除或被零取模。如果是java语言用javac编译器编译通过的,而且定义:浮点数运算时,当分母为0时只要分子不为0,结果均为无穷,分子为0时结果均为NAN。整数运算时,分母不能为0否则抛出算术异常。
所以,如果当C/C++时,答案选A, 如果是java,答案选B
3、请问下面调用,应该选择谁?
[JAVA]void f(String s){} 或者 [JAVA]void f(char *s){}
void f(Integer i){}
调用:f(null);
A: 前者, B 后者 C 报错
首先要明白null的定义,0,或(void*)0,
注意它们的区别:值0,地址0
而上述既可以看成是空字符串,也可以看成是整数0,所以出现混淆。所以才有了C++11之后新增加的nullptr空指针,用于区分。
所以答案应该是C,报错。
4、JAVA语言下,请问下面调用,是应该调用哪个?
void g (Integer i){}
void g (double i){}
调用: g(1);
A: 前者, B 后者 C 报错
首先要审题,JAVA下面,int与Integer是有本质区别的,int是基本数据类型,而Integer是extends的Object的类。g(1)调用参数1,是整形,基本类型。调用时候匹配谁。先匹配基本类型。这里基本类型只有double。所以这里应该调用参数为double的那个。即便是在C/C++下面,也依然是匹配基本数据类型。
所以本题答案是B,调参数double的函数
5、JAVA语言下,请问下面调用,选哪个?
String a = null;
switch (a)
{
}
A: 走null分支, B:"null"分支
C: 走0分支 D: 直接抛出异常
JAVA中表面上支持字符串型的switch,但是本质却是用的String.hashCode()转换成了整型值。换句话说:所谓的字符串型switch本质依然是整型值的switch。
然而本题换个写法就是:null.hashCode(),这明显就会出现空指针异常。
所以本题,明显就应该选择D,直接抛出NullPointerException。
6、请问下面哈希表,resize了几次?
import java.util.HashMap;
HashMap<Integer, Integer> a=new HashMap<Integer, Integer>(10000);
for (Integer i = 0; i < 10000; i++) a.put(i, i);
A: 1次 B:2次: C: 0次
HashMap以数组+链表+红黑树组合而成,一般会在数量达到原来数量之后才会去扩容,总是以上一次大小的2倍扩容机制——也就是2次幂扩容机制。前提是:超过之后才会resize。本题刚刚装满,并未超出。
所以本题答案是C:0次。如果再多一次put,那么则会resize一次。
技术派-程序员常见基础面试题相关推荐
- Java程序员必备基础面试题
java技术再高而羞于展示无疑是浪费了满身的才华.学会沟通, 学会推荐自己,将是对工作最有力的助益.学会以简练扼要的语言,清晰明确的沟通方式,将复杂的问题简单化,并进一步提出精准到位的解决方案.以此行 ...
- 黑马 程序员——Java基础---IO(下)
黑马程序员--Java基础---IO(下) ------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------ 一.概述 Java除了基本的字节流.字符流之外,还提供 ...
- 任务分配算法c语言程序,程序员算法基础——贪心算法
原标题:程序员算法基础--贪心算法 前言 贪心是人类自带的能力,贪心算法是在贪心决策上进行统筹规划的统称. 比如一道常见的算法笔试题跳一跳: 有n个盒子排成一行,每个盒子上面有一个数字a[i],表示最 ...
- C/C++程序员应聘常见面试题深入剖析
为什么80%的码农都做不了架构师?>>> C/C++程序员应聘常见面试题深入剖析 1.引言 本文的写作目的并不在于提供C/C++程序员求职面试指导,而旨在从技术上分析面试题的内 ...
- 【编码错误】新手程序员常见的编码错误
新手程序员常见的编码错误 文章目录 前言 一.没有了解需求就开始写代码 二.不沟通交流就开始做需求 三.代码素养差 四.编码问题总结 4.0不注重代码格式 4.0.1空格 4.0.2换行 4.1随意命 ...
- 程序员常见英文缩写及其意义
在网上看到这两篇文章,有关于程序员需要了解的常见英文缩写以及意义,感觉挺有意思的,就载了下来.感谢原作者的分享. 1. API 应用程序接口(英语:Application Programming In ...
- 黑马 程序员——Java基础---流程控制
黑马程序员--Java基础---流程控制 ------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------ 一.概述 Java提供了两种基本的流程控制结构:分支结构 ...
- 匹配正则_程序员入门基础:python正则表达式贪婪匹配和非贪婪匹配
此文为python正则表达式的高阶入门,正则基础入门请参考程序员入门基础:python的正则表达式. 一.贪婪匹配和非贪婪匹配 举例说明概念: print('非贪婪匹配',re.search('el+ ...
- 程序员常见700单词
程序员常见700单词 快捷键 Ctrl+F 进行搜索查找 1. password /ˈpæswɜ:rd/ n. 密码 2. grep /'grep/ n. 检索目标行命令 3. tre ...
最新文章
- awk 控制语句(if for do while)
- linux java乱码怎么解决,linux中显示中文乱码如何解决
- [轉]資料庫讀寫分離
- UEFI引导的系统下装双系统解决方案
- vm_comcat报错 - 数字或值错误 : 字符串缓冲区太小
- QT+FFMPEG实现视频播放
- mysql 增删改数据 dml 1207 0310
- Pentium II Pentium III架构/微架构/流水线 (4) - P6详解 - 高速缓存/Store Buffers
- igmp是哪个层协议_【干货】IGMPv1协议闲聊
- 《Linux KVM虚拟化架构实战指南》——第1章 KVM虚拟化概述 1.1XEN虚拟化介绍
- ubuntu18.04搭建nfs
- 二叉树的遍历-C++
- 下载虚拟机安装linux镜像(图形化)
- poi html转换成word文档,poi将html转换为word文档
- IntelliJ IDEA文件模板变量
- 计算机科学与技术专业读书笔记300字,计算机读书笔记.doc
- 如何快速增长支付宝会员成长值
- dnf手游登录不显示服务器,不要着急 DNF手游提示登录失败error7正确解决方法
- 【matplotlib】饼图+legend()、loc、color位置颜色图例中文显示(一个饼图的例子)
- centos7 如何取消自动锁屏