Java基础经典10道题

news2024/9/21 16:45:50

目录

for循环的嵌套

题目一: 求101到200之间的素数的个数,并打印

代码分析:

注意点:

题目二:开发验证码

代码分析:

题目三:数组元素的复制

代码分析:

题目四:评委打分

健壮版代码:

代码分析:看源码

注意点:

题目五:数字加密

优化版代码:

代码分析:

题目六:数字解密

代码分析:

题目七:抢红包

优化版代码:

代码分析:

难点:

解释:

题目八:双色球彩票系统

运行结果:

代码分析:

题目九:


for循环的嵌套

题目一: 求101到200之间的素数的个数,并打印

代码:

package com.mohuanan.exercise;

public class ExerciseTest01 {
    public static void main(String[] args) {
        int count = 0;
        for (int i = 101; i <= 200; i++) {
            boolean flag = true;
            for(int j = 2;j < i/2; j++){
                if(i % j == 0){
                    flag = false;
                    break;
                }
            }
            if(flag){
                count++;
                System.out.println(i+"是素数");
            }
        }
        System.out.println("一共"+count+"个素数");
    }
}

代码分析:

这里使用2个for循环,加上if条件判断标志flag是否为true,

注意点:

1.count应该放在if(flag)的里面,当flag为true是,这个数字就是素数

2.第二个for的j变量从2开始

题目二:开发验证码

代码:

package com.mohuanan.exercise;

import java.util.Random;

public class ExerciseTest02 {
    public static void main(String[] args) {
        //因为有52个字母(大小写)
        char[] chs = new char[52];
        for (int i = 0; i < chs.length; i++) {
            if (i <= 25) {
                //根据ASCII码
                //录入大写字母
                chs[i] = (char) (65 + i);//强制转化
            } else {
                //录入小写字母
                chs[i] = (char) (97 - 26 + i);
            }
        }
        String result = "";
        //创建一个Random的对象
        Random r = new Random();

        for(int i = 0;i<4;i++){
            //
            int randomIndex = r.nextInt(52);
            result = result + chs[randomIndex];

        }
        int number = r.nextInt(10);
        result = result + number;
        System.out.println(result);
        
    }

}

代码分析:

1.定义了一个52的char类型的字符串,并用for循环根据ASCII码来给数组的元素赋值(大小写字母),创建了一个Random类,并使用nextInt()方法,进行四次循环,用来随机(大小为数组的长度)出来四个字母,赋值给String类型的变量result,之后再使用Random类中的nextInt()方法产生0到9的随机数,赋值给result

题目三:数组元素的复制

代码:

package com.mohuanan.exercise;

public class ExerciseTest03 {
    public static void main(String[] args) {
        int[] arr = {1,2,3,4,5,6};
        int[] newArr = new int[arr.length];
        for (int i = 0; i < arr.length; i++) {
            newArr[i] = arr[i];
        }
        //遍历输出
        for (int i = 0; i < arr.length; i++) {
            System.out.print(newArr[i]+" ");
        }
        //换行
        System.out.println();
    }
}

代码分析:

这个太简单了,可以自己看上面的代码,这里不再分析

题目四:评委打分

代码:

package com.mohuanan.exercise;

import java.util.Scanner;

public class ExerciseTest04 {
    public static void main(String[] args) {

        int sum = 0;
        int[] arr = new int[6];
        Scanner s = new Scanner(System.in);

        for (int i = 0; i < arr.length; i++) {
            System.out.println("请输入第" + (i + 1) + "个评委的分数");
            arr[i] = s.nextInt();
            sum += arr[i];
        }
        int max = arr[0];
        int min = arr[0];
        for (int i = 1; i < arr.length; i++) {
            if (max < arr[i]) {
                max = arr[i];
            }
            if (min > arr[i]) {
                min = arr[i];
            }
        }
        float score = 0F;
        score = (float) (sum - max - min) / (arr.length - 2);
        System.out.println(score);

    }
}

健壮版代码:

package com.mohuanan.exercise;

