java学习笔记-初级

一、变量

1.双标签

  <!-- 外部js script 双标签 -->

    <script src='my.js'></script>

在新文件my.js里面写:

2.字符串定义:

//外单内双

        var str = '我是一个"高富帅"的程序员';

        console.log(str);

        // 字符串转义字符  都是用 \ 开头 但是这些转义字符写在引号里面

        //外双引号内单引号

        var str1 = "我是一个'高富帅'的\n程序员";// \n 是换行


        console.log(str1);

3.字符串拼接

   // 1. 检测获取字符串的长度 length 

    var str = 'my name is andy';

        console.log(str.length); // 15

        // 2. 字符串的拼接 +  只要有字符串和其他类型相拼接 最终的结果是字符串类型

        console.log('沙漠' + '骆驼'); // 字符串的 沙漠骆驼

        console.log('pink老师' + 18); // 'pink老师18'

        console.log('pink' + true); // pinktrue

        console.log(12 + 12); // 24

        console.log('12' + 12); // '1212'

  console.log('pink老师' + 18 + '岁');

        var age = 19;

        console.log('pink老师' + age + '岁');

案例:

   var age=prompt('请输入您的年龄');

         var str1='您已经'+age+'岁了';

         alert(str1)

4.boolean 及undefined 和null

     var flag=true;//flag 布尔型

      var flag1=false;

      console.log(flag+1);//true参与加法运算当成1

      console.log(flag1+1);//false参与加法运算当成0

    // 如果一个变量声明未赋值 就是 undefined 未定义数据类型

        var str;

        console.log(str);

        var variable = undefined;

        console.log(variable + 'pink'); // undefinedpink

        console.log(variable + 1); // NaN  undefined 和数字相加最后的结果是 NaN

        // null 空值

        var space = null;

        console.log(space + 'pink'); // nullpink

        console.log(space + 1); // 1

5.typeof检测变量数据类型:

   var num = 10;

        console.log(typeof num); // number

        var str = 'pink';

        console.log(typeof str); // string

        var flag = true;

        console.log(typeof flag); // boolean

        var vari = undefined;

        console.log(typeof vari); // undefined

        var timer = null;

        console.log(typeof timer); // object

        // prompt 取过来的值是 字符型的

        var age = prompt('请输入您的年龄');

        console.log(age);

        console.log(typeof age);

6.字符串的不可变性

  var str = 'andy';

        console.log(str);

        str = 'red';

        console.log(str);

        // 因为我们字符串的不可变所以不要大量的拼接字符串

        var str = '';

        for (var i = 1; i <= 1000000000; i++) {

            str += i;

        }

        console.log(str);

7.数据类型转换

1.转为字符串

      //toString()

       var num=10;

       console.log(num);

       var str=num.toString();

       console.log(str);

       console.log(typeof str);

       //String(变量)

       console.log(String(num));

       //+拼接字符串方法

       console.log(''+num);

黑字体是字符串

2.转为数字

// var age = prompt('请输入您的年龄');

        // 1. parseInt(变量)  可以把 字符型的转换为数字型 得到是整数

        // console.log(parseInt(age));

        console.log(parseInt('3.14')); // 3 取整

        console.log(parseInt('3.94')); // 3 取整

        console.log(parseInt('120px')); // 120 会去到这个px单位

        console.log(parseInt('rem120px')); // NaN

        // 2. parseFloat(变量) 可以把 字符型的转换为数字型 得到是小数 浮点数

        console.log(parseFloat('3.14')); // 3.14

        console.log(parseFloat('120px')); // 120 会去掉这个px单位

        console.log(parseFloat('rem120px')); // NaN

        // 3. 利用 Number(变量) 

        var str = '123';

        console.log(Number(str));

        console.log(Number('12'));

        // 4. 利用了算数运算 -  *  /  隐式转换

        console.log('12' - 0); // 12

        console.log('123' - '120');

        console.log('123' * 1);

案例1:计算年龄:

// 弹出一个输入框(prompt),让用户输入出生年份 (用户输入)

        // 把用户输入的值用变量保存起来,然后用今年的年份减去变量值,结果就是现在的年龄  (程序内部处理)

        // 弹出警示框(alert) , 把计算的结果输出 (输出结果)

        var year = prompt('请您输入您的出生年份');

        var age = 2021 - year; // year 取过来的是字符串型  但是这里用的减法 有隐式转换

        alert('您今年已经' + age + '岁了');
3.转换为布尔型

     

    //代表空、否定的值会被转换为false,

        //如''、0、NaN、null、undefined

        console.log(Boolean('')); // false

        console.log(Boolean(0)); // false

        console.log(Boolean(NaN)); // false

        console.log(Boolean(null)); // false

        console.log(Boolean(undefined)); // false

        //其余都是true

        console.log('------------------------------');

        console.log(Boolean('123'));

        console.log(Boolean('你好吗'));

        console.log(Boolean('我很好'));

8.返回字符串和位置

1.根据位置返回字符

        // 1. charAt(index) 根据位置返回字符

        var str = 'andy';

        console.log(str.charAt(3));

        // 遍历所有的字符

        for (var i = 0; i < str.length; i++) {

            console.log(str.charAt(i));

        }

        // 2. charCodeAt(index)  返回相应索引号的字符ASCII 目的: 判断用户按下了那个键

        console.log(str.charCodeAt(0)); // 97

        // 3. str[index] H5 新增的

        console.log(str[0]); // a

2.根据字符返回位置
  //str.indexOf('要查找的字符', [起始的位置])

var str = '改革春风吹满地,春天来了';

        console.log(str.indexOf('春'));//2

        console.log(str.indexOf('春', 3)); //8 、从索引号是 3的位置开始往后查找

9.查找字符串中某个字符出现的次数

 var str = "oaoefoxyozzop";

        var index = str.indexOf('o');

        var num = 0;

        // console.log(index);

        while (index !== -1) {

            console.log(index);

            num++;

            index = str.indexOf('o', index + 1);//从下一个o开始再找

        }

        console.log('o出现的次数是: ' +num);

10. 判断一个字符串中出现次数最多的字符,并统计其次数。

// 有一个对象 来判断是否有该属性 对象['属性名']

var o = {

            age: 18

        }

        if (o['sex']) {

            console.log('里面有该属性');

        } else {

            console.log('没有该属性');

        }

        // 核心算法:利用 charAt() 遍历这个字符串

        // 把每个字符都存储给对象, 如果对象没有该属性,就为1,如果存在了就 +1

        // 遍历对象,得到最大值和该字符

        var str = 'aboooo';

        var obj= {};

        for (var i = 0; i < str.length; i++) {

            var chars = str.charAt(i); // chars 是字符串的每一个字符

            if (obj[chars]) { // o[chars] 得到的是属性值,i=0时是判断o里面是否有a这个属性值

                obj[chars]++;//当o里面有a这个属性时就将a这个属性的值加1

            } else {

                obj[chars] = 1;}//当o里面没有a这个属性时就将a这个属性的值赋值为1,最后的结果:a:1,b:1,o:4 

        }

        console.log(obj);//{a:1,b:1,o:4}

        // 2. 遍历对象

        var max = 0;

        var ch = '';

        for (var k in obj) {

            // k 得到是 属性名

            // o[k] 得到的是属性值

            if (obj[k] > max) {

                max = obj[k];

                ch = k;

            }

        }

        console.log(max);

        console.log('最多的字符是' + ch);

        alert('a的值为'+obj.a);//1

        alert('b的值为'+obj.b);//1

        alert('o的值为'+obj.o);//4

11.字符串操作方法

        // 1. concat('字符串1','字符串2'....)

        var str = 'andy';

        console.log(str.concat('red'));

        // 2. substr('截取的起始位置', '截取几个字符');

        var str1 = '改革春风吹满地';

        console.log(str1.substr(2, 2)); // 第一个2 是索引号的2 从第几个开始  第二个2 是取几个字符

         // 1. 替换字符 replace('被替换的字符', '替换为的字符')  它只会替换第一个字符

        var str = 'andyandy';

        console.log(str.replace('a', 'b'));

        // 有一个字符串 'abcoefoxyozzopp'  要求把里面所有的 o 替换为 *

        var str1 = 'abcoefoxyozzopp';

        while (str1.indexOf('o') !== -1) {

            str1 = str1.replace('o', '*');

        }

        console.log(str1);

        // 2. 字符转换为数组 split('分隔符') 前面我们学过 join 把数组转换为字符串

       ar str2 = ['red', 'pink', 'blue'];

        console.log(str2.join(''));//redpinkblue

        var str3 = 'red&pink&blue';

        console.log(str3.split('&'));// ["red", "pink", "blue"]
  • 运算符
  1. 算数运算符
