java语言进阶篇3——static、Arrays类、Math类

本文深入解析Java中static关键字的应用,包括静态变量、静态方法、静态代码块的概念及使用场景,同时介绍Arrays和Math类提供的实用工具方法,帮助读者掌握Java静态特性和常用数学与数组操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、静态static关键字

  • 一旦使用static关键字,那么这样的内容不再属于对象自己,而是属于类,所以凡是本类的对象都共享同一份。
    静态static关键字
1、static关键字修饰成员
  • 如果没有static关键字,那么必须先创建对象,然后通过对象才能使用它,如果有static关键字,那么不需要创建对象,直接就能通过类名称来使用它。
  • 无论是成员变量还是成员方法,如果有了static关键字,都推荐使用类名称进行调用
  • 静态不能直接访问非静态,因为在内存中先有静态内容后有非静态内容,“先人不知道后人,但后人知道先人”。
  • 静态方法中不能用this,因为this代表当前对象,通过谁调用的方法,谁就是当前对象。
public class Student {  //学生类
    //成员变量
    private int id;
    private String name;
    private int age;
    static String room;  //静态变量
    private static int idCounter = 0; //静态变量,学号计数器,每当新建一个对象,计数器++
    //成员方法
    public Student() {  //无参构造方法
        idCounter++;  //新建一个对象,学号+1
}
    public Student(String name, int age) {  //全参构造方法
        this.name = name;
        this.age = age;
        this.id = ++idCounter;  //id为静态变量,构造方法的参数不用写,可以直接使用
}
    //id、name、age的Getter/Setter方法,静态的不需要
    public int getId() { return id; }
    public void setId(int id) { this.id = id; }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public void method(){
        System.out.println("这是成员方法");
    }
    public static void methodStatic(){  //静态方法,属于类,不属于对象。
        System.out.println("这是静态方法");
    }
}
public class DemoStatic {
    public static void main(String[] args) {
        Student one = new Student("郭靖",20);
        Student.room ="101教室"; //静态变量直接用类名访问,也可对象名
        System.out.println("姓名:"+one.getName()+",年龄:"+one.getAge()+",教室:"+one.room+",学号:"+one.getId());
        //姓名:郭靖,年龄:20,教室:101教室,学号:1
        Student two = new Student("黄蓉",18);
        System.out.println("姓名:"+two.getName()+",年龄:"+two.getAge()+",教室:"+two.room+",学号:"+two.getId());
        //姓名:黄蓉,年龄:18,教室:101教室,学号:2

        one.method(); //成员方法必须先创建对象,然后通过对象调用
        //这是成员方法
        Student.methodStatic(); //静态方法直接用类名调用,推荐
        //这是静态方法
        two.methodStatic();  //也可以用对象调用(编译后java会翻译成:类名.静态方法()),不推荐
        //这是静态方法
    }
}
2、static内存图
  • 根据类名称访问静态成员变量的时候,全程和对象无关,只和类有关。
    static内存图
3、静态代码块
  • 格式:
    public class 类名称{
    static {
    // 静态代码块的内容
    } }
  • 特点:当第一次用到本类时,静态代码块执行唯一的一次。静态内容总是优先于非静态,所以静态代码块比构造方法先执行。
  • 用途:用来一次性的对静态成员变量进行赋值。

二、数组工具类Arrays

  • java.util.Arrays类是一个与数组相关的工具类,里面提供了大量静态方法,用来实现数组常见操作。
  • public static String toString(数组):将参数数组变成字符串(按默认格式“[元素1,元素2,…]”)。
  • public static void sort(数组):按默认升序对数组的元素进行排序,如果是数值,sort按升序排,如果是字符串,按字母升序,如果是自定义的类型,则自定义的类需要有Comparable或Comparator接口的支持。