import java.util.Scanner;

public class ExerciseTest04 {
    public static void main(String[] args) {

        int sum = 0;
        int[] arr = new int[6];
        Scanner s = new Scanner(System.in);

        for (int i = 0; i < arr.length; ) {
            System.out.println("请输入第" + (i + 1) + "个评委的分数");
            //判断 分数是否合法 
            int scoreArr = s.nextInt();
            sum += arr[i];
            if (scoreArr >= 0 && scoreArr <= 100){
                arr[i] = scoreArr;
                sum += arr[i];
                i++;//注意i++放在这里
            }else{
                System.out.println("您之前输入的分数有误"+"请重新输入第" + (i + 1) + "个评委的分数");
            }

        }
        int max = arr[0];
        int min = arr[0];
        for (int i = 1; i < arr.length; i++) {
            if (max < arr[i]) {
                max = arr[i];
            }
            if (min > arr[i]) {
                min = arr[i];
            }
        }
        float score = 0F;
        score = (float) (sum - max - min) / (arr.length - 2);
        System.out.println(score);

    }
}

代码分析:看源码

注意点:

1.score = (float) (sum - max - min) / (arr.length - 2);这里要加强制转化,如果不加,/运算符会截断数据,从而使结果错误

题目五:数字加密

代码:

package com.mohuanan.exercise;

import java.util.Scanner;

public class ExerciseTest05 {
    public static void main(String[] args) {
        Scanner s = new Scanner(System.in);
        System.out.println("请输入您的密码");
        int code = s.nextInt();

        code = handle(code);
        System.out.println(code);
    }

    public static int handle(int code) {
        int result = 0;
        int flag = 1;
        while (code > 0) {
            int temp;
            temp = code % 10;
            temp = (temp + 5) % 10;
            result = result + temp * flag;

            //result = result * 10 + temp;// reversedNumber = reversedNumber * 10 + digit;  // 将最后一位数字添加到反转数字的末尾
            code /= 10;
            flag *= 10;
        }

        result = reversalNum(result);
        return result;

    }

    //数字反转
    public static int reversalNum(int code) {
        int result =0;
        while (code > 0) {
            int temp;
            temp = code % 10;

            result = result * 10 + temp;

            code /= 10;
        }

        return result;
    }

}

优化版代码:

package com.mohuanan.exercise;

public class ExerciseTest06 {
    public static void main(String[] args) {
        int number = 1983;
        //为后面的下面使用number的值
        int temp = number;
        int count = 0;
        //计算数字的长度
        while (number != 0) {
            count++;
            number /= 10;
        }
        //定义一个数组
        int[] arr = new int[count];
        //把数字上的每一位复制到数组中
        while (temp != 0) {
            arr[--count] = temp % 10;
            temp = temp / 10;

        }
        //每位数加上5 并对10求余
        for (int i = 0; i < arr.length; i++) {
            arr[i] = arr[i] + 5;
            arr[i] = arr[i] % 10;
        }
        //所有数字反转
        for (int i = 0;i<arr.length/2; i++) {//arr.length/2 是把它看成一半
            int t;
            t = arr[i];
            arr[i] = arr[arr.length-1-i];//-1是索引 -i是
            arr[arr.length-1-i] = t;
        }
        //拼接
        int newNumber = 0;
        for (int i = 0; i < arr.length; i++) {
            newNumber = newNumber*10 + arr[i];
        }
        //输出打印
        System.out.println(newNumber);

    }
}

代码分析:

题目六:数字解密

代码:

package com.mohuanan.exercise;

public class ExerciseTest07 {
    public static void main(String[] args) {
        int[] arr = {8, 3, 4, 6};

        //反转
        for (int i = 0, j = arr.length - 1; i < j; i++, j--) {//注意这里的循环条件 是 i<j 相当于左右指针
            int temp;
            temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
        //由于之前是加密 余10 +5 所以要判断 并-5
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] >= 0 && arr[i] <= 4) {
                arr[i] = arr[i] + 10;
            }
            arr[i] = arr[i] - 5;
        }
        //拼接
        int number = 0;
        for (int i = 0; i < arr.length; i++) {
            number = number * 10 + arr[i];
        }
        //输出
        System.out.println(number);


    }
}

