《Java实验四》

//实验4--附录一代码
public class PassValueTest
{
    //静态代码块,类一加载就执行的部分。
    //所以运行这个程序会输出 class loding
    static {
        System.out.println("class loding");
    }
    public static void main(String[] args){

    }
}
//实验4--附录二代码

/*
所有解释体现在代码中的注释中。
*/
public class PassValueTest
{
    private int i = -100;    //定义一个私有的成员变量i,初值是-100.

    //定义一个test1方法,参数类型是整形,功能是给局部变量b赋值为100.
    public void test1(int b)
    {
        b = 100;
    }

    //定义一个test2方法,参数是类PassValueTest类型的引用变量,功能是修改私有
    //变量i的值为100.
    public void test2(PassValueTest b)
    {
        b.i = 100;
    }

    //定义一个test3方法,参数是类PassValueTest类型的引用变量,功能是把本对象的私有
    //成员变量赋值给局部类类型的变量b。
    public void test3(PassValueTest b)
    {
        b = this;
    }

    //定义主函数。
    public static void main(String[] args)
    {
        //创建一个类PassValueTest的对象。
        PassValueTest obj = new PassValueTest();

        //定义一个整形变量temp,赋值为100.
        int temp = 100;

        //调用成员方法test1,并对方法中的局部整形变量赋值为100.
        obj.test1(temp);
        System.out.println(temp);

        //调用成员方法test2,并修改其成员变量i的值为100.
        obj.test2(obj);
        System.out.println(obj.i);

        //修改私有成员变量i的值为100.
        obj.i = 100;//这句代码对吗?哦哦,对,因为是在一个类中访问的。

        //创建一个类PassValueTest的对象。
        PassValueTest newobj = new PassValueTest();
        //调用成员方法test3,并把当前对象的私有成员变量i的值(为-100)赋给局部类类型
        //的变量b
        newobj.test3(newobj);
        System.out.println(newobj.i);
    }
}
////实验4--附录三代码
/*
问题如下:
编译如下代码,分析结果;将“注释这行”所在的行注释,再将
注释的call2方法和main方法中的“StaticTest.call2(obj);”方
去掉注释,再次编译,观察结果分析其原因。

回答如下:
(1)在没有去掉注释之前进行编译,会发生如下错误:
========================================================================
StaticTest.java:13: 错误: 无法从静态上下文中引用非静态 方法 nonstaticmethod()
                nonstaticmethod();//注释这行.
                ^
1 个错误
===========================================================================
这个错误说明:在用类名直接调用静态方法时可以的,但在此例中(没有去掉代码中的注释),
直接用类名调用了call1方法(StaticTest.call1();)但是在call1方法中有调用到了静态的
staticmethod()方法,这是没错的,但是在call1方法中又调用了非静态的nonstaticmethod
方法。此时编译器出现报错提示如上。
    从而也就是说:静态的方法可以有类名直接调用,非静态的方法不能有类名调用。

(2)按照题目要求的做法后,在编译不会出现问题;
    运行结果是:
    静态方法被调用
    非静态方法被调用
    非静态方法被调用

    分析运行结果如下:
    首先在主函数中创建了一个StaticTest类的对象obj,然互直接由类名调用静态方法
call1,在call1方法中又调用到了静态的staticmethod方法,然后输出(1)“静态方法被调用”。
接着用类名直接调用了静态的方法call2,并把对象obj传递给静态方法的形式参数o1.在
静态的call2方法中,传递过来的对象调用了非静态的方法nonstaticmethod,此时便打印输出
了(2)“非静态方法被调用”,紧接着又在静态的call2方法中创建了一个本类对象o2,然后用o2对象
也调用了非静态的方法nonstaticmethod.便输出了(3)“非静态方法被调用”

    从以上分析(和自己在代码中的测试)来看:可以总结的是,静态方法可以由类名直接调用,
也可以由对象调用,而非静态的方法只能由对象调用

*/

public class StaticTest
{
    public static void call1()
    {
        staticmethod();
        //nonstaticmethod();//注释这行.
    }

    public static void call2(StaticTest o1)
    {
        o1.nonstaticmethod();
        /*
        *o1.staticmethod();
        *这一句是测试用的,是用于测试静态的方法也能由对象直接调用
        *如果加上这一句,编译运行都没有错,运行的结果是:
        *    静态方法被调用
        *    非静态方法被调用
        *    静态方法被调用
        *    非静态方法被调用
        *则说明了静态的方法也能被对象直接调用。
        */
        StaticTest o2 = new StaticTest();
        o2.nonstaticmethod();
    }

