笔记: JavaSE day16笔记 - string字符串

第十六天课堂笔记

  • 学习任务

image-20240330094805994

Comparable接口★★★★

  • 接口 : 功能的封装 => 一组操作规范

    • 一个抽象方法 -> 某一个功能的封装
    • 多个抽象方法 -> 一组操作规范
  • 接口与抽象类的区别

    • 1本质不同
      • 接口是功能的封装 , 具有什么功能 => 对象能干什么
      • 抽象类是事物本质的抽象 => 对象是什么
    • 2定义方式不同
      • 抽象类 : abstract
      • 接口 : interface
    • 3内容不同
      • 抽象类 => 普通类内容 + 抽象方法
      • 接口 => 抽象方法 + 常量 + static方法 + default 方法
    • 4使用方式不同
      • 抽象类 -> 单继承
      • 接口: 多继承 , 多实现
  • Comparable<T>接口 : 封装了 两个对象 比较大小的功能

    • <T> : 泛型 : 参数传递的数据类型

      image-20240330100619129

    • 实现接口, 重写int compareTo(T o)方法

      • this : 当前对象
      • o : 表示待比较的对象
      • 返回类型int : return 对象2.比较实例变量 - this.比较实例对象;
        • this > o : return 正数
        • this < o : return 负数
        • this = o: return 0
    • 通过 Arrays.sort(对象数组 , 0 , 对象个数); 调用进行排序 , 该方法内会调用重写了的compareTo方法

二维数组★

  • 一维数组 : int[] arrs = {1,3,2} ; : 存储整数类型的数组

  • int[] [] 数组名 = {一维数组 , …}; : 存储一维数组类型的数组 => 数组的数组 => 二维数组的静态初始化形式

    • 二位数组中的每个一维数组, 存储的是一维数组的引用值 => 将二维数组看作对象数组

      image-20240330111856039

  • 二维数组的定义格式

    • 动态初始化 :数据类型[] [] 数组名= new 数据类型[二维数组长度][一维数组长度];
      • 当没给一维数组长度输入值 -> 那么系统不会给一维数组初始化, 即默认初始化为null -> 调用的话, 就会Null Pointer Exception
  • 二维数组的遍历

    • 两层for循环
    • 两层foreach循环

Java常用类

image-20240330113952591