代码分析:

1.反转数字使用两个指针,循环条件i<j,使用临时变量,作为两个数的交换

2.由于数字的范围只能是5到14(因为一个一位数子加上5的范围,0+5到9+5),所以判断当前数字为0到4时就加上10,

3.根据数组的长度来拼接number = number*10+arr[i]

题目七:抢红包

代码:

package com.mohuanan.exercise;

import java.util.Random;

public class ExerciseTest08 {
    public static void main(String[] args) {
        //数组奖池
        int[] arr = {2, 588, 888, 1000, 10000};
        //定义新数组 用于存储抽奖的结果
        int[] newArr = new int[arr.length];
        Random r = new Random();
        for (int i = 0; i < arr.length; i++) {
            int index = r.nextInt(arr.length);
            int prize = arr[index];
            while(contains(newArr,prize)){
                index = r.nextInt(arr.length);
                prize = arr[index];
            }
            newArr[i] = prize;
        }
        //遍历输出
        for (int i = 0; i < newArr.length; i++) {
            System.out.println("第"+(i+1)+"个抽出的是"+newArr[i]);
        }

    }

    //用于判断奖池是否存在
    public static boolean contains(int[] arr, int prize) {
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == prize) {
                return true;
            }
        }
        return false;
    }
}

优化版代码:

package com.mohuanan.exercise;

import java.util.Random;

public class ExerciseTest09 {
    public static void main(String[] args) {
        int[] arr = {2, 588, 888, 1000, 10000};
        //打乱数组里的元素
        Random r = new Random();
        for (int i = 0; i < arr.length; i++) {
            //根据 i 和 随机索引 进行交换
            int temp;//临时变量
            int randomIndex = r.nextInt(arr.length);//注意这里要给一个范围 arr.length 因为是从0开始的 所以0 1 2 3 4
            temp = arr[i];
            arr[i] = arr[randomIndex];
            arr[randomIndex] = temp;
        }
        //遍历输出
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }

    }

}

代码分析:

1.使用Random对象中的nextInt()方法,打乱数组的元素,根据i索引于随机索引进行交换

2.相比于上面的代码,少了(假设到了最后的一个数字,要一直索引,直到arr数组里的元素不与索引的相同)

难点:

1.有些人可能会疑惑,为什么这样子可以打乱数组的元素,

解释:

交换两个数字,数组中的元素,没有改变,改变的只是数组的元素的位置,但是数组的元素还是原来的那几个,

题目八:双色球彩票系统

代码:

package com.mohuanan.exercise;

import java.util.Random;
import java.util.Scanner;