1.基本运算
console.log(1 + 1); // 2

        console.log(1 - 1); // 0

        console.log(1 * 1); // 1

        console.log(1 / 1); // 1

        // % 取余 (取模)  

        console.log(4 % 2); // 0

        console.log(5 % 3); // 2

        console.log(3 % 5); // 3

        // 浮点数 算数运算里面会有问题

        console.log(0.1 + 0.2); // 0.30000000000000004

        console.log(0.07 * 100); // 7.000000000000001

        // 我们不能直接拿着浮点数来进行相比较 是否相等

        var num = 0.1 + 0.2;

        console.log(num == 0.3); // false
2.逻辑运算符
           // 1. 逻辑与 &&  and 两侧都为true  结果才是 true  只要有一侧为false  结果就为false 

        console.log(3 > 5 && 3 > 2); // false

        console.log(3 < 5 && 3 > 2); // true

        // 2. 逻辑或 || or  两侧都为false  结果才是假 false  只要有一侧为true  结果就是true

        console.log(3 > 5 || 3 > 2); // true 

        console.log(3 > 5 || 3 < 2); // false

        // 3. 逻辑非  not  ! 

        console.log(!true); // false
3.短路逻辑
   // 1. 用我们的布尔值参与的逻辑运算  true && false  == false 

        // 2. 123 && 456  是值 或者是 表达式 参与逻辑运算? 

        // 3. 逻辑与短路运算  如果表达式1 结果为真 则返回表达式2  如果表达式1为假 那么返回表达式1

        console.log(123 && 456); // 456

        console.log(0 && 456); //  0

        console.log(0 && 1 + 2 && 456 * 56789); // 0为假,‘1 + 2 && 456 * 56789’不再参与运算

        console.log('' && 1 + 2 && 456 * 56789); // ''

        // 如果有空的或者否定的为假 其余是真的  0  ''  null undefined  NaN

        // 4. 逻辑或短路运算  如果表达式1 结果为真 则返回的是表达式1 如果表达式1 结果为假 则返回表达式2

        console.log(123 || 456); // 123

        console.log(123 || 456 || 456 + 123); // 123

        console.log(0 || 456 || 456 + 123); // 456

        // 逻辑中断很重要 它会影响我们程序运行结果思密达

        var num = 0;

        console.log(123 || num++);

        console.log(num); // 0
4.运算符优先级

  • 流程控制

1.分支

if和else(和c一样)

1.三元表达式

      var num = 10;

        var result = num > 5 ? '是的' : '不是的'// 我们知道表达式是有返回值的

        console.log(result);

1.switch语句

      switch (3) {

            case 1:

                console.log('这是1');

                break;

            case 2:

                console.log('这是2');

                break;

            case 3:

                console.log('这是3');

                break;

            default:

                console.log('没有匹配结果');

        }

  1. 循环

1.for循环:

    //打印三角形

    var str='';

    var raw;

    raw=prompt('输入打印行数');

    for(var i=0;i<=raw;i++){

        for(var j=0;j<=i;j++){

            str=str+'*';

        }

        str=str+'\n';

    }

console.log(str);

  //打印乘法表

    var str='';

    var raw;

    for(var i=1;i<=9;i++){

        for(var j=1;j<=i;j++){

            str=str+i+'*'+j+'='+i*j;

            str=str+'\t';

        }

        str=str+'\n';

    }

    console.log(str);

2.do while

    // 1.do while 循环 语法结构

  do {

            // 循环体

        } while (条件表达式)

        // 2.  执行思路 while不同的地方在于 do while 先执行一次循环体 在判断条件 如果条件表达式结果为真,则继续执行循环体,否则退出循环

        // 3. 代码验证

        var i = 1;

        do {

            console.log('how are you?');

            i++;

        } while (i <= 100)

        // 4. 我们的do while 循环体至少执行一次

  1. continue

  // continue 关键字   退出本次(当前次的循环)  继续执行剩余次数循环

 for (var i = 1i <= 5i++) {

            if (i == 3) {

                continue// 只要遇见 continue就退出本次循环 直接跳到 i++

            }

            console.log('我正在吃第' + i + '个包子');

        }

  • 数组
  1. 数组对象的创建
 // 1. 利用数组字面量

        var arr = [1, 2, 3];

        console.log(arr[0]);

  // 2. 利用new Array()

        // var arr1 = new Array();  // 创建了一个空的数组

        // var arr1 = new Array(2);  // 这个2 表示 数组的长度为里面有2个空的数组元素

        var arr1 = new Array(2, 3); // 等价于 [2,3]  这样写表示 里面有2个数组元素 23

        console.log(arr1);

  1. 检测是否是数组

        // (1) instanceof  运算符 它可以用来检测是否为数组

        var arr = [];

        var obj = {};

        console.log(arr instanceof Array);

        console.log(obj instanceof Array);

        // (2) Array.isArray(参数);  H5新增的方法  ie9以上版本支持

        console.log(Array.isArray(arr));

        console.log(Array.isArray(obj));

  1. 数组元素的增删

 // 1. push() 在我们数组的末尾 添加一个或者多个数组元素   push  推

        var arr = [123];

        // arr.push(4, 'pink');

        console.log(arr.push(4'pink'));

        console.log(arr);

        // (1) push 是可以给数组追加新的元素

        // (2) push() 参数直接写 数组元素就可以了

        // (3) push完毕之后,返回的结果是 新数组的长度 

        // (4) 原数组也会发生变化

        // 2. unshift 在我们数组的开头 添加一个或者多个数组元素

        console.log(arr.unshift('red''purple'));

        console.log(arr);

        // (1) unshift是可以给数组前面追加新的元素

        // (2) unshift() 参数直接写 数组元素就可以了

        // (3) unshift完毕之后,返回的结果是 新数组的长度 

        // (4) 原数组也会发生变化

        // 3. pop() 它可以删除数组的最后一个元素  

        console.log(arr.pop());

        console.log(arr);

        // (1) pop是可以删除数组的最后一个元素 记住一次只能删除一个元素

        // (2) pop() 没有参数

        // (3) pop完毕之后,返回的结果是 删除的那个元素 

        // (4) 原数组也会发生变化

        // 4. shift() 它可以删除数组的第一个元素  

        console.log(arr.shift());

        console.log(arr);

        // (1) shift是可以删除数组的第一个元素 记住一次只能删除一个元素

        // (2) shift() 没有参数

        // (3) shift完毕之后,返回的结果是 删除的那个元素 

        // (4) 原数组也会发生变化

4.数组排序

  // 冒泡排序

        // var arr = [5, 4, 3, 2, 1];

        var arr = [41235];

        for (var i = 0i <= arr.length - 1i++) { // 外层循环管趟数 

            for (var j = 0j <= arr.length - i - 1j++) { // 里面的循环管 每一趟的交换次数

                // 内部交换2个变量的值 前一个和后面一个数组元素相比较

                if (arr[j] < arr[j + 1]) {

                    var temp = arr[j];

                    arr[j] = arr[j + 1];

                    arr[j + 1] = temp;

                }

            }

        }

        console.log(arr);

   // 1. 翻转数组

        var arr = ['pink', 'red', 'blue'];

        arr.reverse();

        console.log(arr);

        // 2. 数组排序(冒泡排序)

        var arr1 = [13, 4, 77, 1, 7];

        arr1.sort(function(a, b) {

            //  return a - b; 升序的顺序排列

            return b - a; // 降序的顺序排列

        });

        console.log(arr1);

  1. 获取数组元素索引
  // 返回数组元素索引号方法  indexOf(数组元素作用就是返回该数组元素的索引号 从前面开始查找

        // 它只返回第一个满足条件的索引号

        // 它如果在该数组里面找不到元素,则返回的是 -1 

        // var arr = ['red', 'green', 'blue', 'pink', 'blue'];

        var arr = ['red', 'green', 'pink'];

        console.log(arr.indexOf('blue'));

        // 返回数组元素索引号方法  lastIndexOf(数组元素作用就是返回该数组元素的索引号 从后面开始查找

        var arr = ['red', 'green', 'blue', 'pink', 'blue'];

        console.log(arr.lastIndexOf('blue')); // 4

    </script>

  1. 数组去重
  // 封装一个 去重的函数 unique 独一无二的 

        function unique(arr) {

            var newArr = [];

            for (var i = 0; i < arr.length; i++) {

                if (newArr.indexOf(arr[i]) == -1) {

                    newArr.push(arr[i]);

                }

            }

            return newArr;

        }

        // var demo = unique(['c', 'a', 'z', 'a', 'x', 'a', 'x', 'c', 'b'])

        var demo = unique(['blue', 'green', 'blue'])

        console.log(demo);

6.数组转换为字符串

        // 1. toString() 将我们的数组转换为字符串

        var arr = [1, 2, 3];

        console.log(arr.toString()); // 1,2,3

        // 2. join(分隔符)

        var arr1 = ['green', 'blue', 'pink'];

        console.log(arr1.join()); // green,blue,pink

        console.log(arr1.join('-')); // green-blue-pink

        console.log(arr1.join('&')); // green&blue&pink

7.基本包装类型

        var str = 'andy';

        console.log(str.length);

        // 对象(var obj={})才有 属性和方法   复杂数据类型才有 属性和方法

        // 简单数据类型为什么会有length 属性呢?

        // 基本包装类型:  就是把简单数据类型 包装成为了 复杂数据类型

        // (1) 把简单数据类型包装为复杂数据类型

        //相当于执行以下操作

        var temp = new String('andy');

        // (2) 把临时变量的值 str

        str = temp;

        // (3) 销毁这个临时变量

        temp = null;

  • 函数

1.语法

   function sayHi() {

            console.log('hi~~');

        }

        // (1) function 声明函数的关键字 全部小写

        // (2) 函数是做某件事情,函数名一般是动词 sayHi 

        // (3) 函数不调用自己不执行

        // 2. 调用函数

        // 函数名();

        sayHi();

        // 调用函数的时候千万不要忘记加小括号

2.参数

1.实参和形参

        function cook(aru) { // 形参是接受实参的  aru = '酸辣土豆丝' 形参类似于一个变量

            console.log(aru);

        }

        cook('酸辣土豆丝');

        cook('大肘子');

        // 4. 函数的参数可以有,也可以没有个数不限

2.参数匹配
     // 函数形参实参个数匹配
        function getSum(num1, num2) {
            console.log(num1 + num2);
 
        }
        // 1. 如果实参的个数和形参的个数一致 则正常输出结果
        getSum(1, 2);
        // 2. 如果实参的个数多于形参的个数  会取到形参的个数 
        getSum(1, 2, 3);
        // 3. 如果实参的个数小于形参的个数  多于的形参定义为undefined  最终的结果就是 NaN
        // 形参可以看做是不用声明的变量  num2 是一个变量但是没有接受值  结果就是undefined 
        getSum(1); // NaN
        // 建议 我们尽量让实参的个数和形参相匹配
3.复杂的数据类型传参

// 复杂数据类型传参

function Person(name) {

            this.name = name;

        }

        function f1(x) { // x = p

            console.log(x.name);  

            x.name = "张学友";

            console.log(x.name); // 3. 这个输出什么 ?   张学友

        }

        var p = new Person("刘德华");

        console.log(p.name); // 1. 这个输出什么 ?刘德华 

        f1(p);               // 2. 这个输出什么 ?刘德华  张学友

        console.log(p.name); // 4. 这个输出什么 ?张学友 p->x->张学友

 
  1. 返回值
 // 函数返回值注意事项
        // 1. return 终止函数
        function getSum(num1, num2) {
            return num1 + num2; // return 后面的代码不会被执行
            alert('我是不会被执行的哦!')
        }
        console.log(getSum(1, 2));
        // 2. return 只能返回一个值
        function fn(num1, num2) {
            return num1, num2; // 返回的结果是最后一个值
        }
        console.log(fn(1, 2));
 
        // 3.  我们求任意两个数的 加减乘数结果
        function getResult(num1, num2) {
            return [num1 + num2, num1 - num2, num1 * num2, num1 / num2];
        }
        var re = getResult(1, 2); // 返回的是一个数组
        console.log(re);
        // 4. 我们的函数如果有return 则返回的是 return 后面的值,如果函数么有 return 则返回undefined
        function fun1() {
            return 666;
        }
        console.log(fun1()); // 返回 666
        function fun2() {
 
        }
        console.log(fun2()); // 函数返回的结果是 undefined
 
 
  1. arguments

当我们不确定有多少个参数传递的时候,可以用arguments来获取。在JavaScript中,arguments实际上它是当前函数的一个内置对象。所有函数都内置了一个arguments对象,arguments对象中存储了传递的所有实参。

 // arguments 的使用  只有函数才有 arguments对象  而且是每个函数都内置好了这个arguments

function fn() {

            // console.log(arguments); // 里面存储了所有传递过来的实参  arguments = [1,2,3]

            // console.log(arguments.length);

            // console.log(arguments[2]);

            // 我们可以按照数组的方式遍历arguments

            for (var i = 0i < arguments.lengthi++) {

                console.log(arguments[i]);}}

        fn(123);

        fn(12345);

        // 伪数组 并不是真正意义上的数组

        // 1. 具有数组的 length 属性

        // 2. 按照索引的方式进行存储的

        // 3. 它没有真正数组的一些方法 pop()  push() 等等

  1. 函数声明
 // 函数的2中声明方式
        // 1. 利用函数关键字自定义函数(命名函数)
        function fn() {
 
        }
        fn();
        // 2. 函数表达式(匿名函数) 
        // var 变量名 = function() {};
        var fun = function(aru) {
            console.log('我是函数表达式');
            console.log(aru);
 
        }
        fun('pink老师');
        // (1) fun是变量名 不是函数名  
        // (2) 函数表达式声明方式跟声明变量差不多,只不过变量里面存的是值  函数表达式里面存的是函数
        // (3) 函数表达式也可以进行传递参数

  • 作用域

1.基本作用域

   // 1.JavaScript作用域  就是代码名字(变量)在某个范围内起作用和效果 目的是为了提高程序的可靠性更重要的是减少命名冲突

        // 2. js的作用域(es6)之前 :全局作用域   局部作用域 

        // 3. 全局作用域: 整个script标签 或者是一个单独的js文件

        var num = 10;

        var num = 30;

        console.log(num);

        // 4. 局部作用域(函数作用域) 在函数内部就是局部作用域 这个代码的名字只在函数内部起效果和作用

        function fn() {

            // 局部作用域

            var num = 20;

            console.log(num);

        }

        fn();

 // js中没有块级作用域  js的作用域: 全局作用域  局部作用域  现阶段我们js 没有 块级作用域
        // 块级作用域 {}   if {}  for {}
        // java 
        // if(xx) {
        //     int num = 10;
        // }
        // 外面的是不能调用num
        if (3 < 5) {
            var num = 10;
        }
        console.log(num); //外面是可以调用num的
2.作用域链

·只要是代码,就至少有一个作用域

·写在函数内部的局部作用域

·如果函数中还有函数,那么在这个作用域中就又可以诞生一个作用域

·根据在内部函数可以访问外部函数变量的这种机制,用镇式查找决定哪些数据能被内部函数访问,就称作作用域链

     // 作用域链  : 内部函数访问外部函数的变量,采取的是链式查找的方式来决定取那个值 这种结构我们称为作用域链   就近原则

        var num = 10;
 
        function fn() { // 外部函数
            var num = 20;
 
            function fun() { // 内部函数
                console.log(num);
 
            }
            fun();
        }
        fn();
 
 
一层一层向上找:

3.案例

案例1.

 // 案例 结果是几?

        function f1() {

            var num = 123;

            function f2() {

                console.log(num); // 站在目标出发,一层一层的往外查找

            }

            f2();

        }

        var num = 456;

        f1();