//public static String toString(数组)
int[] intArray = {10,20,30};//定义一个整型数组
String intstr = Arrays.toString(intArray); //[10,20,30]
//public static void sort(数组)
int[] array1 = {2,1,3,6};
Arrays.sort(array1); //直接在原数组改变顺序
System.out.println(Arrays.toString(array1));//可用Arrays.toString()快速打印数组内容  [1,2,3,6]
String[] array2 = {"aa","cc","bb"};
Arrays.sort(array2);
System.out.println(Arrays.toString(array1)); //[aa,bb,cc]
  • 练习:使用Arrays相关的API,将一个随机的字符串中的所有字符升序排列,并倒序打印。
public class DemoArrays {
    public static void main(String[] args) {
        String str = "sj23g5";
        char[] chars = str.toCharArray(); //先变成字符数组
        Arrays.sort(chars); //排序,数字在前
        for (int i = chars.length - 1; i >= 0; i--) {  //倒序输出 快捷键:chars.forr
            System.out.println(chars[i]);  //s j g 5 3 2 
        }
    }
}

三、数学工具类Math

  • java.util.Math类是数学相关的工具类,里面提供了大量的静态方法,完成数学运算相关操作。
  • public static double abs(double num):获取绝对值,结果带小数
  • public static double ceil(double num):向上取整,结果带小数
  • public static double floor(doublr num):向下取整,结果带小数
  • public static long round(double num):四舍五入,结果不带小数
  • Math.PI : 数值为double型3.14159265358979323846