public class ExerciseTest010 {
    public static void main(String[] args) {
        //1.生成中奖号码
        int[] arr = createNumber();
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i]+" ");
        }

        System.out.println();

        //2.用户输入号码
        int[] peopleArr = peopleInputNumber();

        //3.计算获奖情况
        //中奖的个数
        int redCount = 0;
        int blueCount = 0;
        //计算中红色球的个数 要长度-1
        for (int i = 0; i < arr.length-1; i++) {
            for(int j = 0;j<peopleArr.length-1;j++){
                //找到就 红色球+1 并退出循环,避免没有必要的运算
                if(arr[i]==peopleArr[j]){
                    redCount++;
                    break;
                }
            }
        }
        //计算中蓝色球的个数
        if(arr[arr.length-1]==peopleArr[peopleArr.length-1]){//注意是下标 所以-1
            blueCount++;
        }
        //根据红蓝球的个数 判断获奖情况
        switch(redCount){
            case 6:
                if(blueCount==1){
                    System.out.println("恭喜你获得1000万 但是这是虚拟的 不要沉迷于");
                }else if(blueCount == 0){
                    System.out.println("恭喜你获得500万 但是这是虚拟的 不要沉迷于");
                }
                break;
            case 5:
                if(blueCount==1){
                    System.out.println("恭喜你获得3000元 但是这是虚拟的 不要沉迷于");
                }else if(blueCount == 0){
                    System.out.println("恭喜你获得200元 但是这是虚拟的 不要沉迷于");
                }
                break;
            case 4:
                if(blueCount==1){
                    System.out.println("恭喜你获得3000元 但是这是虚拟的 不要沉迷于");
                }else if(blueCount == 0){
                    System.out.println("恭喜你获得10元 但是这是虚拟的 不要沉迷于");
                }
                break;
            case 3:
                if(blueCount==1){
                    System.out.println("恭喜你获得10元 但是这是虚拟的 不要沉迷于");
                }
                break;
            case 2:
            case 1:
                if(blueCount==1){
                    System.out.println("恭喜你获得5元 但是这是虚拟的 不要沉迷于");
                }
                break;
            default :
                System.out.println("没中,再接再厉,下次再买,才怪,不要再买了");
        }

    }
    //用户输入号码
    public static int[] peopleInputNumber(){
        //动态定义一个数组
        int[] arr = new int[7];
        Scanner sc = new Scanner(System.in);
        //用户录入6个红球

        for (int i = 0; i < arr.length-1; ) {
            boolean flag = false;
            System.out.print("请输入您的第"+(i+1)+"个红球号码");
            int redNumber = sc.nextInt();
            // 如果录入的数字不存在就赋值   注意数字的范围(1-33)
            if((!judgeNumber(arr,redNumber)) && (redNumber>=1 && redNumber <=33)){
                arr[i] = redNumber;
                i++;//录入新的数字才 i++ 即录入下一个数字
                flag = true;

            }
            if(flag==false){
                System.out.print("您输入的号码出错");
            }
        }
        //用户录入蓝球
        System.out.print("请输入您的蓝球号码:");
        int blueNumber = sc.nextInt();
        // 注意数字的范围(1-16)
        if(blueNumber>=1 && blueNumber <=16){
            arr[arr.length-1] = blueNumber;

        }else{
            while(true){
                System.out.print("您的号码超出范围 请重新输入:");
                blueNumber = sc.nextInt();
                if(blueNumber>=1 && blueNumber <=16){
                    arr[arr.length-1] = blueNumber;
                    break;
                }
            }
        }
        return arr;
    }

    //生成中奖号码
    public static int[] createNumber() {
        //创建一个动态长度为7的数组
        int[] arr = new int[7];
        Random r = new Random();
        //红球号码
        for (int i = 0; i < arr.length - 1; ) {//因为6个红球 一个蓝 所以-1
            int redNumber = r.nextInt(33) + 1;//这里加1 使范围从 1到33

            //如果存在  就再 随机

            //如果不存在 就赋值 并 i++
            if (!judgeNumber(arr, redNumber)) {
                arr[i] = redNumber;
                i++;// 赋值后再i++ 注意i++放在这里 这是新的数字 才让 i++
            }
        }
        //蓝球号码
        int blueNumber = r.nextInt(16) + 1;
        arr[arr.length-1]= blueNumber;
        return arr;
    }

    //判断是否存在
    public static boolean judgeNumber(int[] arr, int redNumber) {
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == redNumber) {
                return true;
            }
        }
        return false;
    }
}

运行结果:

代码分析:

1. 根据需求,解决问题,分为3个步骤,

        1.1 生成一个获奖的代码,方法: 使用Random对象,动态创建一个长度为7(6红1蓝)的数组,当随机产生的数字要在范围内(红:1-33 蓝:1-16),并判断当前的数字在数组中是否存在,如果不存在,就将当前数字赋值到数组里,并i++,使将6个红球都赋值到数组里,最后再将蓝球号码赋值到数组的最后一个元素

        1.2 用户录入他的号码,方法: 动态创建一个长度为7(6红1蓝)的数组,使用Scanner对象,将用户录入的数字赋值到数组里面,(当随机产生的数字要在范围内(红:1-33 蓝:1-16),并判断当前的数字在数组中是否存在,如果不存在,就将当前数字赋值到数组里)使用while(true)使代码的健壮性更好,当用户输入的数字正确时,break,跳出循环

        1.3 定义redCount,blueCount,使用两个for计算中奖的红蓝球的个数,再根据中奖的红蓝球的个数,使用switch和if的嵌套来得出用户中奖的情况