案例2.

// 案例2 :结果是几?

        var a = 1;

        function fn1() {

            var a = 2;

            var b = '22';

            fn2();

            function fn2() {

                var a = 3;

                fn3();

                function fn3() {

                    var a = 4;

                    console.log(a); //a的值 ?

                    console.log(b); //b的值 ?

                }

            }

        }

        fn1();

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Jenkins自动化部署之流水线模式部署

文章目录 任务类型Pipeline流水线项目声明式的Pipeline脚本式Pipeline 示例脚本生成Tools配置示例 高级Pipeline Script from SCM 任务类型 在Jenkins中&#xff0c;有不同类型的任务&#xff08;项目&#xff09;适用于不同的构建需求。以下是一些常见的Jenkins任务类型&…

供应链投毒预警 | 恶意NPM包利用Windows反向shell后门攻击开发者

概述 本周&#xff08;2024年02月19号&#xff09;&#xff0c;悬镜供应链安全情报中心在NPM官方仓库&#xff08;https://npmjs.com&#xff09;中发现多起NPM组件包投毒事件。攻击者利用包名错误拼写方式 (typo-squatting)在NPM仓库中连续发布9个不同版本的恶意包&#xff0…

ubuntu20.04 ROS-Noetic 配置qtcreator的ROS环境

文章目录 1 安装qtcreator1.1 下载安装Qt1.2 配置命令启动qtcreator2 配置ROS2.1 直接安装qtcreator-ros2.2 在qtcreator上安装ros_qtc_plugin插件3 注意3.1 构建套件3.2 更新、删除qt4 参考链接1 安装qtcreator QT官网:Qt Downloads 下载包链接:qt5.12.12 Qt5.12.12默认qtc…

SpringBoot使用classfinal-maven-plugin插件加密Jar包

jar包加密 1、在启动类的pom.xml中加入classfinal-maven-plugin插件 <build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin><plugin><…

官网万词霸屏推广+关键词排名优化源码系统 带完整的安装代码包以及搭建教程

随着搜索引擎算法的不断更新和市场竞争的加剧&#xff0c;传统的SEO方法已经难以满足企业对于快速、高效推广的需求。罗峰结合多年的互联网营销经验和最新的搜索引擎优化技术&#xff0c;给大家推荐一款集网站搭建、关键词优化、数据分析于一体的源码系统。 以下是部分代码示例…

Linux信号【产生-保存-处理】

目录 前言&#xff1a; 1、进程信号基本概念 1.1、什么是信号&#xff1f; 1.2、信号的作用 2、键盘键入 2.1、ctrlc 终止前台进程 2.1.1、signal 注册执行动作 3、系统调用 3.1、kill 函数 3.2、模拟实现 myKill 3.3、raise 函数 3.4、abort 函数 4、软件条件信号…

时间序列分析实战(十一):ECM误差修正模型

&#x1f349;CSDN小墨&晓末:https://blog.csdn.net/jd1813346972 个人介绍: 研一&#xff5c;统计学&#xff5c;干货分享          擅长Python、Matlab、R等主流编程软件          累计十余项国家级比赛奖项&#xff0c;参与研究经费10w、40w级横向 文…

服务器数据恢复-服务器RAID5上层XFS文件系统分区数据恢复案例

服务器数据恢复环境&#xff1a; MD1200磁盘柜中的磁盘通过RAID卡创建了一组RAID5阵列&#xff0c;分配了一个LUN。在Linux操作系统层面对该LUN进行了分区&#xff0c;划分sdc1和sdc2两个分区&#xff0c;通过LVM扩容的方式将sdc1分区加入到了root_lv中&#xff1b;sdc2分区格式…

代码随想录第46天|139.单词拆分 多重背包理论基础 背包总结

文章目录 单词拆分思路&#xff1a;代码 多重背包≈0-1背包题目代码 背包总结 单词拆分 3 思路&#xff1a; 代码 class Solution {public boolean wordBreak(String s, List<String> wordDict) {HashSet<String> set new HashSet<>(wordDict);boolean[]…

视频记录仪_基于联发科MT6762的智能4G记录仪方案

智能记录仪采用联发科强劲八核处理器&#xff0c;12nm制程工艺的记录仪具便是满足这些需求的理想选择。搭载4GB32GB内存&#xff0c;并运行Android 11.0操作系统&#xff0c;这款记录仪具展现出强劲的性能表现。 首先&#xff0c;这款记录仪具具备优秀的视频录制功能。它能完整…

综合练习(一)

目录 列出薪金高于部门 30 的所有员工薪金的员工姓名和薪金、部门名称、部门人数 列出与 ALLEN从事相同工作的所有员工及他们的部门名称、部门人数、领导姓名 Oracle从入门到总裁:https://blog.csdn.net/weixin_67859959/article/details/135209645 列出薪金高于部门 30 的所…

【音视频处理】使用ffmpeg实现多个视频合成一个视频(按宫格视图)

先上结果 环境 硬件&#xff1a;通用PC 系统&#xff1a;Windows 测试有效 软件&#xff1a;ffmpeg 解决 0、命令 ffmpeg.exe -i input1.mp4 -i input2.mp4 -i input3.mp4 -i input4.mp4 -filter_complex "[0:v]scaleiw/2:ih/2,pad2*iw:2*ih[a]; [1:v]scaleiw/2:ih/2…

人脸2D和3D道具SDK解决方案提供商

人脸识别和增强现实技术成为了许多企业和开发者关注的焦点&#xff0c;为了满足市场对高质量、易于集成的人脸识别SDK的需求&#xff0c;美摄科技推出了一系列领先的人脸2D/3D道具SDK解决方案。 一、产品特点 高精度识别&#xff1a;美摄科技的人脸识别技术采用深度学习算法&…

【OCR识别】使用OCR技术还原加密字体文字

文章目录 1. 写在前面2. 页面分析3. 字符知识4. 加密分析 【作者主页】&#xff1a;吴秋霖 【作者介绍】&#xff1a;Python领域优质创作者、阿里云博客专家、华为云享专家。长期致力于Python与爬虫领域研究与开发工作&#xff01; 【作者推荐】&#xff1a;对JS逆向感兴趣的朋…

VirtualBox虚拟机安装 Linux 系统

要想学习各种计算机技术&#xff0c;自然离不开Linux系统。并且目前大多数生产系统都是安装在Linux系统上。常用的Linux系统有 Redhat&#xff0c;Centos&#xff0c;OracleLinux 三种。 三者的区别简单说明如下&#xff1a; Red Hat Enterprise Linux (RHEL): RHEL 是由美国…

微信小程序构建npm失败解决方式

安装完所需要的依赖后&#xff0c;在微信开发者工具菜单栏中选择&#xff1a;“工具” -> “构建 npm”&#xff0c;但是失败。 解决方法&#xff1a;修改 project.config.json 开发者工具创建的项目&#xff0c;miniprogramRoot 默认为 miniprogram&#xff0c;package.js…

Vue3自定义文件列表页面(含上传、搜索、复制链接)

文章目录 一、代码展示二、代码解读三、结果展示 一、代码展示 <template><div class"container"><h1>文件列表</h1><div class"header-actions"><a-input placeholder"输入关键词搜索" v-model:value"…

element-ui附件上传及在线查看详细总结,后续赋源码

一、附件上传 1、在element-ui上面复制相应代码 a、accept"image/*,.pdf,.docx,.xlsx,.doc,.xls" 是规定上传文件的类型&#xff0c;若是不限制&#xff0c;可以直接将accept‘all即可&#xff1b; b、:action"action" 这个属性就是你的上传附件的地址&am…

spring boot集成Elasticsearch 7.16.3

环境&#xff1a;Elasticsearch 版本 7.16.3 Elasticsearch for windows下载地址 windows 若依 spring boot版本 2.6.0 pom文件添加 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch<…

细数Android开发者的艰辛历程,android零基础

首先我们来看一下组件化项目和传统项目的区别: 在传统的项目里 我们通常情况下会有一个commonLib的Libary模块和一个app的application模块&#xff0c;业务中的逻辑都写在app中各个功能模块放到不同的包下。这样做有以下几个主要的缺点&#xff1a; 1.无论分包做的再好&…