System.out.println(Math.abs(-2.3));  // 2.3
System.out.println(Math.ceil(3.1));  //4.0
System.out.println(Math.ceil(5.0));  //5.0
System.out.println(Math.floor(2.9));  //2.0
System.out.println(Math.floor(6.0));  //6.0
System.out.println(Math.round(9.6));  //10
内容概要:本文详细探讨了杯形谐波减速器的齿廓修形方法及寿命预测分析。文章首先介绍了针对柔轮与波发生器装配时出现的啮合干涉问题,提出了一种柔轮齿廓修形方法。通过有限元法装配仿真确定修形量,并对修形后的柔轮进行装配和运转有限元分析。基于Miner线性疲劳理论,使用Fe-safe软件预测柔轮寿命。结果显示,修形后柔轮装配最大应力从962.2 MPa降至532.7 MPa,负载运转应力为609.9 MPa,解决了啮合干涉问题,柔轮寿命循环次数达到4.28×10⁶次。此外,文中还提供了详细的Python代码实现及ANSYS APDL脚本,用于柔轮变形分析、齿廓修形设计、有限元验证和疲劳寿命预测。 适合人群:机械工程领域的研究人员、工程师,尤其是从事精密传动系统设计和分析的专业人士。 使用场景及目标:①解决杯形谐波减速器中柔轮与波发生器装配时的啮合干涉问题;②通过优化齿廓修形提高柔轮的力学性能和使用寿命;③利用有限元分析和疲劳寿命预测技术评估修形效果,确保设计方案的可靠性和可行性。 阅读建议:本文涉及大量有限元分析和疲劳寿命预测的具体实现细节,建议读者具备一定的机械工程基础知识和有限元分析经验。同时,读者可以通过提供的Python代码和ANSYS APDL脚本进行实际操作和验证,加深对修形方法和技术路线的理解。
### Java 蓝桥杯习题集概述 蓝桥杯大赛作为一项面向全国高校学生的编程竞赛活动,其题目涵盖了广泛的计算机科学基础知识。以下是基于提供的引用内容以及扩展的知识整理出的一份与 **Java** 相关的蓝桥杯练习题目列表。 #### 基础练习部分 1. 数组操作问题 - 题目示例:杨辉三角形打印[^1] 描述:通过二维数组实现杨辉三角形的构建并输出。 ```java import java.util.Scanner; public class YangHuiTriangle { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); int[][] a = new int[n][n]; for (int i = 0; i < n; i++) { a[i][0] = 1; a[i][i] = 1; for (int j = 1; j < i; j++) { a[i][j] = a[i - 1][j - 1] + a[i - 1][j]; } } for (int i = 0; i < n; i++) { for (int j = 0; j <= i; j++) { System.out.print(a[i][j] + " "); } System.out.println(); } } } ``` 2. 排序算法应用 - 题目示例:数列排序[^2] 描述:给定一个长度为 `n` 的数列,将其按照从小到大的顺序排列。 ```java import java.util.Arrays; import java.util.Scanner; public class SequenceSort { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); int[] nums = new int[n]; for (int i = 0; i < n; i++) { nums[i] = sc.nextInt(); } Arrays.sort(nums); for (int num : nums) { System.out.print(num + " "); } } } ``` 3. 特殊数字识别 - 题目示例:特殊的数字(水仙花数) 描述:找出所有的三位数中的水仙花数(即该数等于其各位数字立方和的数)。 ```java public class NarcissisticNumber { public static void main(String[] args) { for (int i = 100; i <= 999; i++) { int hundreds = i / 100; int tens = (i % 100) / 10; int units = i % 10; if (Math.pow(hundreds, 3) + Math.pow(tens, 3) + Math.pow(units, 3) == i) { System.out.println(i); } } } } ``` --- #### 进阶练习部分 4. 字符串处理 - 题目示例:字符串反转 描述:输入一个字符串,将其字符顺序反转后输出。 ```java import java.util.Scanner; public class StringReverse { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String str = sc.nextLine(); StringBuilder sb = new StringBuilder(str).reverse(); System.out.println(sb.toString()); } } ``` 5. 素数判断 - 题目示例:素数判定 描述:判断某个正整数是否为素数。 ```java import java.util.Scanner; public class PrimeCheck { public static boolean isPrime(int n) { if (n <= 1) return false; for (int i = 2; i * i <= n; i++) { if (n % i == 0) return false; } return true; } public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); System.out.println(isPrime(n) ? "Yes" : "No"); } } ``` 6. 动态规划入门 - 题目示例:斐波那契数列求解 描述:计算第 N 项斐波那契数值。 ```java import java.util.Scanner; public class Fibonacci { public static long fib(int n) { if (n == 0 || n == 1) return n; long prev = 0, curr = 1; for (int i = 2; i <= n; i++) { long next = prev + curr; prev = curr; curr = next; } return curr; } public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); System.out.println(fib(n)); } } ``` --- #### 提高难度部分 7. 图结构遍历 - 题目示例:图的广度优先搜索(BFS) 描述:利用队列实现无向图的 BFS 遍历。 ```java import java.util.*; public class GraphTraversal { public static void bfs(List<List<Integer>> graph, int start) { Queue<Integer> queue = new LinkedList<>(); Set<Integer> visited = new HashSet<>(); queue.add(start); visited.add(start); while (!queue.isEmpty()) { int node = queue.poll(); System.out.print(node + " "); for (Integer neighbor : graph.get(node)) { if (!visited.contains(neighbor)) { queue.add(neighbor); visited.add(neighbor); } } } } public static void main(String[] args) { List<List<Integer>> graph = new ArrayList<>(); // 初始化图... bfs(graph, 0); } } ``` 8. 数据结构综合运用 - 题目示例:栈的应用——括号匹配验证 描述:检查一串括号表达式是否合法。 ```java import java.util.Stack; import java.util.Scanner; public class ParenthesesValidation { public static boolean isValid(String s) { Stack<Character> stack = new Stack<>(); for (char c : s.toCharArray()) { if (c == &#39;(&#39; || c == &#39;{&#39; || c == &#39;[&#39;) { stack.push(c); } else { if (stack.isEmpty()) return false; char top = stack.pop(); if ((c == &#39;)&#39; && top != &#39;(&#39;) || (c == &#39;}&#39; && top != &#39;{&#39;) || (c == &#39;]&#39; && top != &#39;[&#39;)) { return false; } } } return stack.isEmpty(); } public static void main(String[] args) { Scanner sc = new Scanner(System.in); String input = sc.next(); System.out.println(isValid(input) ? "Valid" : "Invalid"); } } ``` --- ### 总结 上述列举了从基础到提高的不同层次的蓝桥杯练习题目及其对应的解决方案。这些题目覆盖了常见的数据结构、算法设计思路以及实际编码技巧,适合初学者逐步提升自己的编程能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值