    public void nonstaticmethod()
    {
        System.out.println("非静态方法被调用");
    }

    public static void staticmethod()
    {
        System.out.println("静态方法被调用");
    }

    public static void main(String[] args)
    {
        StaticTest obj = new StaticTest();
        StaticTest.call1();
        StaticTest.call2(obj);
    }
}
//实验四---第三题:
class Circle
{
    private final double PI = 3.14;
    private double radius;
    private double area;
    private double length;

    Circle(){}
    //构造函数
    Circle(double radius)
    {
        this.radius = radius;
    }
    //设置圆半径
    public void setRadius(double radius)
    {
        this.radius = radius;
    }
    //获取圆半径
    public double getRadius()
    {
        return radius;
    }

    //求圆的面积
    public double getArea()
    {
        area = PI*radius*radius;
        return area;
    }

    //求圆的周长
    public double getLength()
    {
        length = 2*PI*radius;
        return length;
    }

    public void print()
    {
        System.out.println("圆的半径="+getRadius()+"圆的面积="+getArea()+"圆的周长="+getLength());
    }

    public static void main(String[] args)
    {
        Circle c1 = new Circle();
        c1.setRadius(1);
        //c1.getArea();
        //c1.getLength();
        c1.print();

        Circle c2 = new Circle(100);
        c2.print();
    }
}
//实验四---第四题:
public class MyDate
{
    //成员变量:
    private int year;
    private int month;
    private int day;
    private boolean leap;

    //构造函数
    MyDate(){}

    MyDate(int year,int month,int day)
    {
        this.year = year;
        this.month = month;
        this.day = day;
    }

    private void setYear(int year)
    {
        this.year = year;
    }
    private  int getYear()
    {
        return year;
    }

    private void setMonth(int month)
    {
        this.month = month;
    }
    private int getMonth()
    {
        return month;
    }

    private void setDay(int day)
    {
        this.day = day;
    }
    private int getDay()
    {
        return day;
    }

    //判断是否是闰年。
    public  boolean isRunyear(int year)
    {
        if(year%4==0){
            if(year%100==0){
                if(year%400==0)
                    leap = true;
                    else
                        leap = false;
                }
                else
                    leap = true;
            }
            else
                leap = false;
        return leap;
    }

    //计算输入的xx年xx月xx日是本年的第几天。
    public int f()
    {
        int sum=0;
        switch(month)
        {
            case 1:sum=0;break;
            case 2:sum=31;break;
            case 3:sum=59;break;
            case 4:sum=90;break;
            case 5:sum=120;break;
            case 6:sum=151;break;
            case 7:sum=181;break;
            case 8:sum=212;break;
            case 9:sum=243;break;
            case 10:sum=273;break;
            case 11:sum=304;break;
            case 12:sum=334;break;
            default:System.out.println("data error!");break;
        }
        sum+=day;
        boolean l = isRunyear(year);
        if(l && month>2)
            sum++;
        return sum;
    }
    //打印相关信息。
    public void print(boolean l)
    {
        if(l)
            System.out.print(year+"是闰年   ");
        else
            System.out.print(year+"不是闰年   ");
        System.out.println(year+"/"+month+"/"+day+"是这一年的第"+f());
    }

    public static void main(String[] args)
    {
        MyDate d1 = new MyDate();
        d1.setYear(2012);
        d1.setMonth(10);
        d1.setDay(1);
        int x = d1.getYear();
        boolean y = d1.isRunyear(x);
        d1.print(y);

        System.out.println("=======================================");
        MyDate d2 = new MyDate(2009,4,1);
        int n = d2.getYear();
        boolean m = d2.isRunyear(n);
        d2.f();
        d2.print(m);
    }
}
时间: 2024-10-16 15:19:12

《Java实验四》的相关文章

CI框架源码阅读笔记3 全局函数Common.php