2. 为了使代码更加的"好",可以增加一些注释和提高代码执行的效率,为了便于以后的维护,变量名和方法名一定要用通俗易懂的命名规则(驼峰原则) ,

题目九:买飞机票

代码:

package com.mohuanan.exercise;
 
import java.util.Scanner;
 
public class ExerciseDemo03 {
    public static void main(String[] args) {
        //创建一个Scanner对象
        Scanner sc = new Scanner(System.in);
        //原来票价
        System.out.println("请输入您的票价");
        int ticket = sc.nextInt();
        //月份
        System.out.println("请输入您的月份");
        int month = sc.nextInt();
        //舱位
        System.out.println("请输入您的舱位,0 头等舱 1经济舱");
        int seat = sc.nextInt();
 
        //旺季
        if(month >= 5 && month <= 10){
            //头等舱
            if(seat == 0){
                ticket = (int)(ticket * 0.9);//数据类型强制转化
 
            }else if(seat == 1){
                ticket = (int)(ticket * 0.85);
            }else{
                System.out.println("没有这个舱位");
            }
        //淡季
        }else if((month >= 1 && month <= 4) || month >= 11 && month <= 12){
            if(seat == 0){
                ticket = (int)(ticket * 0.7);//数据类型强制转化
 
            }else if(seat == 1){
                ticket = (int)(ticket * 0.65);
            }else{
                System.out.println("没有这个舱位");
            }
 
        }else{
            System.out.println("抱歉,您输入的月份不对");
        }
 
        System.out.println(ticket);
    }
}

代码分析:

                使用了if条件的嵌套,逐步细化问题,

题目十:二维数组

代码:

package com.mohuanan.exercise;

public class ExerciseTest012 {
    public static void main(String[] args) {
        //静态定义一个二维数组
        int[][] yearArrArr = {
                {1, 2, 3},
                {4, 5, 6},
                {7, 8, 9},
                {10, 11, 12}
        };
        //计算一年的和
        int yearSum = 0;

        for (int i = 0; i < yearArrArr.length; i++) {
            //int[] quarteArr = yearArrArr[i];
            int sum = getSum(yearArrArr[i]);
            System.out.println("第" + (i + 1) + "个季度和为" + sum);
            yearSum = yearSum + sum;
        }

        System.out.println("一年的和为"+yearSum);
        
    }

    //求每一个季度的销售额
    public static int getSum(int[] arr) {
        int sum = 0;
        for (int i = 0; i < arr.length; i++) {
            sum = sum + arr[i];
        }
        return sum;
    }
}

代码分析:

1.静态定义一个二维数组,使用getSum()方法求每一个季度的和,并返回给sum

2.使用一个for循环,求每一个季度的和,并定义一个yearSum的变量存储一年的和,每一次循环把每一个季度的和赋值给yearSum,并累加

目录

for循环的嵌套

题目一: 求101到200之间的素数的个数,并打印

代码分析:

注意点:

题目二:开发验证码

代码分析:

题目三:数组元素的复制

代码分析:

题目四:评委打分

健壮版代码:

代码分析:看源码

注意点:

题目五:数字加密

优化版代码:

代码分析:

题目六:数字解密

代码分析:

题目七:抢红包

优化版代码:

代码分析:

难点:

解释:

题目八:双色球彩票系统

运行结果:

代码分析:

题目九:买飞机票

代码分析:

题目十:二维数组

代码分析:


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1527665.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

HandyControl PropertyGrid及自定义编辑器

