• 课上及课后的问题


    //20163677 多文佳

    一.在程序中写太多的注释,会使程序变大,运行变慢?

         不会。Java编译器在将.java文件编译成.class文件时,会删除所有的注释,因此,可以放心大胆地在代码中添加注释,它不会使程序变大!

          这种直觉实际上是有问题的。       软件程序的尺寸与其运行速度之间确实有比较大的相关性,但这并非“因果关系”,软件运行速度与软件本身的设计、所用的具体技术和运行平台等密切相关,受很多种因素的影响

    二.(1)一个Java类文件中真的只能有一个公有类吗? (2)请使用Eclipse或javac检测一下以下代码,有错吗?

    public class Test {

         public static void main(String[] args){

        }

        public class Inner{

        }

    }

    回答:(1)一个java类中不仅仅只能有一个公有类,可以同时存在许多公有类。

    (2)这样写没错,在主函数中定义类是被允许的。

    三.把main()方法的返回值由 void 改为 int ,程序能编译通过吗?能运行吗?

        不能通过编译,不能运行。

        但是如果在函数中加入return语句可以通过编译,但不能运行。

    四.为什么java规定作为程序入口点的main() 方法静态的?

        当我们执行一个java程序的时候,因为java都是以类作为程序的组织单元,当我们要执行的时候,我们并不知道这个main方法会放到哪个类当中,也不知道是否是要产生类的一个对象,为了解决程序的运行问题,我们将这个main方法定义为static,这样的话,当我们在执行一个java代码的时候,我们在命令提示符中写:java First(First为一个类),解释器就会在First这个类当中,去调用这个静态的main方法,而不需要产生First这个类的对象,当我们加载First这个类的时候,那么main方法也被加载了,作为我们java程序的一个入口。

    五.Java变量遵循“同名变量的屏蔽原则”,请课后阅读相关资料弄清楚相关知识,然后自己编写一些测试代码,就象本示例一样,有意识地在不同地方定义一些同名变量,看看输出的到底是哪个值。

      例子public class Test{

                                        private static int value=1;

                                         public static void main(String[] args) {

                                                                                                    int value=2;

                                                                                                    System.out.println(value);

                                                                                                    }

                                         }

    例子的运行结果为2。原因是第一个私有变量value作用于整个类,而在主函数中value改变了,第二个value只作用于主函数,所以应该输出2;

    六.为什么double类型的数值进行运算得不到“数学上精确”的结果?

    这个涉及到二进制与十进制的转换问题。
    N进制可以理解为:数值×基数的幂,例如我们熟悉的十进制数123.4=1×10²+2×10+3×(10的0次幂)+4×(10的-1次幂);其它进制的也是同理,例如二进制数11.01=1×2+1×(2的0次幂)+0+1×(2的-2次幂)=十进制的3.25。
    double类型的数值占用64bit,即64个二进制数,除去最高位表示正负符号的位,在最低位上一定会与实际数据存在误差(除非实际数据恰好是2的n次方)。

    举个例子来说,比如要用4bit来表示小数3.26,从高到低位依次对应2的1,0,-1,-2次幂,根据最上面的分析,应当在二进制数11.01(对应十进制的3.25)和11.10(对应十进制的3.5)之间选择。
    简单来说就是我们给出的数值,在大多数情况下需要比64bit更多的位数才能准确表示出来(甚至是需要无穷多位),而double类型的数值只有64bit,后面舍去的位数一定会带来误差,无法得到“数学上精确”的结果。
    七.以下代码的输出结果是什么?
      int X=100;
      int Y=200;
      System.out.println("X+Y="+X+Y);
      System.out.println(X+Y+"=X+Y");
     为什么会有这样的输出结果?

    输出结果为

    X+Y=100200
    300=X+Y

    原因:当"X+Y="在前时,默认的把int型X,Y转化为String型,System.out.println()本身的参数默认为String型,遇到这种情况默认了转化,所以输出了100200,而第二个就是简单的输出。

  • 相关阅读:
    日记 2018/1/12
    【程序员笔试面试必会——排序①】Python实现 冒泡排序、选择排序、插入排序、归并排序、快速排序、堆排序、希尔排序
    Python笔试、面试 【必看】
    高性能Go并发
    Go连接MySql数据库Error 1040: Too many connections错误解决
    MAC 配置文件 ~/.zshrc
    go-statsd项目
    日记 2017.11.20
    sed 命令详解
    Opentsdb简介(一)
  • 原文地址:https://www.cnblogs.com/duowenjia/p/7636265.html
Copyright © 2020-2023  润新知