String字符串★★★

  • 创建String对象

    • 赋值字符串创建 : String s = “fasfe”;

    • 根据构造方法创建对象 :

      • 根据字节数组创建

        • String(byte[] bytes) 可以把bytes数组中所有字节以默认的字符编码解析为字符串
        • String(byte[] bytes, int offset, int length)可以把bytes数组中从offset开始的length个字节以默认的字符编码解析为字符串
        • String(byte[] bytes, String charsetName)可以把bytes数组中所有字节以指定的字符编码解析为字符串
        • 用处: 从文件中读取若干字节保存到字节数组中 , 将字节数组 转换为 字符串 => 转换需要用到字符编码
        • 字符编码就是字符与一串01二进制之间映射
          • 常用的字符编码 : UTF-8 , UTF-16 , GBK/GB2312 , ASCII , ISO8859-1
            • utf-8 : Unicode编码 ,
              • 一个英文字符-> 1 byte字节的二进制 ,
              • 一个汉字字符 -> 3 byte字节的二进制
            • utf-16: Unicode编码 -> 2 byte字节的二进制 , => char类型数据默认编码
            • GBK/GB 2312 : 中文编码 , GB 2312包含的字符数量多
              • 一个英文字符-> 1 byte字节的二进制 ,
              • 一个汉字字符 -> 2 byte字节的二进制
            • ASCII : 美国信息交换码, 只有英文 -> 1 byte
            • ISO8859-1 : 西欧编码,(Latin编码) 兼容ASCII => tomcat服务器默认编码

        image-20240330115250542

      • 根据字符数组创建

        • String(char[] value) 把value数组中所有的字符连接为字符串.
        • String(char[] value, int offset, int count) 把value数组中从offset开始的count个字符连接为字符串
  • 字符串数据存储 到 字符串常量池当中

  • 字符串的字面值

    • 字符串保存在字符串常量池中, 采用的是 享元模式
    • 字符串对象声明赋值 : 先看 常量池是否有该数据 , 有则引用值, 无则创建
    • 如果字符串重新赋值: 不是在常量池中覆盖替换 , 而是在常量池中重新创建一个字符串对象, 将对象引用赋值

    image-20240330163325661

    • ==javac编译器会 在编译过程中 对字符串 常量的连接 进行优化 , 在.Java -> .class的这个过程中优化

    • 代码如下:

      public static void main(String[] args) {
              // 定义两个字符串
              // "helloworld" 会存储到堆区中的常量池中,将索引值赋值给s1
              String s1 = "helloworld";
              // "helloworld"已经存在常量池中, 不会再重新创建, 将索引值给s2
              String s2 = "helloworld";
              System.out.println("s1 == s2 = " + (s1 == s2));
              System.out.println(s1 == s2); // 故判断结果为 true
      
              // 定义字符串
              String s3 = "hello";  //"hello"在常量池中不存在, 故重新创建, 并将索引值给s3
              String s4 = s3 + "world"; // s3是变量, 无法用到编译优化 , "world"不在常量池中,故需要创建 ,使用+号对string连接 , 会在 堆区 创建一个 新的字符串对象 , 故会是一个新的引用值 给 s4
              System.out.println(s1 == s4);  // 故 s1 和 s4 的码值不同 false
      
              String s5 = "hello" + "world"; // javac编译器会对字符串 常量的连接 进行优化 , 在.Java -> .class的这个过程中优化,故 s5 其实就是 s5 = "helloworld"
              System.out.println(s1 == s5);  // true
              System.out.println(s4 == s5);  // false
      
              // final 常量
              final String s6 = "hello"; // "hello"在常量池中已经存在, 故直接引用值 赋给 s6
              String s7 = s6 + "world";   // "world"已经在常量池中, 不需要创建,只需要调用,  因为s6是个常量 , 故javac编译器会对字符串 进行优化 => 即 s6 + "world" == "helloworld" , 然后又发现"helloworld"在常量池中已经存在 , 故直接将 引用值 赋 给 s7
              System.out.println("s1 == s7 = " + (s1 == s7));  // true
      

    image-20240330172617108

    • ​ 面试题: 以下两个共创建了几个String字符串对象 ??

              // 问题: 以下两个共创建了几个String字符串对象 ??
              String s8 = new String("girlfriend");
              String s9 = new String("girl" + "friend");
                      /* 共三个
                首先 : "girlfriend" 在常量池中不存在, 故创建一个字符串对象
                其次 : new String("girlfriend") : 表示new 了一个字符串对象
                然而 : "girl" + "friend" 由于是两个常量使用+号拼接, 在javac编译时, 会自动进行调优, 使得"girl" + "friend" == "girlfriend" , 而"girlfriend" 在常量池中已经存在, 故只需要引用赋值, 不需要创建新的
                最后 : new String("girl" + "friend") : 表示new 了一个字符串对象
                综上所述 : 共创建了3个字符串对象
               */
      
  • string对象的不可变性

    • 创建string对象后, string字符串对象的字符序列,就无法修改
    • string提供的方法: toUppercase() , trim() , replace() 都是返回一个新的字符串对象, 原来的字符串不变
    • string类底层使用private final byte[] value 字节数组 来保存字符串的每个字符 ,
      • 该数组是private 私有的, 我们没有权限修改 value数组的元素
      • string类 也没有相应的方法修改 value 数组元素
    • 使用 + 进行字符串连接时 , 会创建新的string对象
  • 问题 : 因为string字符串是不可变的 , 创建string字符串对象后 , 他的字符序列 就不能修改了 , 使用加号(+) 对string 变量进行连接时, 会创建新的string对象

    • 当频繁使用字符串连接时 , 会出现多次创建string的情况 ,
    • 故 频繁字符串操作 时建议使用 可变字符串来进行操作
stringBuilder&stringBuffer
  • 可变字符串 => 字符序列可以修改

    • stringBuffer : 是线程安全的
    • stringBuilder : 是线程不安全的 , 但是执行效率更高
  • 线程安全

    • 多个线程 同时操作 一个共享数据 的时候, 可能会存在数据紊乱
  • 创建对象常用构造方法

    • new StringBuilder() 创建空字符串, 底层数组默认长度为16
    • new StringBuilder( 1000000 ) 创建空字符串, 指定底层数组的大小, 避免数组频繁扩容
    • StringBuilder(CharSequence seq) 根据其他字符串创建
  • 常用操作

    • StringBuilder append(String str) 在当前字符串后面连接str
    • StringBuilder delete(int start, int end) 删除字符串中[start, end)范围内的字符
    • StringBuilder insert(int offset , String str) : 在当前字符串的offset位置插入 str
    • StringBuilder replace(int start, int end, String str) 把当前字符串[start, end)范围内的字符替换为str
    • StringBuilder reverse() 把字符串中的字符序列逆序
    • String toString()
      • 因为字符串方法返回值类型都是字符串对象,故可以使用连缀操作
  • 代码如下:

        public static void main(String[] args) {
            // new一个可变字符串
            StringBuilder stringBuilder = new StringBuilder();// 空串, 底层数组长度为16
            StringBuilder stringBuilder1 = new StringBuilder(2000); // 空串, 底层数组长度为capacity : 2000
            StringBuffer stringBuffer = new StringBuffer(); // 'StringBuffer stringBuffer' may be declared as 'StringBuilder' : 都可以声明为StringBuilder
    
            // append() : 字符串的连接
            for (int i = 0; i < 10; i++) {
                stringBuffer.append(i);
            }
            System.out.println("stringBuffer = " + stringBuffer);
    
            // delete() : 删除
            stringBuffer.delete(3, 8); // 删除[3 , 8)范围内数字
            System.out.println("删完后stringBuffer = " + stringBuffer);  //删完后stringBuffer = 01289
    
            // insert() : 插入
            stringBuffer.insert(3, "flower"); // 在索引为3的位置上插入个数,后面的数顺延
            System.out.println("插入后stringBuffer = " + stringBuffer);  //插入后stringBuffer = 012flower89
    
            // replace() 替换
            stringBuffer.replace(0, 3, "double");
            System.out.println("替换后stringBuffer = " + stringBuffer); // 把[0 , 3)的值替换成str   // 替换后stringBuffer = doubleflower89
    
            // reverse() : 反转
            stringBuffer.reverse();
            System.out.println("反转后stringBuffer = " + stringBuffer);  //反转后stringBuffer = 98rewolfelbuod
    
            // 因为字符串方法返回值类型都是字符串对象,故可以使用连缀操作
            String string = stringBuffer.reverse()
                    .replace(0, 5, "hejiabei")
                    .toString();
            System.out.println("string = " + string); // string = hejiabeieflower89
        }
    
string常用的方法
  • char charAt(int index); : 返回字符串中 index 位置的字符

  • int length(); : 字符串中字符的数量

    • string字符串由若干字符组成,

      • jdk8之前 : 底层定义 private final char value[] 字符数组来保存字符串的每个字符

      • jdk9 开始 : 底层定义 private final byte[] value 字节数组来保存字符串的每个字符

        • 目的 : 节省空间
        • 在存储等操作时, 先判断字符编码,
          • 如果是Latin编码则使用一个字节存储一个字符
          • 如果是utf16编码 ,则使用2个字节存储一个字符
      • 底层源码:

        
            public int compareTo(String anotherString) {
                byte v1[] = value;
                byte v2[] = anotherString.value;
                byte coder = coder();
                if (coder == anotherString.coder()) {
                    return coder == LATIN1 ? StringLatin1.compareTo(v1, v2)
                                           : StringUTF16.compareTo(v1, v2);
                }
                return coder == LATIN1 ? StringLatin1.compareToUTF16(v1, v2)
                                       : StringUTF16.compareToLatin1(v1, v2);
             }
            @IntrinsicCandidate
            public static int compareTo(byte[] value, byte[] other) {
                int len1 = value.length;
                int len2 = other.length;
                return compareTo(value, other, len1, len2);
            }
        
            public static int compareTo(byte[] value, byte[] other, int len1, int len2) {
                int lim = Math.min(len1, len2);
                for (int k = 0; k < lim; k++) {
                    if (value[k] != other[k]) {
                        return getChar(value, k) - getChar(other, k);
                    }
                }
                return len1 - len2;
            }
        
  • 代码如下:

            // 定义一个字符串
            String s = "繁荣昌盛,国泰民安";
            // 获取字符串长度
            System.out.println("s.length() = " + s.length());
            for (int i = 0; i < s.length(); i++) {
                System.out.print(s.charAt(i) + " ");
            }
            System.out.println();
    
  • int compareTo(String anotherString) : 比较两个字符大小

    • string类型实现了comparable接口, 重写了comparaTo方法,

    • 定义比较大小的规则: 区分大小写 , 逐个比较字符串的每个字符 , 遇到了第一个不一样的字符 字符相减 , 如果都一样 , 再比较字符串长度 .

    • 底层代码:

      public int compareTo(String anotherString) {
              byte v1[] = value;
              byte v2[] = anotherString.value;
              byte coder = coder();
              if (coder == anotherString.coder()) {
                  return coder == LATIN1 ? StringLatin1.compareTo(v1, v2)
                                         : StringUTF16.compareTo(v1, v2);
              }
              return coder == LATIN1 ? StringLatin1.compareToUTF16(v1, v2)
                                     : StringUTF16.compareToLatin1(v1, v2);
           }
          private static int compareToUTF16Values(byte[] value, byte[] other, int len1, int len2) {
              int lim = Math.min(len1, len2);
              for (int k = 0; k < lim; k++) {
                  char c1 = getChar(value, k);
                  char c2 = StringUTF16.getChar(other, k);
                  if (c1 != c2) {
                      return c1 - c2;
                  }
              }
              return len1 - len2;
          }
      
  • int compareToIgnoreCase(String str); 忽略大小写, 比较字符大小

    • 代码如下:
            // 比较两个字符串大小
            System.out.println("\"hello\".compareTo(\"hella\") = " + "hello".compareTo("hella"));
            System.out.println("\"hello\".compareTo(\"w\") = " + "hello".compareTo("w"));
            System.out.println("\"繁荣昌盛\".compareTo(s) = " + "繁荣昌盛".compareTo(s));
            System.out.println("\"hello\".compareTo(\"HELLO\") = " + "hello".compareTo("HELLO"));
            System.out.println("\"hello\".compareToIgnoreCase(\"HELLO\") = " + "hello".compareToIgnoreCase("HELLO"));
    
  • boolean contains(CharSequence s) : 判断当前字符串是否包含s字符串

    • CharSequence 是一个接口 ,
      • 在调用方法时 , 方法实参为 CharSequence 接口的 实现类对象或者 匿名内部类对象
      • CharSequence接口 的实现类有 : string , string builder , string buffer
    • 代码如下:
            // 包含
            System.out.println("s.contains(\"国\") = " + s.contains("国")); // true
            System.out.println("s.contains(\"中\") = " + s.contains("中")); // fase
    
  • boolean endsWith(String suffix) : 判断字符串是否以suffix结尾

  • boolean startsWith(String prefix) : 判断字符串是否以 prefix 开头

  • boolean equals(Object anjObject) : 判断两个字符串是否一样

  • boolean equalsIgnoreCase(String anotherString) : 忽略大小写, 判断是否一样

    • 代码如下
            // 判断字符
            System.out.println("s.startsWith(\"繁\") = " + s.startsWith("繁"));  //true
            System.out.println("s.endsWith(\"强\") = " + s.endsWith("强"));  // false
            System.out.println("s.equals(\"繁荣昌盛,国泰民安\") = " + s.equals("繁荣昌盛,国泰民安"));  //s.equals("繁荣昌盛,国泰民安") = true
            System.out.println("\"hello\".equalsIgnoreCase(\"HELLO\") = " + "hello".equalsIgnoreCase("HELLO"));  //"hello".equalsIgnoreCase("HELLO") = true
    
  • byte[] getBytes() : 返回当前字符串 在默认编码下 对应的字节数组 :

    • utf-8编码中 , 一个英文字符对应一个byte字节, 一个汉字对应 3个 byte 字节
  • byte[] getBytes(String charsetName) : 返回当前字符串 在指定的编码 下对应的字节数组

    • 报出异常 unhandled exception
    • 代码如下:
            // 返回 编码对应的字节数组
            byte[] bytes = s.getBytes();
            System.out.println("Arrays.toString(bytes) = " + Arrays.toString(bytes));  //Arrays.toString(bytes) = [-25, -71, -127, -24, -115, -93, -26, -104, -116, -25, -101, -101, 44, -27, -101, -67, -26, -77, -80, -26, -80, -111, -27, -82, -119]
            // 将字节数组 转为字符串: 通过创建string来实现
            String s1 = new String(bytes);
            System.out.println("s1 = " + s1);  //s1 = 繁荣昌盛,国泰民安
            // 指定编码 返回对应的字节数组
            byte[] gbks = s.getBytes("GBK"); //Unhandled exception: java.io.UnsupportedEncodingException
            System.out.println("Arrays.toString(gbks) = " + Arrays.toString(gbks));  //Arrays.toString(gbks) = [-73, -79, -56, -39, -78, -3, -54, -94, 44, -71, -6, -52, -87, -61, -15, -80, -78]
            // 将字节数组重新合成字符串
            String s2 = new String(gbks);
            System.out.println("s2 = " + s2);  //s2 = ���ٲ�ʢ,��̩��
            String gbk = new String(gbks, "GBK");
            System.out.println("gbk = " + gbk);  //gbk = 繁荣昌盛,国泰民安
    
  • int indexOf(String str) : 返回str在当前字符串中第一次出现的索引值

  • int lastIndexOf(String str) : 返回最后一次出现的索引值

  • String substring(int beginIndex) : 返回当前字符串 从 begin Index位置 开始的子串

  • String substring(int beginIndex, int endIndex) : 返回[beginIndex , endIndex ) 范围的子串

  • 代码如下:

            // 查字符
            String path = "E:\\course\\02Project\\javaSEProject\\day16\\src\\cn\\hejiabei\\string\\StringMethod.java";
            // 获取文件名 以及 文件类型
            int slash = path.lastIndexOf("\\");  // 获取最后一个小标
            int dot = path.lastIndexOf('.');
            // 获取字符串一段的值
            String fileName = path.substring(slash + 1, dot);
            System.out.println("fileName = " + fileName); // fileName = StringMethod
            String suffix = path.substring(dot);
            System.out.println("suffix = " + suffix); // suffix = .java
    
  • String replace(CharSequence target, CharSequence replacement) : 将target 替换为 replacement, 返回一个新字符串 , 原字符串不变

  • 代码如下:

            // 字符替换replace
            String s3 = "xiaoming666xiaohua666";
            String s4 = s3.replace('6', '*');
            System.out.println("原来是s3 = " + s3);   //原来是s3 = xiaoming666xiaohua666
            System.out.println("替换后s4 = " + s4);  //s4 = xiaoming***xiaohua***
    
  • String[] split(String regex) : 将字符串 通过regex 拆分成 数组

    • regex = “”: 使用""空串 对字符串拆分 , => 即拆分成字符数组 ==> 相当于toCharArray方法
  • 代码如下:

            // 拆分
            String s5 = " 东临碣石,以观沧海,水何澹澹,山岛竦峙,树木丛生,百草丰茂,秋风萧瑟,洪波涌起,日月之行,若出其中,星汉灿烂,若出其里,幸甚至哉,歌以咏志";
            System.out.println(s5); // 东临碣石,以观沧海,水何澹澹,山岛竦峙,树木丛生,百草丰茂,秋风萧瑟,洪波涌起,日月之行,若出其中,星汉灿烂,若出其里,幸甚至哉,歌以咏志
            String[] split = s5.split(",");
            System.out.println("Arrays.toString(split) = " + Arrays.toString(split));  //Arrays.toString(split) = [ 东临碣石, 以观沧海, 水何澹澹, 山岛竦峙, 树木丛生, 百草丰茂, 秋风萧瑟, 洪波涌起, 日月之行, 若出其中, 星汉灿烂, 若出其里, 幸甚至哉, 歌以咏志]
            // 也可以使用""空字符进行拆分
            String[] split1 = s5.split("");
            System.out.println("Arrays.toString(split1) = " + Arrays.toString(split1));  //Arrays.toString(split1) = [ , 东, 临, 碣, 石, ,, 以, 观, 沧, 海, ,, 水, 何, 澹, 澹, ,, 山, 岛, 竦, 峙, ,, 树, 木, 丛, 生, ,, 百, 草, 丰, 茂, ,, 秋, 风, 萧, 瑟, ,, 洪, 波, 涌, 起, ,, 日, 月, 之, 行, ,, 若, 出, 其, 中, ,, 星, 汉, 灿, 烂, ,, 若, 出, 其, 里, ,, 幸, 甚, 至, 哉, ,, 歌, 以, 咏, 志]
    
  • char[] toCharArray(); : 将字符串转成 字符数组

  • 代码如下:

            // 字符串 转换成 字符数组
            String s6 = "hello , world";
            char[] charArray = s6.toCharArray();
            System.out.println("Arrays.toString(charArray) = " + Arrays.toString(charArray));  //Arrays.toString(charArray) = [h, e, l, l, o,  , ,,  , w, o, r, l, d]
    
  • String toLowerCase(); : 大写转小写

  • String toUpperCase(); : 小写转大写

  • 代码如下:

            // 大小写转化
            String s7 = "Good Good Study";
            String upperCase = s7.toUpperCase();
            System.out.println("upperCase = " + upperCase);  //upperCase = GOOD GOOD STUDY
            String lowerCase = s7.toLowerCase();
            System.out.println("lowerCase = " + lowerCase);  //lowerCase = good good study
    
  • String trim(); : 去掉字符串前后空格符

  • 代码如下:

            // 去掉两边空白字符
            String s8 = "    Good    Good     Study   ";
            System.out.println("s8 = " + s8);  //s8 =     Good    Good     Study
            // 去掉两边空白
            String trim = s8.trim();
            System.out.println("trim = " + trim);  //trim = Good    Good     Study
    
  • static String valueOf(int i) : 把其他类型的数据转换为字符串

    • 底层调用stu对象的toString()对象 , Student类没有重写toString()对象, 调用object类继承来的toString()方法 , 返回: 全限定类名 + “@” + 哈希码的十六进制
  • static String valueOf(Object obj) : 把对象转为字符串

  • 代码如下:

            // 将 数据类型 转换为 字符串 valueof
            int num = 2523;
            String s9 = String.valueOf(num);
            System.out.println("s9 = " + s9);  // // s9 = 2523
            // object转换
            Student student = new Student("张三");
            String s10 = String.valueOf(student);
            System.out.println("s10 = " + s10);  //s10 = cn.hejiabei.string.StringMethod$Studenfd0d5ae
    

调用object类继承来的toString()方法 , 返回: 全限定类名 + “@” + 哈希码的十六进制

  • static String valueOf(Object obj) : 把对象转为字符串

  • 代码如下:

            // 将 数据类型 转换为 字符串 valueof
            int num = 2523;
            String s9 = String.valueOf(num);
            System.out.println("s9 = " + s9);  // // s9 = 2523
            // object转换
            Student student = new Student("张三");
            String s10 = String.valueOf(student);
            System.out.println("s10 = " + s10);  //s10 = cn.hejiabei.string.StringMethod$Studenfd0d5ae
    

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

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

相关文章

学习刷题-14

3.29 贪心算法 跳跃游戏 II 给定一个非负整数数组&#xff0c;你最初位于数组的第一个位置。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 你的目标是使用最少的跳跃次数到达数组的最后一个位置。 贪心的思路&#xff0c;局部最优&#xff1a;当前可移动距离尽可能多…

Redis 常见数据结构及命令

目录 一.Redis常见的数据结构 二.Redis数据结构对应的命令 1.String类型 2.Hash类型 3.List类型 4.Set类型 5.Sorted Set类型 一.Redis常见的数据结构 Redis支持多种数据结构&#xff0c;包括字符串&#xff08;string&#xff09;、哈希&#xff08;hash&#xff09;、…

B端:甲方吐槽界面丑,少反驳,气势能得100分,体验永远0分

2023-10-24 10:20贝格前端工场 甲方吐槽B端系统界面丑陋时&#xff0c;作为设计师或开发者&#xff0c;我们不应该立即反驳或争辩。相反&#xff0c;我们应该以积极的态度倾听甲方的意见&#xff0c;并采取以下措施&#xff1a; 理解甲方需求&#xff1a; 首先要理解甲方对界…

二维码门楼牌管理应用平台建设:一扫即知,智慧生活新篇章

文章目录 前言一、二维码门楼牌管理的创新之处二、二维码门楼牌管理应用平台的实际应用三、二维码门楼牌管理应用平台的未来展望 前言 随着信息技术的飞速发展&#xff0c;二维码门楼牌管理应用平台应运而生&#xff0c;为城市管理和居民生活带来了极大的便利。只需轻轻一扫&a…

CentOS7 磁盘相关的命令及磁盘重新调整分配

umount 在CentOS 7中&#xff0c;umount是一个常用的命令&#xff0c;用于卸载文件系统。以下是一些常用的umount命令&#xff1a; 卸载指定的文件系统&#xff1a; umount /dev/sdXN 其中&#xff0c;/dev/sdXN是你想要卸载的分区。例如&#xff0c;/dev/sda1。 卸载并…

传参的指针,你的值到底变了没?!(有关函数形参修改的另类案例)

我们都知道&#xff0c;想要在函数中修改某个变量的值&#xff0c;传变量本身是没有用的。原因在于不同的函数在不同的空间上&#xff0c;函数的生命周期随着函数的调用而结束&#xff0c;因此在函数内部进行的值操作是不会对函数外的变量产生影响的。所以在函数里面想要修改变…

今日早报 每日精选15条新闻简报 每天一分钟 知晓天下事 3月31日,星期日

每天一分钟&#xff0c;知晓天下事&#xff01; 2024年3月31日 星期日 农历二月廿二 1、 医保局&#xff1a;北京、广西、内蒙古、甘肃已将辅助生殖纳入医保报销。 2、 百日咳卷土重来&#xff0c;今年已有13人死亡&#xff0c;医生提醒&#xff1a;久咳不愈要警惕。 3、 上海…

亚马逊云科技—云从业者认证考试限时 50% 折扣优惠 限量提供, 先到先得!

亚马逊云科技云从业者认证&#xff08;AWS Certified Cloud Practitioner&#xff09;作为全球热门的云基础认证, 对于寻求基础云知识的开发者、专业人士、学生, 以及没有技术背景的职场人士来说, 都是进阶亚马逊云认证之旅的良好起点并助您进一步提升职场竞争力&#xff01; 与…

Spring IoCDI(3)

DI详解 接下来学习一下依赖注入DI的细节. 依赖注入是一个过程, 是指IoC容器在创建Bean时, 去提供运行时所依赖的资源, 而资源指的就是对象. 在之前的案例中, 使用了Autowired这个注解, 完成了依赖注入这个操作. 简单来说, 就是把对象取出来放到某个类的属性中. 在一些文章中…

上市公司-劳动投资效率数据集-Abresid 含原始数据及处理代码(2020-2022年)

01、数据简介 劳动投资效率是指企业在进行劳动力投资时所获得的效益程度。简单来说&#xff0c;它衡量了企业对于人力资源的投入与产出之间的比率&#xff0c;反映了企业在人力资源管理方面的效果和效率。 Abresid是劳动投资效率的测度指标&#xff0c;它来源于某个回归模型的…

Vmware下减小Ubuntu系统占用系统盘大小

1、虚拟机设置下占用空间 如图&#xff0c;给虚拟机分配了120GB&#xff0c;已经占用116.9GB&#xff0c;开机会提示空间不足。 2、实际使用空间 ubuntu系统下使用“df -h”命令查看实际使用空间大小50GB左右 造成这个原因是&#xff0c;虚拟机的bug&#xff1a;在虚拟机的ub…

【PHP编程使用UI框架】——GET和POST的请求方法

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;开发者-曼亿点 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 曼亿点 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a…

详解 Java多线程带来的的风险-线程安全

目录 一、什么是线程安全&#xff1f; 二、线程不安全的原因 1、线程调度是随机的 2、修改共享数据&#xff1a;多个线程修改同⼀个变量 3、原⼦性 ​编辑 &#xff08;1&#xff09;什么是原⼦性 &#xff08;2&#xff09;⼀条 java 语句不⼀定是原⼦的&#xff0c;也不⼀定…

【转移表】

文章目录 一、函数指针数组1.什么事函数指针数组2.函数指针数组如何定义 二、转移表结束语 一、函数指针数组 1.什么事函数指针数组 在我们学习函数指针数组前&#xff0c;大家可以一起回顾一下我们以前学习的指针和数组。 数组指针 数组指针是指指向数组的指针。 int arr…

每日五道java面试题之springboot篇(四)

目录&#xff1a; 第一题. Spring Boot 打成的 jar 和普通的 jar 有什么区别 ?第二题. 微服务中如何实现 session 共享 ?第三题. Spring Boot 中如何实现定时任务 ?第四题. 运行 Spring Boot 有哪几种方式&#xff1f;第五题. 开启 Spring Boot 特性有哪几种方式&#xff1f…

MySQL - 高阶语句(一)

先准备一张表 create table class1 (id int,name varchar(10) primary key not null ,score decimal(5,2),address varchar(20),hobbid int(5));insert into class1 values(1,liuyi,80,beijing,2); insert into class1 values(2,wangwu,90,shengzheng,2); insert into class1 …

Linux是怎么发送一个网络包的?

目录 摘要 1 从 send 开始 2 传输层 3 网络层 4 网络接口层 4.1 邻居子系统 4.2 网络设备子系统 4.3 软中断发送剩余的 skb 4.4 硬中断又触发软中断 总结 摘要 一个网络包的发送&#xff0c;始于应用层&#xff0c;经层层协议栈的封装&#xff0c;终于网卡。今天来循…

【C语言】贪吃蛇【附源码】

欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 一、游戏说明&#xff1a; 一个基于C语言链表开发的贪吃蛇游戏&#xff1a; 1. 按方向键上下左右&#xff0c;可以实现蛇移动方向的改变。 2. 短时间长按方向键上下左右其中之一&#xff0c;可实现蛇向该方向的短时间…

AndroidStudio出现类似 Could not create task ‘:app:ToolOperatorDemo.main()‘. 错误

先看我们的报错 翻译过来大概意思是:无法创建任务:app:ToolOperatorDemo.main()。 没有找到名称为“main”的源集。 解决方法&#xff1a; 在.idea文件夹下的gradle.xml文件中 <GradleProjectSettings>标签下添加<option name"delegatedBuild" value"f…

指针强化练习(详解)

更多学习内容 结构体内存对齐 和 位段-CSDN博客指针初级&#xff08;基础知识&#xff09;-CSDN博客指针进阶(深入理解)-CSDN博客 目录 1.sizeof与strlen的区别 2.一维数组 3.字符指针 4.二维数组 5.指针运算(笔试题) 6.函数指针 1.sizeof与strlen的区别 请思考以下运行结…