Java入門6(String和封裝類)

来源:https://www.cnblogs.com/te9uila/archive/2023/04/18/17330421.html
-Advertisement-
Play Games

使用第三方jar包,完成get/set操作 Lombok,結合特殊的註解,實現setter和getter的自動生成 導入jar包 使用插件Lombok 在類里import 即可使用 import lombok.AllArgsConstructor; import lombok.Data; impor ...


使用第三方jar包,完成get/set操作

Lombok,結合特殊的註解,實現setter和getter的自動生成

  1. 導入jar包
  2. 使用插件Lombok
  3. 在類里import 即可使用
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

// 使用註解@Data,在類編譯的時候,自動給class文件生成getter,setter,toString 以及其他方法
@Data
// 自動生成無參構造
@NoArgsConstructor
// 自動生成有參構造
@AllArgsConstructor
public class Person {
    private String name;
    private String sex;
    private int age;
}

系統常用類 String

// String類
public final class String
    implements java.io.Serializable, Comparable<String>, CharSequence {
    /** The value is used for character storage. */
    private final char value[];
    ...

​ String 底層是使用char數組進行存儲的,由於在String類中,char數組是用final修飾的,因此String類型的數據不可以被改變!!!

String str = "test01";
char[] cs = str.toCharArray();
// .toCharArray(),使用System.arraycopy方法,將String底層數組複製並輸出給cs

構造方法

String()無參構造
// String無參構造 -- 空字元串
String tmp = new String();
// 創建出來的空字元串預設沒有任何字元存儲
String(byte[] bytes)位元組數組(每一個字元所對應的字元集編碼)作為參數
// 將位元組數組,轉化為字元數組,再將字元數組拼接存儲到字元串中
byte[] bs = {65,66,67,68};
String tmp = new String(bs);
String(char[] value)char數組作為參數
// 將字元數組拼接存儲到字元串中
char[] cs = {'a','q','c'};
String tmp = new String(cs);
String (String original)String字元串作作為參數 ---- 字元數組的引用傳遞
// 將目標字元串底層存儲所使用的char數組的記憶體地址,傳遞給當前字元串對象所對應的字元數組引用
String tmp = new String("test");
// 等同於
// 使用等號賦值的字元串,預設會使用字元串常量池,來進行字元串對象的復用
String tmp = "test";

image-20230417150409215

等號和new定義字元串的區別

// 通過等號賦值直接定義的字元串是存放在運行時常量池中的,記憶體地址相同
String tmp = "test";
String tmp1 = "test";
System.out.println(tmp.equals(tmp1)); // true
System.out.println(tmp == tmp1); // true

// 而用new定義的字元串,實在堆中創建,記憶體地址不同
String tmp = new String("test");
String tmp1 = new String("test1");
System.out.println(tmp.equals(tmp1)); // true
System.out.println(tmp == tmp1); // false

equals方法源碼分析

​ 記憶體地址判斷 -> 長度判斷 -> 逐位比較

// 源碼
public boolean equals(Object anObject) {
    if (this == anObject) { // 判斷兩個對象記憶體地址是否相同
        return true;
    }
    if (anObject instanceof String) { // 判斷傳入的參數是不是String對象
        String anotherString = (String)anObject; // 向下轉型,方便後續訪問String特有的方法和屬性
        int n = value.length; // 當前調用equals方法的字元串所對應的char數組的長度
        if (n == anotherString.value.length) { // 判斷兩個字元串的長度是不是一致
            char v1[] = value; // v1代表當前字元串所對應的char數組
            char v2[] = anotherString.value; // v2代表參數字元串所對應的char數組
            int i = 0;
            while (n-- != 0) { // 逐位比較
                if (v1[i] != v2[i])
                    return false;
                i++;
            }
            return true;
        }
    }
    return false;
}

API方法

str.charAt()通過下表獲取索引處的值
String tmp = "test";
System.out.println(tmp.charAt(3)); // t
str.concat("...")返回拼接結果,不改變str本身
String tmp = "test";
System.out.println(tmp.concat(" plus")); // test plus
str.contains("...")判斷是否包含子字元串
String tmp = "test";
System.out.println(tmp.contains("es")); // true
str.endsWith("...")判斷是不是以...結尾
String tmp = "test";
System.out.println(tmp.endsWith("st")); // true
str.equalsIgnoreCase(String tmp)比較時忽略大小寫
String tmp = "test";
String tmp1 = "test01";
System.out.println(tmp.equalsIgnoreCase(tmp1)); // false
str.indexof("...")返回指定字元第一次出現時的索引值
String tmp = "test";
System.out.println(tmp.indexOf("t")); // 0
str.indexof("...",index)返回從index開始往後指定字元第一次出現時的索引值
String tmp = "test";
System.out.println(tmp.indexOf("t",2)); // 3
str.isEmpty當且僅當length()為0時返回true
String tmp = "test";
System.out.println(tmp.isEmpty()); // false
str.toCharArray()將字元串還原成char數組
String tmp = "test";
System.out.println(tmp.toCharArray()); // test
str.split("...")將字元串根據...拆分
String tmp = "This is a test";
String[] res = tmp.split(" ");
for (String i : res) {
    System.out.print(i + " \\ "); // This \ is \ a \ test \ 
}
str.startsWith(...)判斷是否以指定字元串開頭
String tmp = "This is a test";
System.out.println(tmp.startsWith("This")); // true
str.substring()字元串截取
String tmp = "This is a test";
// 一個參數確定開始位置
System.out.println(tmp.substring(3)); // s is a test
// 兩個參數確定起止位置(左閉右開)
System.out.println(tmp.substring(3,8)); // s is 
str.toLowerCase() / str.toUpperCase()將字元強制大小寫
String tmp = "This is a test";
System.out.println(tmp.toLowerCase()); // this is a test
System.out.println(tmp.toUpperCase()); // THIS IS A TEST
str.trim()去除前面和後面的空格
String tmp = "    This is a test    ";
System.out.println(tmp.trim()); // This is a test

系統常用類 StringBuffer / StringBuilder

區別

StringBuffer:支持線程安全,性能相對較差

StringBuilder: 不支持線程安全,性能相對較好

使用方式(StringBuilder為例)

// StringBuilder的底層數組比較String的數組,少了一個final修飾符,因此說明StingBuilder時可變的
// 構造方法:
// 無參構造
StringBuilder tmp = new StringBuilder();
// StringBuilder底層使用的是一個叫做value的字元數組(預設16個字元)
System.out.println(tmp.capacity()); // 16
// 如果不斷的使用append方法進行字元串拼接,StringBuilder就會自動擴容
tmp.append("Hei bro, this is a test !");
System.out.println(tmp.capacity()); // 34

// 有參構造
// 如果出現有參構造,StringBuilder的容量會在初始化字元串的基礎上加上16
StringBuilder tmp = new StringBuilder("This is a test");
System.out.println(tmp.capacity()); // 30

StringBuilder擴容機制

​ 新數組容量 =(原數組的容量+1)*2 :這種擴容機制會使擴容的次數越來越少,增加性能

// 如果StringBuilder需要擴容,就會定義一個新的char數組
// 新數組容量是(原數組的容量+1)*2
// 並且會將指向原數組的指針指向新數組,原數組會被GC進行回收
private int newCapacity(int minCapacity) {
    // overflow-conscious code
    int newCapacity = (value.length << 1) + 2;
    if (newCapacity - minCapacity < 0) {
        newCapacity = minCapacity;
    }
    return (newCapacity <= 0 || MAX_ARRAY_SIZE - newCapacity < 0)
        ? hugeCapacity(minCapacity)
        : newCapacity;
}

API方法(StringBuilder特殊的)

str.capacity()返回StringBuilder容量
str.delete(a,b)刪除此序列的子字元串中的字元
// 刪除子字元串之後,並不影響StringBuilder容量
StringBuilder tmp = new StringBuilder("This is a test");
System.out.println(tmp.delete(3,8)); // Thia test
str.deleteCharAt(a)刪除指定下標的元素
str.replace(a,b,...) 用指定字元串替換指定區間
StringBuilder tmp = new StringBuilder("This is a test");
System.out.println(tmp.replace(4,8," have fun! ")); // This have fun! a test
str.setCharAt()設定指定位置的字元
StringBuilder tmp = new StringBuilder("This is a test");
tmp.setCharAt(4,'G');
System.out.println(tmp); // ThisGis a test
str.toString()創建一個新的String對象,去除尾部多餘的空格
@Override
public String toString() {
    // Create a copy, don't share the array
    return new String(value, 0, count);
}
System.out.println(System.currentTimeMillis());

封裝類

​ 針對八種基本數據類型進行定義以及使用的,封裝類有八個

基本數據類型 對應的封裝類
byte Byte
short Short
int Integer
long Long
float Float
double Double
char Character

賦值的兩種使用方式

// 四種整型的封裝類支持使用常量池技術(-128 ~ 127)
// 通過 = 號賦值的整數,會被存儲在常量池中

// 等號直接賦值(常量池)
Integer tmp1 = 1;
// 使用構造方法(堆)
Integer tmp2 = new Integer(1);

Scanner鍵盤獲取

// 導入包
import java.util.Scanner;
// 使用Scanner類創建一個對象
Scanner s = new Scanner(System.in);
// 獲取系統輸入
// 獲取String類型數據
String input = s.nextline();
// 獲取整型數據
int input = Integer.parseInt(s.nextLine());
// 獲取浮點型數據
float input = Float.parseFloat(s.nextLine());

裝箱和拆箱

裝箱:將基本類型轉換為封裝類類型的過程

拆箱:將封裝類類型轉換為基本類型的過程

int a = 1;
Integer b = 1;
// 自動裝箱
Integer tmp = a;
// 手動裝箱
Integer tmp = new Interger(a);
// 自動拆箱
int tmp = b;
// 手動拆箱
int tmp = b.intValue();

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文是從開源項目 RuoYi 的提交記錄文字描述中根據關鍵字漏洞|安全|阻止篩選而來。旨在為大家介紹日常項目開發中需要註意的一些安全問題以及如何解決。 項目安全是每個開發人員都需要重點關註的問題。如果項目漏洞太多,很容易遭受黑客攻擊與用戶信息泄露的風險。本文將結合3個典型案例,解釋常見的安全漏洞及修 ...
  • 項目介紹&功能實現 1.項目介紹&環境搭建 一個以社交平臺為核心的輕電商項目,功能如下: 簡訊登錄、商戶查詢緩存、優惠券秒殺、達人探店、好友關註、附近的商戶、用戶簽到、UV統計 1.1項目架構 1.2項目環境搭建 1.2.1後端項目搭建 mysql的版本採用5.7及以上版本 (1)首先創建資料庫,需 ...
  • 本文首發於公眾號:Hunter後端 原文鏈接:Django筆記二十四之資料庫函數之比較和轉換函數 這一篇筆記開始介紹幾種資料庫函數,以下是幾種函數及其作用 Cast 轉換類型 Coalesce 優先取值 Greatest 返回較大值 Nullif 值相同返回 None 1、model 準備 這一篇筆 ...
  • 網路分層結構 電腦網路體系大致分為三種,OSI七層模型、TCP/IP四層模型和五層模型。一般面試的時候考察比較多的是五層模型。最全面的Java面試網站 五層模型:應用層、傳輸層、網路層、數據鏈路層、物理層。 應用層:為應用程式提供交互服務。在互聯網中的應用層協議很多,如功能變數名稱系統DNS、HTTP協議 ...
  • 一、哆啦A夢 由於代碼過長,這裡僅顯示部分代碼: from turtle import * import turtle as t from random import * #五軌跡跳躍 def my_goto(x,y): penup() goto(x,y) pendown() def eyes(): ...
  • Go語言流媒體開源項目 LAL 今天發佈了v0.35.4版本。 LAL 項目地址:https://github.com/q191201771/lal 老規矩,簡單介紹一下: ▦ 一. OBS支持RTMP H265推流 新出的標準,一般被稱為enhanced RTMP,OBS新版(29.1+版本,點我 ...
  • 什麼是冒泡排序 冒泡排序(Bubble Sort)也是一種簡單直觀的排序演算法。它重覆地走訪過要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數列的工作是重覆地進行直到沒有再需要交換,也就是說該數列已經排序完成。這個演算法的名字由來是因為越小的元素會經由交換慢慢"浮"到數列的頂端 ...
  • 平時開發時的工作的話之主要負責寫代碼就行了,什麼發佈項目啊,好吧不是我們乾的事。在我們的瞭解中打包發佈項目應該不是一個困難的問題。 對,最簡單的方法就行使用直接使用maven插件打包,甚至我們都不需要知道他是怎麼實現的,插件能幫我們將項目打包為一個jar包,然後使用java -jar xx.jar就 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...