前提条件 项目引入对应HandyControl对应版本包。 使用案例 UI部分 <Window xmlns:hc"https://handyorg.github.io/handycontrol"><hc:TabControl><hc:TabItem Header"默认样式"><hc:PropertyGrid Width"380" SelectedO…

[RCTF2015]EasySQL ---不会编程的崽

今天也是sql注入的新类型---二次注入。不得不说花样真的多哦。 既然真的是sql注入了。那就不测试其他地方了。现在注册进去看一下界面 单纯的回显了名字。源代码里发现user.php。 可以修改密码&#xff1f;二次注入应该就在用户名这里了。因为修改密码时&#xff0c;用户名会被…

学习笔记Day11:初探Linux

Linux系统初探 Linux系统简介 发行版本Ubuntu/centOS&#xff0c;逻辑一样&#xff0c;都可以用。 服务器 本质是一台远程电脑&#xff0c;大多数服务器是Linux系统&#xff0c;通常使用命令行远程访问而不是桌面操作。LInux服务器允许多用户同时访问。NGS组学测序数据上游…

硬盘哨兵Hard Disk Sentinel Pro V6.20.0.0 便携版

Hard Disk Sentinel 是一款功能强大的硬盘监控和分析软件&#xff0c;专为 Windows 用户设计。它可以实时监测硬盘驱动器&#xff08;HDD&#xff09;、固态硬盘&#xff08;SSD&#xff09;、混合硬盘&#xff08;SSHD&#xff09;、NVMe SSD、RAID 数组和外部 RAID 盒子的健康…

pdf文件属性的删除

pdf文件属性的删除 投标过程中需要处理文件属性&#xff0c;特别是word文件属性以及pdf文件的处理 这里讲解pdf文件属性的处理 word处理在我的另外一个博客中&#xff0c;word文件属性的处理 https://ht666666.blog.csdn.net/article/details/134102504 一般用 adobe acroba…

MySQL—数据库导入篇

什么是数据库&#xff1f; 数据库是干啥的&#xff1f; 数据库&#xff08;Database&#xff09;是按照数据结构来组织、存储和管理数据的仓库。 MySQL属于哪一类数据库&#xff1f; MySQL是一种关系型数据库。所谓的关系型数据库&#xff0c;是建立在关系模型基础上的数据库&a…

LabVIEW飞行器螺旋桨性能测试与数据监控

LabVIEW飞行器螺旋桨性能测试与数据监控 开发LabVIEW的电动飞行器螺旋桨性能测试与数据监控系统&#xff0c;专门针对电动飞行器螺旋桨在运行过程中的性能测试和监控需求。通过采集转速、转矩、拉力和温度等关键参数&#xff0c;系统能够实时监测和分析螺旋桨的状态&#xff0…

深度学习_ResNet_5

ResNet学习目标 什么是ResNet为什么要引入ResNet&#xff1f;ResNet网络结构的特点利用ResNet完成图像分类 什么是ResNet&#xff1f; ResNet&#xff08;Residual Network&#xff09;是一种深度残差网络&#xff0c;由何凯明等人在2015年提出&#xff0c;是深度学习领域中一…

网络视频播放器|基于JSP技术+ Mysql+Java+ B/S结构的网络视频播放器设计与实现(可运行源码+数据库+设计文档)

推荐阅读100套最新项目 最新ssmjava项目文档视频演示可运行源码分享 最新jspjava项目文档视频演示可运行源码分享 最新Spring Boot项目文档视频演示可运行源码分享 2024年56套包含java&#xff0c;ssm&#xff0c;springboot的平台设计与实现项目系统开发资源&#xff08;可…

3D模型优化服务+三维可视化+数字孪生+元宇宙=眸瑞科技

眸瑞科技&#xff1a;老子云平台AMRT3D数字孪生引擎 老子云概述 老子云3D可视化快速开发平台&#xff0c;集云压缩、云烘焙、云存储云展示于一体&#xff0c;使3D模型资源自动输出至移动端PC端、Web端&#xff0c;能在多设备、全平台进行展示和交互&#xff0c;是全球领先、自…

MYSQL日志 redo_log更新流程 bin_log以及bin_log数据恢复

Redo_log写入策略 Redo log的Innodb_flush_log_at_trx_commit:: 这个参数有三个取值 取值为0&#xff1a;每次事务提交时&#xff0c;只是把redo_log留在 redo log buffer中&#xff0c;宕机会丢失数据&#xff1b; 取值为1&#xff08;默认值&#xff09;&#xff1a;每次事…

代码随想录算法训练营第day30|332.重新安排行程 、 51. N皇后 、37. 解数独

目录 332.重新安排行程 思路&#xff1a; 51. N皇后 思路&#xff1a; 37. 解数独 332.重新安排行程 力扣题目链接 (opens new window) 给定一个机票的字符串二维数组 [from, to]&#xff0c;子数组中的两个成员分别表示飞机出发和降落的机场地点&#xff0c;对该行程进…

Jenkins-pipeline流水线构建完钉钉通知

添加钉钉机器人 在钉钉群设置里添加机器人拿出Webhook地址&#xff0c;设置关键词 Jenkins安装钉钉插件 Dashboard > 系统管理 > 插件管理&#xff0c;搜索构建通知&#xff0c;直接搜索Ding Talk也行 安装DingTalk插件&#xff0c;重启Jenkins 来到Dashboard > 系…

探索编程迷宫:选择你的职业赛道

在现代科技的浪潮中&#xff0c;程序员的职业赛道就像是一座迷宫&#xff0c;充满着前端的美丽花园&#xff0c;后端的黑暗洞穴&#xff0c;以及数据科学的神秘密室。这个迷宫中&#xff0c;每一条通道都充满了挑战和机遇&#xff0c;而每一个行走其中的人都在寻找着属于自己的…

sentinel系统负载自适应流控

系统负载自适应流控 规则配置 规则创建 public class SystemRule extends AbstractRule {private double highestSystemLoad -1;private double highestCpuUsage -1;private double qps -1;private long avgRt -1;private long maxThread -1; }SystemRule类包含了以下几…

设计模式学习笔记 - 设计原则与思想总结:2.运用学过的设计原则和思想完善之前性能计数器项目

概述 在 《设计原则 - 10.实战&#xff1a;针对非业务的通用框架开发&#xff0c;如何做需求分析和设计及如何实现一个支持各种统计规则的性能计数器》中&#xff0c;我们讲解了如何对一个性能计数器框架进行分析、设计与实现&#xff0c;并且实践了一些设计原则和设计思想。当…

如何使用 ArcGIS Pro 生成TIN

三角网是一种常用于表示地表地形的数字地球模型&#xff08;DEM&#xff09;方式&#xff0c;我们可以通过 ArcGIS Pro 将等高线和高程点转换为TIN&#xff0c;这里为大家介绍一下转换方法&#xff0c;希望能对你有所帮助。 数据来源 教程所使用的数据是从水经微图中下载的高…

vue2使用webSocket双向通讯

基于webSocket实现双向通信&#xff0c;使用webworker保持心跳。 由于浏览器的资源管理策略会暂停或限制某些资源的消耗&#xff0c;导致前端心跳包任务时效&#xff0c;后端接收不到webSocket心跳主动断开&#xff0c;因此需要使用webworker保持心跳 引入webworker npm insta…

CSDN 停更通知

CSDN 不再更新&#xff0c;欢迎关注我的微信公众号&#xff0c;分享更多有趣的技术内容。 如果大家有任何疑问&#xff0c;或者感兴趣的话题&#xff0c;都可以通过微信公众号与我交流&#xff0c;相互学习&#xff0c;相互成长。

Trent电源设计那些事儿教学

本课程将深入探讨Trent电源设计的关键概念与技术。学生将学习功率电子器件和拓扑、电路保护、稳压技术以及EMI滤波等内容。通过理论和实践相结合的教学方式&#xff0c;帮助学员掌握Trent电源设计的原理与应用。 课程大小&#xff1a;12.5G 课程下载&#xff1a;https://down…