从本篇开始,将深入CI框架的内部,一步步去探索这个框架的实现.结构和设计. Common.php文件定义了一系列的全局函数(一般来说,全局函数具有最高的加载优先权,因此大多数的框架中BootStrap引导文件都会最先引入全局函数,以便于之后的处理工作). 打开Common.php中,第一行代码就非常诡异: if ( ! defined('BASEPATH')) exit('No direct script access allowed'); 上一篇(CI框架源码阅读笔记2 一切的入口 index

IOS测试框架之:athrun的InstrumentDriver源码阅读笔记

athrun的InstrumentDriver源码阅读笔记 作者:唯一 athrun是淘宝的开源测试项目,InstrumentDriver是ios端的实现,之前在公司项目中用过这个框架,没有深入了解,现在回来记录下. 官方介绍:http://code.taobao.org/p/athrun/wiki/instrumentDriver/ 优点:这个框架是对UIAutomation的java实现,在代码提示.用例维护方面比UIAutomation强多了,借junit4的光,我们可以通过junit4的

Yii源码阅读笔记 - 日志组件

?使用 Yii框架为开发者提供两个静态方法进行日志记录: Yii::log($message, $level, $category);Yii::trace($message, $category); 两者的区别在于后者依赖于应用开启调试模式,即定义常量YII_DEBUG: defined('YII_DEBUG') or define('YII_DEBUG', true); Yii::log方法的调用需要指定message的level和category.category是格式为“xxx.yyy.z

源码阅读笔记 - 1 MSVC2015中的std::sort

大约寒假开始的时候我就已经把std::sort的源码阅读完毕并理解其中的做法了,到了寒假结尾,姑且把它写出来 这是我的第一篇源码阅读笔记,以后会发更多的,包括算法和库实现,源码会按照我自己的代码风格格式化,去掉或者展开用于条件编译或者debug检查的宏,依重要程度重新排序函数,但是不会改变命名方式(虽然MSVC的STL命名实在是我不能接受的那种),对于代码块的解释会在代码块前(上面)用注释标明. template<class _RanIt, class _Diff, class _Pr> in

CI框架源码阅读笔记5 基准测试 BenchMark.php

上一篇博客(CI框架源码阅读笔记4 引导文件CodeIgniter.php)中,我们已经看到:CI中核心流程的核心功能都是由不同的组件来完成的.这些组件类似于一个一个单独的模块,不同的模块完成不同的功能,各模块之间可以相互调用,共同构成了CI的核心骨架. 从本篇开始,将进一步去分析各组件的实现细节,深入CI核心的黑盒内部(研究之后,其实就应该是白盒了,仅仅对于应用来说,它应该算是黑盒),从而更好的去认识.把握这个框架. 按照惯例,在开始之前,我们贴上CI中不完全的核心组件图: 由于BenchMa

CI框架源码阅读笔记2 一切的入口 index.php

上一节(CI框架源码阅读笔记1 - 环境准备.基本术语和框架流程)中,我们提到了CI框架的基本流程,这里这次贴出流程图,以备参考: 作为CI框架的入口文件,源码阅读,自然由此开始.在源码阅读的过程中,我们并不会逐行进行解释,而只解释核心的功能和实现. 1.       设置应用程序环境 define('ENVIRONMENT', 'development'); 这里的development可以是任何你喜欢的环境名称(比如dev,再如test),相对应的,你要在下面的switch case代码块中

Apache Storm源码阅读笔记

欢迎转载,转载请注明出处. 楔子 自从建了Spark交流的QQ群之后,热情加入的同学不少,大家不仅对Spark很热衷对于Storm也是充满好奇.大家都提到一个问题就是有关storm内部实现机理的资料比较少,理解起来非常费劲. 尽管自己也陆续对storm的源码走读发表了一些博文,当时写的时候比较匆忙,有时候衔接的不是太好,此番做了一些整理,主要是针对TridentTopology部分,修改过的内容采用pdf格式发布,方便打印. 文章中有些内容的理解得益于徐明明和fxjwind两位的指点,非常感谢.

CI框架源码阅读笔记4 引导文件CodeIgniter.php

到了这里,终于进入CI框架的核心了.既然是"引导"文件,那么就是对用户的请求.参数等做相应的导向,让用户请求和数据流按照正确的线路各就各位.例如,用户的请求url: http://you.host.com/usr/reg 经过引导文件,实际上会交给Application中的UsrController控制器的reg方法去处理. 这之中,CodeIgniter.php做了哪些工作?我们一步步来看. 1.    导入预定义常量.框架环境初始化 之前的一篇博客(CI框架源码阅读笔记2 一切的入

jdk源码阅读笔记之java集合框架(二)(ArrayList)

关于ArrayList的分析,会从且仅从其添加(add)与删除(remove)方法入手. ArrayList类定义: p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Monaco } span.s1 { color: #931a68 } public class ArrayList<E> extends AbstractList<E> implements List<E> ArrayList基本属性: /** *

dubbo源码阅读笔记--服务调用时序

上接dubbo源码阅读笔记--暴露服务时序,继续梳理服务调用时序,下图右面红线流程. 整理了调用时序图 分为3步,connect,decode,invoke. 连接 AllChannelHandler.connected(Channel) line: 38 HeartbeatHandler.connected(Channel) line: 47 MultiMessageHandler(AbstractChannelHandlerDelegate).connected(Channel) line: