糊涂(Hutool)工具常见的使用方法

news2025/1/12 13:35:02

 简介:

Hutool是一个小而全的Java工具类库,通过静态方法封装,降低相关API的学习成本,提高工作效率,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”。

 

安装:

在我们的maven中引入糊涂的依赖即可

<!--引入Hutool工具类-->
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.8.16</version>
        </dependency>

因为我们使用的是单元测试,所以我们还需要引入junit的依赖。如果是spring boot项目,就不需要引入,引入junit,因为springboot已经继承了,要是maven项目就需要引入。

<!--引入junit单元测试-->
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter</artifactId>
            <scope>test</scope>
        </dependency>

集合类:

集合工具-ColUtil

主要封装了对数组和集合类的操作

新建一个ColUtilTest测试类:

public class ColUtilTest {

}

在这个类上添加  @Slf4j注解

@Slf4j
public class ColUtilTest {

}
join方法:

就是将一个集合转换成字符串。

    @Test
    @DisplayName(value = "测试集合转成字符串")
    void testListToStr(){
        String[] str = {"a","b","c","d"};
        ArrayList<String> list = CollUtil.newArrayList(str);
        String join = CollUtil.join(list, ","); //用指定分隔符分割
        log.info(join);
    }
sortPageAll方法

这是一个组合方法,功能是将给定的多个集合放到一个集合(list)中,根据给定的Comparator对象排序,然后分页取数据。

 

    @Test
    @DisplayName(value = "合并集合到一个集合中,并按照分页的数据按需取出")
    void testToList(){
        //Integer类型的比较器
        Comparator<Integer> comparator = new Comparator<>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return o1.compareTo(o2);
            }
        };
        //新建三个集合
        ArrayList<Integer> list1 = CollUtil.newArrayList(1, 2, 3);
        ArrayList<Integer> list2 = CollUtil.newArrayList(4, 5, 6);
        ArrayList<Integer> list3 = CollUtil.newArrayList(7, 8, 9);

        //把list1,list2,list3,按照从小到大排序,取 0~3个
        List<Integer> result = CollUtil.sortPageAll(0, 3, comparator, list1, list2, list3);
        System.out.println(result);

    }
popPart方法

传入一个栈对象,然后弹出指定数目的元素对象,弹出是指pop()方法,会从原栈中删掉。并否则删除的元素。

    @Test
    @DisplayName(value = "测试出栈")
    void testPopPart(){
        Stack stack = new Stack();
        stack.push(1);
        stack.push(2);
        stack.push(3);
        stack.push(4);
        List popPart = CollUtil.popPart(stack, 2);
        System.out.println(popPart);  //输出,出栈的元素
        System.out.println(stack);  //查看原来的stack
    }
append方法:

在数组末尾添加一个元素,其实就是List.add()方法实现的。

    @Test
    @DisplayName(value = "给数组末尾添加元素")
    void testToAppend(){
       Integer[] ids = {4,5};
        Integer[] append = ArrayUtil.append(ids, 1, 2, 3);
        System.out.println(Arrays.toString(append));     //输出数组元素
        System.out.println(ArrayUtil.toString(append));  //输出数组元素
    }
resize方法

重新调整数组的大小,如果调整后的大小比原来小,截断,如果比原来大,则多出的位置用null补位。

    @Test
    @DisplayName("重新调整数据的大小")
    void testResize(){
        Object[] array = ArrayUtil.newArray(5);  //创建一个长度为5的数组
        array[0] = 1;
        array[1] = 2;
        array[2] = 3;
        array[3] = 4;
        System.out.println(ArrayUtil.toString(array));   //输出数据的数据
        System.out.println(ArrayUtil.length(array));  //查看这个数组的长度
        Object[] resize = ArrayUtil.resize(array, 3);  //调整数组大小为3
        System.out.println(ArrayUtil.length(resize));   //输出调整后数组的大小
        System.out.println(ArrayUtil.toString(resize));
        Object[] newSize = ArrayUtil.resize(resize, 6);  //调整数组大小为6
        System.out.println(ArrayUtil.toString(newSize)); //测试新数组里面的数据
        System.out.println(ArrayUtil.length(newSize));  //测试新数组的长度

    }
addAll方法

将多个集合添加到一个Collection

    @Test
    @DisplayName(value = "把多个集合,合并到一个集合中")
    void testAddAll(){
        Collection coll = new ArrayList();
        coll.add(88);
        coll.add(99);
        Collection<Integer> collection = CollUtil.addAll(CollUtil.newArrayList(1, 2, 3, 4), CollUtil.newArrayList(6, 7, 8));
        collection.addAll(coll);
        System.out.println(collection);
    }
sub方法

对集合切片,其他类型的集合会转换成List,

自动修正越界等问题,完全避免IndexOutOfBoundsException异常。

    @Test
    @DisplayName(value = "测试对集合进行切片")
    void testSubList(){
        ArrayList<Integer> list = CollUtil.newArrayList(1, 2, 3, 4, 5, 6);
        List<Integer> subList = CollUtil.sub(list, 0, 3);
        System.out.println(subList);  //输出切片的数据
        System.out.println(CollUtil.sub(list, 0, list.size() + 3)); //已经明显超出集合长度了
        System.out.println(list);   //原集合
    }
isEmpty,isNotEmpty方法

判断集合是否为空(包括null和没有元素的集合)

    @Test
    @DisplayName(value = "list集合转成map")
    void testListToMap(){
        ArrayList<Integer> keys = CollUtil.newArrayList(1, 2, 3, 4);
        ArrayList<String> values = CollUtil.newArrayList("a", "b", "c", "d");
        Map<Integer, String> map = CollUtil.zip(keys, values);
        System.out.println(map);
    }
zip方法

给定两个集合,然后两个集合中的元素一一对应,组成一个Map。此方法还有一个重载方法,可以传字符,然后给定分隔符,字符串会被split成列表。

    @Test
    @DisplayName(value = "list集合转成map")
    void testListToMap(){
        ArrayList<Integer> keys = CollUtil.newArrayList(1, 2, 3, 4);
        ArrayList<String> values = CollUtil.newArrayList("a", "b", "c", "d");
        Map<Integer, String> map = CollUtil.zip(keys,values);
        System.out.println(map);
    }

列表工具-ListUtil

List在集合中使用最为频繁,因此新版本的Hutool中针对List单独封装了工具方法

indexOfAll方法 

查找某个元素,在集合中的位置(返回的是索引)

    @Test
    @DisplayName(value = "查找某个元素在集合中出现的位置")
    void test1(){
        LinkedList<String> linkedList = ListUtil.toLinkedList("1", "2", "3", "4", "3", "2", "1");
        int[] ints = ListUtil.indexOfAll(linkedList, "2"::equals);  //输出的是索引
        System.out.println(ArrayUtil.toString(ints));
    }
快速生成list集合方法:

用下面的方法,可以帮助我们快速的生成list集合。

    @Test
    @DisplayName(value = "快速生成list集合")
    void testFindOption(){
        List<Integer> list = ListUtil.of(1, 2, 3, 4, 5);
        list.forEach(l ->{
            System.out.println(l);  //遍历集合
        });

        ArrayList<Integer> arrayList = ListUtil.toList(1, 2, 3, 4);
        System.out.println(arrayList);

        LinkedList<Integer> linkedList = ListUtil.toLinkedList(1, 2, 3, 4, 5, 6, 7);
        System.out.println(linkedList);

        List<Integer> integerList = Arrays.asList(1, 2, 3, 4);
        System.out.println(integerList);
    }
sub方法

此方法是列表截取,根据起始索引截取。不会影响原来的集合

    @Test
    @DisplayName(value = "集合数据截取")
    void testSubList(){
        ArrayList<Integer> list = ListUtil.toList(1, 2, 3, 4, 5, 6);
        List<Integer> sub = ListUtil.sub(list, 0, 3);
        System.out.println(sub);  //截取出来的集合
        System.out.println(list); //原集合
    }
