作者曾写过一段时间Java, 时间一长也就忘得差不多了. 现在重新学习一个, 故而只是提要式的记录.

Java是静态强类型语言, 运行于Java虚拟机(Java Virtual Machine, JVM)上.

若要运行Java程序需要安装Java运行环境(Java Runtime Environment, JRE). 若要编译Java源文件需要安装JDK(Java Development Kit).

  • Ubuntu安装: apt-get install openjdk-8-jre-headless

  • Mac安装: brew cask install java

Java使用类来组织代码, 源代码保存于.java文件中. 一个源文件可以定义多个类, 最多只能有一个public类,源文件名必须与public类一致.

使用javac [SrcFile]命令编译Java源文件, 每个类都会编译得到一个.class文件. 使用java [ClassName]将会搜索相应地类, 并执行其main()方法.

照例先写HelloWorld:

public class Main {

    public static void main(String[] args) {
        System.out.println("Hello World!");
    }
}

编译执行:

$javac Main.java
$java Main
Hello World!

Java标识符可以由字母,数字和_组成, 不得以数字开头, 大小写敏感.

Java的语句以;结尾, 使用{}标志代码块. 语句与行无关, 可以一句几行或一行多句.

Java支持//引导的行注释符和/*, */标志的块注释符.

数据类型

Java提供了一系列内置类型及其封装类, 类型的大小与操作系统无关.

  • byte: 8位二进制补码表示的带符号整数, 封装类java.lang.Byte

  • short: 16位二进制补码表示的带符号整数, 封装类java.lang.Short

  • int: 32位二进制补码表示的带符号整数, 封装类java.lang.Integer

  • long: 64位二进制补码表示的带符号整数, 字面值加L后缀, 如233L, 封装类java.lang.Long.

  • float: 32位单精度, 符合IEEE754标准的浮点数, 字面值加f或F后缀, 如1f, 封装类java.lang.Float

  • double: 64位双精度浮点数, 封装类java.lang.Double

  • char: 16位Unicode字符, 字面值使用单引号标志, 如1, 封装类java.lang.Character.

定义变量时初始化::

int sum = 0;

Java的boolean类型对象只能进行关系运算,只有boolean值才能进行流程控制. 其它数据类型(包括int)不能与boolean相互转换,也不能进行流程控制或关系运算.

Java使用与C几乎相同的算术, 关系和逻辑运算符如?:, %, 逻辑运算符同样具有短路特性.

Java同样支持++--运算符以及复合赋值运算符. 赋值运算符将返回左值, 因此可以进行连续赋值:

public class Main {

    public static void main(String[] args) {
        int a = 0, b= 0;
        System.out.println(a=2);  // 2
        a = b = 3;
        System.out.println(a);  // 3
        System.out.println(b);  // 3

    }
}

引用

Java中除上述内置类型的变量外, 其它变量均为引用类型.

final关键字修饰的对象为常量, 一经初始化无法修改:

final int i = 2;

==运算符用于判断引用是否指向同一个对象, 要判断对象内容是否相同需要使用equals()方法.

流程控制

Java的流程控制语句与C基本相同, 不过做了一些很好的改进:

if

public class Main {

    public static void main(String[] args) {
        int score = 77;
        if (score > 90) {
            System.out.println("Excellent");
        }
        else if (score > 60) {
            System.out.println("Good");
        }
        else {
            System.out.println("Fail");
        }
    }
}

switch

public class Main {

    public static void main(String[] args) {
        char ch = 'a';
        switch (ch) {
            case 'a': System.out.println("Apache"); break;
            case 'b': System.out.println("Basic"); break;
            default: System.out.println("??");
        }
    }
}

while

public class Main {

    public static void main(String[] args) {
        int i = 1, sum = 0;
        while (i <= 100) {
            sum += i;
            i++;
        }
        System.out.println(sum);
    }
}

do

public class Main {

    public static void main(String[] args) {
        int i = 1, sum = 0;
        do {
            sum += i;
            i++;
        } while( i <= 100);
        System.out.println(sum);
    }
}

for

public class Main {

    public static void main(String[] args) {
        int i, sum = 0;
        for (i = 1; i <= 100; i++) {
            sum += i;
        }
        System.out.println(sum);
    }
}

foreach

public class Main {

    public static void main(String[] args) {
        int[] arr = new int[5];
        for (int i : arr) {
            System.out.println(i);
        }

    }
}

break, continue

public class Main {

    public static void main(String[] args) {
        int i, sum = 0;
        for (i = 1; i <= 100; i++) {
            sum += i;
            if (i % 2 == 0) {
              continue;
            }
            if (i > 80) {
                break;
            }
        }
        System.out.println(sum);
    }
}

可以使用label来跳出多层循环:

public class Main {

    public static void main(String[] args) {
        int i, j;
        outer: for (i = 1; i <= 100; i++) {
            for (j = 1; j <= 100; j++) {
                if (j == 10) {
                    continue outer;
                }
                if (i > 3) {
                    break outer;
                }
                System.out.print(i);
                System.out.println(j);
            }
        }
    }
}

异常

异常类族的基类为java.lang.Throwable, 它派生出ErrorException两个子类.

Error用来指示运行环境错误, 如JVM内存异常. 程序一般无法从Error中恢复.

Exception则是那些可以恢复的异常的基类, 其子类中包括:

  • IOException: 找不到文件等造成的输入输出异常

  • InterruptedException: 线程被其它线程中断造成的异常

  • RuntimeException: 由程序本身造成的异常:

    • NullPointerException: 引用指向的对象不存在造成的异常

    • IndexOutofBoundException: 对容器的访问下标越界造成异常

Java使用try-catch块捕获异常:



public class Main {

