java学习笔记(day13)

0x00 static关键字

一旦用了static关键字,那么这样的内容不再属于对象自己,而是属于类的,所以凡是本类的对象,都共享一分。

static关键字修饰成员变量

如果一个成员变量使用了static关键字,那么这个变量不再属于对象自己,而是属于所在的类。也就是多个对象共享同一份数据。

static关键字修饰成员方法

一旦使用static修饰成员方法,那么这就成了静态方法。静态方法不属于对象,而是属于类的。

如果没有static关键字,那么必须首先创建对象,然后通过对象才能使用它。

对于静态方法来说,可以通过对象名进行调用,也可以直接通过类名称来调用。对于直接使用对象名调用的情况,这种调用方式,在被编译之后也会被javac翻译成“类名称.静态方法名”

无论是成员变量,还是成员方法。如果有了static,都推荐使用类名称进行调用。
静态变量:类名称.静态变量
静态方法:类名称.静态方法()

对于本类当中的静态方法,可以省略类名称。

注意事项

  1. 静态只能直接访问静态,不能直接访问非静态。
    原因:因为在内存当中,是【先】有的静态内容,【后】有的非静态内容。
  2. 根据类名称访问静态成员变量的时候,全程和对象就没关系,只和类有关系。

静态代码块

格式:
public class 类名称{
static {
//静态代码块的内容
}
}

特点:
当第一次用到本类时,静态代码块执行唯一的一次。
静态内容宗是优先于非静态,所以静态代码块比构造方法先执行。

静态代码块的典型用途:
用来一次性的对静态成员变量进行赋值。

0x01 Arrays工具类

定义:
这是一个与数组相关的工具类,里面提供了大量静态方法,用来实现数组常见的操作。

1. toString方法

public static String toString(数组):将参数数组变成字符串(按照格式:【元素1,元素2,元素3...】)

2. sort方法

public static void sort(数组):按照默认升序(从小到大)对数组进行排序。

PS:

  1. 如果是数值顺序,sort默认按照升序从小到大。
  2. 如果是字符串,sort默认按照字母升序。
  3. 如果是自定义类型,那么这个自定义的类需要有Comparable或者Camparator借口的支持。

3.练习1:将一个随机字符串中的所有字符升序排列,倒序打印。

package day13;
/*题目:将一个随机字符串中的所有字符升序排列,倒序打印。 */
import java.util.Arrays;
public class Sortlianxi01 {    
      public static void main(String[] args) {        
            String str1 = "asdavzxcadaweadsczxgasd";        
            char[] chars = str1.toCharArray();        
            Arrays.sort(chars);        
            for (int i = chars.length - 1 ; i > 0  ; i--) {            
                  System.out.println(chars[i]);        
            }    
      }
}

0x02 Math类

定义:
该类是数学相关的工具类,里面提供了大量的静态方法,完成与数学运算相关的操作。

1.abs方法

public static double abs(double num):获取绝对值。

2.ceil方法

public static double ceil(double num):向上取整。

3.floor方法

public static double floor(double num):向下取整。

4.round方法

public static long round(double num):四舍五入。

Math.PI 代表近似圆周率的常量。

5.练习1:计算在-10.8 到5.9之间,绝对值大于6或者小于2.1的整数有多少个。

package day13;
/*题目:计算在-10.8 到5.9之间,绝对值大于6或者小于2.1的整数有多少个。 */
public class Mathlianxi01 {    
      public static void main(String[] args) {        
            double min = -10.8;        
            double max = 5.9;        
            int count = 0;        
            for (int i = (int)min; i <=(int)max ; i++) {            
                  if (Math.abs(i)>6 || Math.abs(i)<2.1){                
                        count++;            
                  }        
            }        
            System.out.println(count);    
      }
}
posted @ 2020-10-09 16:27  小明-o3rr0r  阅读(183)  评论(0编辑  收藏  举报