sortByProperty方法

按照bean对象的某个数字类型的字段值排序

先创建一个 TestBean实体类对象,添加 @Data,和@AllArgsConstructor注解

    @Data
    @NoArgsConstructor
    @AllArgsConstructor
    class TestBean{
        private Integer id;
        private String name;
    }

    @Test
    @DisplayName(value = "按照我们自定义的bean对象中的id属性排序")
    void testSort(){
        ArrayList<TestBean> list = ListUtil.toList(
                new TestBean(2, "测试2"),
                new TestBean(4, "测试4"),
                new TestBean(1, "测试1"),
                new TestBean(3, "测试3")
        );

        list.forEach(System.out::println);  //排序前
        ListUtil.sortByProperty(list,"id");
        System.out.println("************************************************");
        list.forEach(l -> System.out.println(l));  //排序后
    }
swapTo方法

将指定元素和指定下标位置的元素交换位置

    @Test
    @DisplayName(value = "元素交换")
    void testSwap(){
        List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6, 7);
        ListUtil.swapTo(list,5,1);  // 元素为5 的和下标是1的交换位置
        System.out.println(list);
    }
partition方法
  • 这个方法起到分组的作用。
  • 通过传入要分组的集合,每个分组区间的大小,将一个集合分成不同的块。

    @Test
    @DisplayName(value = "集合分组")
    void testPart(){
        ArrayList<Integer> list = ListUtil.toList(1, 2, 3, 4, 5, 6,7);
        List<List<Integer>> partition = ListUtil.partition(list, 3); //三个元素是一组
        System.out.println(partition);
        System.out.println(ListUtil.partition(list, 2));  //两个元素是一组
    }

开发中常用工具类:

随机工具-RandomUtil

RandomUtil主要针对JDK中Random对象做封装,严格来说,Java产生的随机数都是伪随机数,所以Hutool封装后产生的随机结果也是伪随机结果。

新建一个 RandomTest测试类:在添加@slf4j注解

@Slf4j
@DisplayName(value = "测试生成随机数")
public class RandomTest {

}

randomInt方法
  • RandomUtil.randomInt 获得指定范围内的随机数
  • 前包后不包

      @Test
    @DisplayName("测试生成指定范围的随机数")
    void randomTest1(){
        log.info("测试生成指定范围的随机数");
        for (int i = 0; i < 100; i++) {
            int random = RandomUtil.randomInt(10, 100);
            if (random == 10){
                log.info("包含了{}",random);
            }
            if (random == 100){
                log.info("包含了{}",random);
            }
            System.out.println("生成的随机数是:"+random);
        }
    }
randomBytes 方法
  • 生成一个 byte类型范围内的随机数,包含正数和负数。
  • 可以传递一个参数,表示生成几个。

    @Test
    @DisplayName("测试生成在byte范围内的随机数,包括正数和负数,返回在一个数组中")
    void randomTest2(){
        log.info("测试生成在byte范围内的随机数,包括正数和负数,返回在一个数组中");
        byte[] bytes = RandomUtil.randomBytes(10);
        System.out.println(ArrayUtil.toString(bytes));
    }
randomString 方法
  • 获得一个随机的字符串(只包含数字和字符)
  • 传入一个参数指定,生成的随机字符串的长度

    @Test
    @DisplayName(value = "获得一个随机的字符串(包含数字和字符)")
    void testRandomStr(){
        String s1 = RandomUtil.randomString(10);
        String s2 = RandomUtil.randomString(4);
        System.out.println(s1);
        System.out.println(s2);
    }
randomNumbers 方法

 获得一个只包含数字的字符串

    @Test
    @DisplayName(value = "获得一个随机的字符串(包含数字)")
    void testRandomNums(){
        String numbers1 = RandomUtil.randomNumbers(10);
        String numbers2 = RandomUtil.randomNumbers(7);
        System.out.println(numbers1);
        System.out.println(numbers2);
    }
唯一 ID工具-IdUtil

唯一ID生成应用十分广泛,生成方法也多种多样,Hutool针对一些常用生成策略做了简单封装。

唯一ID生成器的工具类,涵盖:

  • UUID
  • ObjectId(MongoDB)
  • Snowflake(Twitter)
UUID

UUID全称通用唯一识别码(universally unique identifier),JDK通过java.util.UUID提供了 Leach-Salz 变体的封装。Hutool中,生成一个UUID字符串方法如下: 

我们先新建一个测试类:UuidTest,然后加上@Slf4j的注解

@Slf4j
@DisplayName(value = "UUID的测试类")
public class UuidTest {

}
randomUUID方法

生成的UUID是带 - 的字符串

    @Test
    @DisplayName(value = "测试生成带 - 的UUID")
    public void testId1(){
        log.info("测试生成带 - 的UUID");
        String uuid = cn.hutool.core.util.IdUtil.randomUUID();
        System.out.println(uuid);
    
simpleUUID方法

生成不带 - 的字符串

    @Test
    @DisplayName(value = "测试生成不带 - 的UUID")
    public void testId2(){
        log.info("测试生成不带 - 的UUID");
        String uuid = cn.hutool.core.util.IdUtil.simpleUUID();
        System.out.println(uuid);
    }

说明:

Hutool重写了java.util.UUID的逻辑,使用糊涂工具生成不带 - UUID字符串,不需要做字符串替换,性能提高一倍左右。

ObjectId

ObjectId是MongoDB数据库的一种唯一ID生成策略,是UUID version1的变种

我们新建一个ObjectIdTest测试类,加上@Slf4j的注解。

@Slf4j
@DisplayName(value = "ObjectId的测试类")
public class ObjectIdTest {

}
next方法

生成类似于: 5bsf78fg878dsg7svdsf98dsds9

    @Test
    @DisplayName(value = "测试生成一串的ObjectId")
    void testObjectIdTest1(){
        log.info("测试生成一大串的ObjectId");
        String next = ObjectId.next();
        System.out.println(next);
    }
objectId方法

这个方法是 Hutool-4.1.14才开始提供

    @Test
    @DisplayName(value = "测试生成一串的ObjectId")
    void testObjectIdTest2(){
        log.info("测试生成一大串的ObjectId");
        String id = IdUtil.objectId();
        System.out.println(id);
    }

数组工具-ArrayUtil

数组工具类主要是解决对象数组(包括包装类型数组)和原始类型数组使用方法不统一的问题。

 新建一个ArrayUtilTest测试类,加上@Slf4j注解

@Slf4j
public class ArrayUtilTest {

}

isEmpty方法

数组的判空类似于字符串的判空,标准是null或者数组长度为0,ArrayUtil中封装了针对原始类型和泛型数组的判空和判非空:

    @Test
    @DisplayName(value = "测试数组是否为空")
    void testIsEmpty(){
        int[] a = {};
        int[] b = null;
        int[] c = {1,2,3};
        System.out.println(ArrayUtil.isEmpty(a));
        System.out.println(ArrayUtil.isEmpty(b));
        System.out.println(ArrayUtil.isEmpty(c));
    }
isNotEmpty方法

    @Test
    @DisplayName(value = "测试非空判断")
    void testIsNotEmpty(){
        int[] a = {};
        int[] b = null;
        int[] c = {1,2,3};
        System.out.println(ArrayUtil.isNotEmpty(a));
        System.out.println(ArrayUtil.isNotEmpty(b));
        System.out.println(ArrayUtil.isNotEmpty(c));

    }
newArray方法

新建泛型数组。

Array.newInstance并不支持泛型返回值,在此封装此方法使之支持泛型返回值。

    @Test
    @DisplayName(value = "新建泛型数组")
    void testNewArray(){
        Object[] strArr = ArrayUtil.newArray(String.class, 4);
        strArr[0] = "1";
        strArr[1] = "2";
        strArr[2] = "8";
        System.out.println(ArrayUtil.toString(strArr));
    }

我的泛型是 String类型的,在给数组添加新元素的时候,如果添加 其他类型,比如 Integer类型,就会报错。

resize方法

使用ArrayUtil.size方法,生成一个新的重新设置大小的数组

    @Test
    @DisplayName(value = "调整数组大小")
    void testArrResize(){
        Object[] array = ArrayUtil.newArray(5);
        System.out.println(array.length);  //新生成数组的长度
        Object[] resize = ArrayUtil.resize(array, 3);
        System.out.println(resize.length);

    }
addAll方法

Array.addAll方法,将多个泛型数组合并为一个数组。

    @Test
    @DisplayName(value = "合并数组")
    void testAddAll(){
        Object[] intArr = ArrayUtil.newArray(Integer.class, 3);
        Object[] strArr = ArrayUtil.newArray(String.class, 4);
        Object[] all = ArrayUtil.addAll(intArr, strArr);
        System.out.println(all.length);
        all[0] = 1;
        all[4] = "你好";
        all[2] = 3.8D;
        System.out.println(ArrayUtil.toString(all));
    }
cone方法

数组本身支持clone方法,因此确定为某种类型数组时调用ArrayUtil.clone(T[]),不确定类型的使用ArrayUtil.clone(T),两种重载方法在实现上有所不同,但是在使用中并不能感知出差别。

    @Test
    @DisplayName(value = "克隆数组")
    void testClone(){
        Integer[] a = {1,2,3,4};
        Integer[] cloneB = ArrayUtil.clone(a);
        System.out.println(ArrayUtil.toString(cloneB));
    }

数字工具-NUmberUtil

数字工具针对数学运算做工具性封装

新建一个 NumberUtilTest 测试类,并添加@Slf4j注解

@Slf4j
public class NumberUtilTest {

}
加减乘除
add方法

 针对数字类型做加法

    @Test
    @DisplayName(value = "测试减法")
    void testSub(){
        BigDecimal sub = NumberUtil.sub(1, 2, 3, 4, 5);
        System.out.println(sub);
    }
sub方法

针对数字类型做减法

    @Test
    @DisplayName(value = "测试减法")
    void testSub(){
        BigDecimal sub = NumberUtil.sub(1, 2, 3, 4, 5);
        System.out.println(sub);
    }
mul方法

针对数字类型做乘法

    @Test
    @DisplayName(value = "测试乘法")
    void testMul(){
        double mul = NumberUtil.mul(3.4, 0.345);
        System.out.println(mul);
    }

div方法

针对数字类型做除法,并提供重载方法用于规定除不尽的情况下保留小数位数和舍弃方式。

    @Test
    @DisplayName(value = "测试除法")
    void testDiv(){
        double div = NumberUtil.div(10, 0.34);
        System.out.println(div);
    }
round方法
  • NumberUtil.round 方法主要封装BigDecimal中的方法来保留小数,返回BigDecimal,这个方法更加灵活,可以选择四舍五入或者全部舍弃等模式。

    @Test
    @DisplayName(value = "四舍五入保留小数点")
    void testRound(){
        Double tel1 = 12345.123456;
        Double tel2 = 12345.127656;
        Console.log(round(tel1,4)); //四舍五入,且保留小数点后四位
        Console.log(round(tel2,3)); //四舍五入,且保留小数点后三位

    }
roundStr方法
  • NumberUtil.roundStr 方法主要封装String.format方法,舍弃方式采用四舍五入。

    @Test
    @DisplayName(value = "另一种方法")
    void testRoundStr(){
        double te1=123456.123456;
        double te2=123456.128456;
        Console.log(roundStr(te1,2));//四舍五入,保留小数点后两位
        Console.log(roundStr(te2,2));//四舍五入,保留小数点后两位
    }
校验数字:
isNumber方法

是否为数字

    @Test
    @DisplayName(value = "检验是否是数字")
    void testIsNumber(){
          String  str = "899daoen";
          String  num = "4353";
        System.out.println(NumberUtil.isNumber(str));
        System.out.println(NumberUtil.isNumber(num));
    }
isInteger方法

是否为整数

    @Test
    @DisplayName(value = "检验是否是整数")
    void testIsInteger(){
        String i1 = "123.4";
        String i2 = "89424";
        String i3 = "89asda424";
        System.out.println(NumberUtil.isInteger(i1));
        System.out.println(NumberUtil.isInteger(i2));
        System.out.println(NumberUtil.isInteger(i3));
    }
isDouble方法

是否是浮点数

    @Test
    @DisplayName(value = "校验是否是浮点数")
    void testIsDouble(){
        String d1 = "12546";
        String d2 = "1254gfg6";
        String d3 = "1.234";
        System.out.println(NumberUtil.isDouble(d1));
        System.out.println(NumberUtil.isDouble(d2));
        System.out.println(NumberUtil.isDouble(d3));
    }

isPrimes方法

是否是质数

    @Test
    @DisplayName(value = "校验是否是质数")
    void testIsPrimes(){
        Integer p1 = 3;
        Integer p2 = 12;
        Integer p3 = 17;
        System.out.println(NumberUtil.isPrimes(p1));
        System.out.println(NumberUtil.isPrimes(p2));
        System.out.println(NumberUtil.isPrimes(p3));
    }
随机数:
generateRandomNumber方法

生成不重复随机数 根据给定的最小数字和最大数字,以及随机数的个数,产生指定的不重复的数组。

    @Test
    @DisplayName(value = "生成不重复的随机数")
    void testGenRandom(){
        int[] ints = NumberUtil.generateRandomNumber(1, 20, 19); //size范围不能超过end - begin的差
        System.out.println(ArrayUtil.toString(ints));
    }
generateBySet方法

生成不重复随机数 根据给定的最小数字和最大数字,以及随机数的个数,产生指定的不重复的数组。

    @Test
    @DisplayName(value = "生成不重复的数组")
    void testGenBySet(){
        Integer[] generate = NumberUtil.generateBySet(5, 10, 5);//size范围不能超过end - begin的差
        System.out.println(ArrayUtil.toString(generate));
    }
整数列表:
range方法

方法根据范围和步进,生成一个有序整数列表

    @Test
    @DisplayName(value = "生成一个有序整数数组")
    void testRange(){
        int[] range = NumberUtil.range(7);  //从 0 开始 到 7 结束
        System.out.println(ArrayUtil.toString(range));
        int[] ints = NumberUtil.range(5, 10);  //生成一个从5开始,到10结束的数组
        System.out.println(ArrayUtil.toString(ints));
    }
appendRange方法

将给定范围内的整数添加到已有集合中

    @Test
    @DisplayName(value = "把指定范围内的整数,添加到一个集合中")
    void testAppendRange(){
        ArrayList<Integer> list = ListUtil.toList(1, 2, 3, 4);
        Collection<Integer> collection = NumberUtil.appendRange(6, 9, list);
        collection.forEach(c -> System.out.println(c));
    }
compare 方法

 

    @Test
    @DisplayName(value = "比较两个数的大小")
    void testCompare(){
        /**
         * x 是第一个参数,y是第二个参数
         *  x > y 返回 1
         *  x < y 返回 -1
         *  x = y 返回 0
         */
        System.out.println(NumberUtil.compare(12, 15));
        System.out.println(NumberUtil.compare(20, 10));
        System.out.println(NumberUtil.compare(25, 25));
    }

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

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

相关文章

Linux网络编程(一-网络相关知识点)

目录 一、网络相关知识简介 二、网络协议的分层模型 2.1 OSI七层模型 2.2 TCP/IP五层模型 2.3 协议层报文间的封装与拆封 三、IP协议 3.1 MAC地址 3.2 IP地址 3.3 MAC地址与IP地址区别 一、网络相关知识简介 互联网通信的本质是数字通信&#xff0c;任何数字通信都离…

国内首款支持苹果Find My芯片-伦茨科技ST17H6x

深圳市伦茨科技有限公司&#xff08;以下简称“伦茨科技”&#xff09;发布ST17H6x Soc平台。成为继Nordic之后全球第二家取得Apple Find My「查找」认证的芯片厂家&#xff0c;该平台提供可通过Apple Find My认证的Apple查找&#xff08;Find My&#xff09;功能集成解决方案。…

K8S集群重新初始化--详细过程

K8S集群重新初始化 1、master节点1.1、在master节点执行下面reset命令&#xff1a;1.2、手动清除配置信息&#xff0c;这一步很关键&#xff1a;1.3、重新引导集群1.4、创建配置目录&#xff0c;并复制权限配置文件到用户目录下&#xff1a;1.5 查看集群状态1.6 安装Calico网络…

通过两台linux主机配置ssh实现互相免密登陆

一、准备工作 1:两台Linux主机&#xff0c;需要能ping通 2:检查防火墙是否处于关闭状态,没关闭的话关闭&#xff0c;防止防火墙拦截流量 查看防火墙状态&#xff1a;systemctl status firewalld 关闭防火墙&#xff1a;systemctl stop firewalld 3:使用getenforce命令查…

Google Pixel 与 iPhone手机:哪个更好?

iPhone稳定可靠&#xff0c;Pixel性价比高且创新。两者各有千秋&#xff0c;满足不同需求 谷歌的 Pixel 手机是 Android 最接近 iPhone 的手机&#xff0c;也是真正原生的Android手机。在iPhone 15 Pro Max 与华为 Mate 60 Pro的比较中不难看出&#xff0c;iPhone依然有着极强…

Java实现任务栏图标闪烁功能,点击任务栏打开Java窗口,使用GUI的JFrame实现

JFrame是指一个计算机语言-java的GUI程序的基本思路是以JFrame为基础,它是屏幕上window的对象,能够最大化、最小化、关闭。 GUI主要功能是实现人与计算机等电子设备的人机交互。它是用户与操作系统之间进行数据传递和互动操控的工具,用户可以通过一定的操作实现对电子设备的…

PyTorch|view(),改变张量维度

在构建自己的网络时&#xff0c;了解数据经过每个层后的形状变化是必须的&#xff0c;否则&#xff0c;网络大概率会出现问题。PyToch张量有一个方法&#xff0c;叫做view(),使用这个方法&#xff0c;我们可以很容易的对张量的形状进行改变&#xff0c;从而符合网络的输入要求。…

【自学笔记】01Java基础-07面向对象基础-04接口与内部类详解

记录学习Java基础中有关接口类和内部类的知识。 1 接口 interface 关键字用于定义接口类&#xff0c;接口类是一系列方法的声明&#xff0c;一般只有方法的特征没有方法的实现&#xff0c;因此可以被不同的类接入实现&#xff0c;而这些实现可以具有不同的行为&#xff08;功…

《Training language models to follow instructions》论文解读--训练语言模型遵循人类反馈的指令

目录 1摘要 2介绍 方法及实验细节 3.1高层次方法论 3.2数据集 3.3任务 3.4人体数据收集 3.5模型 3.6评价 4 结果 4.1 API分布结果 4.2公共NLP数据集的结果 4.3定性结果 问题 1.什么是rm分数 更多资料 1摘要 使语言模型更大并不能使它们更好地遵循用户的意图。例…

C#学习教程一

VS2022 一:C#简介 基础: 全称:c sharp 面向对象 高级编程语言:(GC动态控制内存) C#、Java、Python... 低级编程语言:(经常与硬件打交道、内存、寄存器等) c/C++ 汇编... .net=dot net 过程: C/C++ 通过编译器转换成机器指令 C#通过编译器转换成IL中间语言…

怎么用 Excel 做出专业的 project 甘特图?10个步骤和60个模板

使用Excel来创建Project甘特图的步骤包括&#xff1a;1、基本设置和布局调整、2、数据输入和时间线配置、3、任务依赖性和进度跟踪、4、视觉效果优化、5、数据更新和维护、6、模板保存和共享。尤其突出基本设置和布局调整&#xff0c;它是构建一个清晰、有效的甘特图的基础。 甘…

【2023 - 探索】博0到博1,游戏新地图的探索日志

【2023 - 探索】博0到博1&#xff0c;游戏新地图的探索日志 写在最前面CSDN探索日志2023的探险 探索日志年终回顾探索 冒险回顾实习6月开始跟着老师做科研年中的一些其他事情9月开始上课开学后11月&#xff0c;读者互动 新年展望新年祝福 写在最前面 2023&#xff0c;我解锁了新…

Safari历史记录怎么恢复?掌握好这3个方法!

大家在使用Safari浏览器时难免会遇到一些问题&#xff0c;比如Safari历史记录误删除或意外丢失&#xff0c;想必这是一件很令人烦恼的事情。 那么&#xff0c;当苹果手机上的Safari历史记录不见时&#xff0c;我们该如何找回呢&#xff1f;safari历史记录怎么恢复&#xff1f;…

UTONMOS:探索元宇宙,开启未来游戏新篇章

在元宇宙的世界里&#xff0c;游戏不再只是消遣&#xff0c;而是一个全新的互动世界&#xff0c;等待你来探索&#xff01; 逼真的虚拟现实技术&#xff0c;让你沉浸在充满想象力的游戏世界中&#xff0c;体验前所未有的刺激和乐趣。 与来自全球的玩家互动交流&#xff0c;结…

应用案例 | 使用Softing PROFIBUS Tester 5解决网络问题

PROFIBUS是在工业自动化领域里被广泛使用的现场总线协议&#xff0c;它具有高可靠性、低成本等优势&#xff0c;主要应用于制造业、能源、交通等领域。然而&#xff0c;随着时间的推移&#xff0c;PROFIBUS网络也不可避免地会出现一些组件老化的问题&#xff0c;从而对其性能和…

涛思数据获评北京市“专精特新”中小企业

众所周知&#xff0c;“专精特新”企业是国家引导中小企业增强自主创新能力和核心竞争力&#xff0c;不断提高中小企业发展质量和水平而实施的重大工程&#xff0c;旨在支持企业走专精特新发展之路&#xff0c;更好地促进企业高质量发展&#xff0c;也成为各领域产业链供应的关…

Project软件使用指南:六个关键功能助力项目成功

在项目管理的复杂世界中&#xff0c;Project软件提供了关键的解决方案。主要功能包括&#xff1a;1、任务和进度管理、2、资源分配、3、财务监控、4、风险评估、5、协作增强、6、报告和洞察力。特别是在任务和进度管理方面&#xff0c;Project软件通过动态时间表和任务跟踪工具…

CAN201 计网概念收集

Lecture 1 the theoretical basis for networking Network edge and core 地理覆盖范围&#xff1a;广WAN&#xff0c;城MAN&#xff0c;局LAN&#xff0c;个PAN 交换方式&#xff0c;电路&#xff0c;报文&#xff0c;分组 电路交换vs报文vs分组 Network performance pr…

vscode在node环境中如何调试

1.在vscode编辑器中&#xff0c;点击左侧的小图标。创建launch.js文件&#xff08;这个文件创建好以后会在项目的.vscode文件下&#xff09; 配置文件内容如下&#xff0c;我们只需要关注program字段&#xff0c;这是入口文件&#xff0c;写绝对路径就行 {// 使用 IntelliS…

C#调用WinAPI部分命令

C#是针对WIndows而生的,开发WIndows应用最快。然而想要让自己程序进阶,就不需深入Windows底层,WinAPI为我们提供了一把利刃。 目录 1、查找窗口句柄 2、查找窗口内子对象 3、指定窗口样式 4、指定窗口扩展样式 5、调整窗口大小Z轴(层叠) 6、获得窗口样式 7、向窗口…