    public static void main(String[] args) {
        try {
            throw new RuntimeException("nothing");
        }
        catch (RuntimeException e) {
            System.out.println(e.getMessage());
        }
        catch (Exception e) {
            e.printStackTrace();
        }
        finally {
            ; // release something
        }
    }
}

可能抛出异常的代码在try中, 依次使用catch尝试捕获抛出的异常, 若无法捕获则向上一级方法抛出. 无论是否有异常发生还是异常是否被捕获, finally块中的代码都会被执行.

若方法不处理某个异常就把它向上抛出. 但是方法若可能向上抛出检查性(checked)异常, 必须使用throws关键字声明.

public void test() throws ClassNotFoundException {}

通过继承异常类, 程序员可以自定义异常.

Java通过包来管理命名空间. 包声明语句是除注释外Java源文件中的第一条语句.

package com.finley

包管理的是类而非源文件, 多个源文件可以使用同一个包名. 但是字节码.class文件所在的目录结构必须与包名吻合.

通过import语句引入某个类:

import com.finley.Test

使用*可以引入源文件中所有类:

import com.finley.*

Java默认导入java.lang.*, 使用源文件自身包中的其它类也无需引入.

再会Java的更多相关文章

  1. Spark案例分析

    一.需求:计算网页访问量前三名 import org.apache.spark.rdd.RDD import org.apache.spark.{SparkConf, SparkContext} /* ...

  2. 使用Java原生代理实现AOP

    ### 本文由博主柒.原创,转载请注明出处 ### 完整源码下载地址 [https://github.com/MatrixSeven/JavaAOP](https://github.com/Matri ...

  3. Java基础应用

    Java集合类解析 List.Map.Set三个接口,存取元素时,各有什么特点? List 以特定次序来持有元素,可有重复元素.Set 无法拥有重复元素,内部排序.Map 保存key-value值,v ...

  4. 网络爬虫讲解(附java实现的实例)

    本文转载http://blog.csdn.net/luojinping/article/details/6870898 转载过来主要是防止想百度文库一样突然停止运作,导致很多文库丢失而无法找寻 网络蜘 ...

  5. 深入理解JVM内幕:从基本结构到Java 7新特性

    转自:http://www.importnew.com/1486.html 每个Java开发者都知道Java字节码是执行在JRE((Java Runtime Environment Java运行时环境 ...

  6. Java 编程入门(词汇表)

    抽象类(abstract class):抽象类不能创建对象,主要用来创建子类.Java中的抽象类使用 abstract 修饰符定义. 抽象数据类型(abstract data type ADT):抽象 ...

  7. Java日志系统框架的设计与实现

    推荐一篇好的文章介绍java日志系统框架的设计的文章:http://soft.chinabyte.com/database/438/11321938.shtml 文章内容总结: 日志系统对跟踪调试.程 ...

  8. ZeroMQ(java)中的数据流SessionBase与SocketBase

    前面的文章中已经比较的清楚了ZeroMQ(java)中如何在底层处理IO, 通过StreamEngine对象来维护SelectableChannel对象以及IO的事件回调,然后通过Poller对象来维 ...

  9. Java泛型总结

    1. 什么是泛型?泛型(Generic type 或者 generics)是对 Java 语言的类型系统的一种扩展,以支持创建可以按类型进行参数化的类.可以把类型参数看作是使用参数化类型时指定的类型的 ...

随机推荐

  1. windows下使用redis c++

    redis是高效key-value NOSQL 数据库 代码开源 windows下使用需要使用微软在redis官方上的改进版 地址 https://redis.io/download 寻找window ...

  2. 项目启动一直死循环 DruidDataSource.init 方法

    今日项目启动遇到一个问题: 项目启动一直死循环 DruidDataSource.init 方法, 代码和同事相同,环境也一致 最后通过maven  clean 然后重新install ,再次启动正常了 ...

  3. ScriptOJ-unique#89

    一般做法 const unique = (arr) => { const result = arr.reduce((acc, iter) => { if(acc.indexOf(iter) ...

  4. Django的一些隐性经验

    隐性经验 前后信息的沟通 url中的参数 get获取 这个参数可以写在URL当中(可以写多个,写在这里的get函数需要有相应的参数去获取).,也可以在模版中添加(通过?若是直接写则表示在当前的URL中 ...

  5. 18.数组(一)之认识java数组

    数组是一个简单的复合数据类型,它是一组有序数据的集合,它当中的每一个数据都具有相同的数据类型,我们通过数组名再加上一个不会越界的下标值来唯一确定数组中的元素. 还有就是,数组是一个特殊的对象. 不管在 ...

  6. Android-Java-子类实例化过程(内存图)

    案例一: package android.java.oop15; // 描述Person对象 class Person { // 构造方法就算不写 默认有一个隐式的无参构造方法:public Pers ...

  7. cf 20C Dijkstra?

    带队列  dijkstra #include <iostream> #include <cstdio> #include <queue> #include < ...

  8. python 使用进程池Pool进行并发编程

    进程池Pool 当需要创建的子进程数量不多时,可以直接利用multiprocessing中的Process动态成生多个进程,但如果是上百甚至上千个目标,手动的去创建进程的工作量巨大,此时就可以用到mu ...

  9. AndroidStudio制作底部导航栏以及用Fragment实现切换功能

    前言 大家好,给大家带来AndroidStudio制作底部导航栏以及用Fragment实现切换功能的概述,希望你们喜欢 学习目标 AndroidStudio制作底部导航栏以及用Fragment实现切换 ...

  10. 利用nodejs安装并运行express的三个坑

    概述 这是我安装并运行express的三个坑,应该是比较常见的,在此记录一下. 内容 express不是内部或外部命令 输入命令:express -V 报错:'express' 不是内部或外部命令,也 ...