主頁 > 後端開發 > 指標其實也沒有那么難

指標其實也沒有那么難

2021-12-11 06:07:08 後端開發

指標其實也沒有那么難 — 初級指標

本章內容是指標的內容,有哪些地方寫的不好還請多多指點,??

首先說一下指標的初級知識點什么是指標,


指標是什么?

按傳統的方式來講:

在計算機科學中,指標(Pointer)是編程語言中的一個物件,利用地址,它的值直接指向
(points to)存在電腦存盤器中另一個地方的值,由于通過地址能找到所需的變數單元,可以
說,地址指向該變數單元,因此,將地址形象化的稱為“指標”,意思是通過它能找到以它為地址
記憶體單元

記憶體單元是什么呢?就好比現實生活中我們的房間,不就是哪個單元哪個房間號嘛,

我們用畫圖的形式來展示,

指標

指標是個變數,存放記憶體單元的地址(編號),

用代碼方式表示:

#include <stdio.h>
int main()
{
    int i = 9;//向記憶體申請一塊空間
    int* p = &i;//&i 取出i的地址 放到p變數中  而p就是一個指標變數 它指向的是i變數所在的地址
    return 0;
}

簡單的來說: 指標就是個變數,這個變數是用來存放地址的,(存放到指標變數中的值都將被當作地址處理),

比如說: int* p = 12;

資料在記憶體中都是地址的形式存放的,而在記憶體中地址是以4位16進制和8位16進制表示的,而12的16進制不就是字母C嗎,

上面一行代碼解釋為:定義一個整型指標變數,把12這個值當作地址賦值給變數p,%p以地址的形式列印所以是 --> 0000000C,

  • 一個小的單元到底是多大?(1個位元組)

對于32位機器來說,我們假設有32根地址線,每根地址線在尋找地址的時候產生一個電信號正電或者負電(1/0)

那么32根地址線產生的地址是:

00000000 00000000 00000000 00000000

00000000 00000000 00000000 00000001

00000000 00000000 00000000 00000010

......

11111111 11111111 11111111 11111111

2的32次方個地址,

每個地址標識一個位元組,那么就可以給(2^32Byte == 2^32/1024KB == 2^32/1024/1024MB == 2^32/1024/1024/1024GB == 4GB)

4GB的空閑編址,同樣的方法放到64位機器上,編址有16777216TB,是這么多嗎

這里我們就明白了:

  • 在32位機器上,地址是32個0或者1組成的二進制序列,那地址就應該用4個位元組的空間來存盤,所以一個指標變數大小就是4個位元組
  • 換做64位機器上,那地址就應該用8個位元組來存盤,指標變數大小就是8個位元組,

由此我們得出結論:

  • 指標是用來存放地址的,地址是唯一標示一塊地址空間的,
  • 指標的大小在32位平臺上是4個位元組,在64位平臺上是8個位元組,

指標和指標型別

在此之前我們學過基本型別有:整型、字符型、浮點型等,既然指標也是變數,那指標是不是也會有不同的型別呢?答案是肯定的!

指標也是變數,所以也會有該對應的指標型別,下面舉幾個例子:

#include <stdio.h>
int main()
{
    int a = 10;//整型
    char b = 'w';//字符型
    float c = 3.14;//單精度浮點型
    double d = 123.789;//雙精度浮點型
    
    int* pa = &a;//整形指標
    char* pb = &b;//字符指標
    float* pc = &c;//浮點型指標
    double* pd = &d;//浮點型指標
    return 0;
}

以上代碼就列舉了部分指標型別,

下面我們來看一段代碼

sizeof()是計算資料大小的運算子,單位是位元組,可以看到不管是什么型別的指標都是4個位元組,誒~既然大小都是4個位元組,那我們定義不同型別的指標又有什么意義呢?那我們何不造一個通用型別的指標呢?當然不行呢,你看我們每個人每天都要吃飯,雖然說有不同的方式可以讓自己吃飽,但是為什么要這么多不同的食品讓我們填飽肚子呢?直接造一種可以讓人吃飽的食品不就好了,這個時候大家又知道了不同的食品有不同的作用,有些要補維生素A呀或者是維生素B呀等等,同樣的指標型別也會有它不同的意義呀!

下面我們繼續看段代碼

我們看到記憶體上,a的地址,后面是變數a的資料存盤方式 -->小端存盤方式,當我們把a的地址存放到變數pa中,我們通過地址去改變a的值,請看下面

右下角我們看到pa變數的值變成了a的地址,而且a的值也被改成了20,好這個看不出什么,下面我們看另外一段代碼

跟上面一樣,我只是改變了指標的型別,改變指標型別后我們看到*pa=20執行之后,為什么右上角的值變成了 14 46 13 00呢?

通過觀察,指標型別不同,操作的位元組數就不同,可以看到int* 指標改變的是4個位元組,而char* 指標改變的是1個位元組,

由此我們得出結論:

指標型別決定了,對指標解參考的時候有多大權限(能操作幾個字符),比如說:char* 的指標解參考就只能訪問一個位元組,而int*的指標解參考能訪問4個位元組,

指標型別意義1:

指標型別決定了指標解參考時,能訪問的空間大小,

我們繼續看下面一段代碼的運行結果:

可以看到int型別指標p的地址與p+1的地址之間差了4 而char型別指標pc和pc+1的地址之間差了1,雖然說是以陣列來舉例子,不過就算不用陣列舉例也是一樣的,

指標型別意義2:

指標型別決定了指標+1或者-1有多大距離(指標的步長),也就是位元組

這有啥用呢?

可以知道我們創建了一個整型陣列,這個陣列有10個元素全部初始化成0了,陣列名代表陣列首元素的地址,把陣列首元素的地址傳給變數p通過回圈給陣列賦值,

結果很明顯,通過指標+整數訪問陣列的元素,然后再給陣列元素賦值,那么我們把指標型別改一下呢會出現什么效果?

它改變的是什么?搜嘎斯內,它只改變了整型資料中一個位元組的內容,這是一個位元組一個位元組的訪問,沒改變指標型別之前呢,沒改變之前是4個位元組4個位元組的訪問所以啊,

  1. 希望一個位元組一個位元組訪問 可以用char型別的指標
  2. 一個整型一個整型訪問 可以用int型別的指標

以此類推,想怎樣訪問就用什么樣型別的指標,

總結一下指標型別的作用

  1. 指標型別決定了指標解參考(訪問位元組)的權限有多大,
  2. 指標型別決定了指標向前走或者向后走有多大(距離,步長),

野指標

野指標,大家看到會想起啥?野狗?野貓?它們都是沒得家的沒得主人,到處流浪,那么野指標是啥?

先按傳統的說法:

野指標就是指標指向的位置是不可知的(隨機的、不正確的、沒有明確限制的)

那為什么會產生野指標這玩意兒呢?

接下來我們看看野指標形成的原因,

野指標成因

1.指標未初始化

 #include <stdio.h>
 int main()
 {
     int* p ;//定義一個區域的指標變數,區域變數不初始化的話,默認是隨機值
     *p = 10;//*p是對指標的解參考操作,這里非法訪問記憶體
 	//使用了未初始化的區域變數p
 	//使用未初始化的記憶體p
     return 0;
 }

2.指標越界訪問

 int main()
 {
 	int arr[10] = { 0 };
 	int* p = arr;
 	int i = 0;
 	for (i = 0; i <= 10; i++)
 	{
 		//當指標指向的范圍超出陣列arr的范圍時,p就是野指標
 		*p = i;
 		p++;
 	}
 	return 0;
 }

3.指標指向的空間釋放

int* work()
{
	int a = 20;//函式呼叫后變數a銷毀了
	return &a;//所以此時a的地址雖然說還是那地址,但是指向的那塊空間已經還給了作業系統
}
int main()
{
	int* p = work();
    //對p指標的解參考 去訪問一個已經還給作業系統的空間 那片空間說不定作業系統已經存放其他內容 而且這也是屬于非法訪問記憶體
	*p = 30;
	return 0;
}

說了這么多的野指標成因,那我們應該怎樣有效的避免野指標的產生呢?

  1. 初始化指標
  2. 小心指標越界
  3. 指標指向空間釋放即使置NULL
  4. 指標使用之前檢查有效性 可用assert斷言
#include <stdio.h>
int main()
{
    //當不知道p應該初始化為什么地址的時候,可以初始化NULL
    int* p = NULL;//初始化指標
    return 0;
}

指標運算

指標運算有3種形式:

  • 指標±整數
  • 指標-指標
  • 指標的關系運算

指標±整數

int main()
{
	int arr[10] = { 20,21,22,23,24,25,26,27,28,29 };
	int* p = arr;
	int* end = arr + 9;
	while (p <= end)
	{
		printf("%d\n", *p);
		p++;//指標+整數    p+=1;
	}
	return 0;
}

可以知曉,指標+整數 在整型陣列中訪問下一個元素,既然可以+那肯定也能-

指標-整數

指標-指標

指標-指標,聯系之前學過的內容,指標不就是地址嘛,那指標-指標 不就是 地址 - 地址,指標+指標沒啥意義,就和日期一樣,日期+日期有啥用嘛?日期-日期可以,日期+天數也可以,但是日期加日期就沒啥意義了,

#include <stdio.h>
int main()
{
    int arr[10]={1,2,3,4,5,6,7,8,9,10};
    int* p = arr;
    int* end = arr + 9;
    printf("%d\n", end - p);
    return 0;
}

代碼運行如下:

運行結果是9,我們發現從arr[0]到arr[9]之間剛好就是9個元素,

試試arr - (arr +9)這不是-9嘛看看代碼運行效果:

結果也是-9,雖然數字是相同了,但是符號卻不相同,而陣列中是隨著陣列下標的增長地址是由低到高的,記憶體中地址也是由低到高,

因此我們如要需要得到元素的個數,應該用高地址- 低地址,

注意事項:

指標-指標的前提是:兩個指標指向的是通一塊空間

給大家來個實際點的:

#include <stdio.h>
//函式遞回方法
int me_strlen(char*str)
{
    if(*str != '\0')
        return 1 + me_strlen(str + 1);
    else
        return 0;
}
int me_strlen(char* str)
{
    char* p = str;//p指標指向 str 變數   str 指向的是 字串首字符的地址
    while(p != '\0')//字串長度是找'\0'
    {
        p++;
    }
    return p - str;//指標-指標 就是中間元素個數 
}
int main()
{
    char arr[] = "hello world";
    int ret = me_strlen(arr);//傳字串首字符的地址
    return 0;
}

指標關系的運算

指標關系運算,我們知道關系運算是啥,關系運算不就是 > < >= <= != ==

用代碼舉個例子吧:

#include <stdio.h>
int main()
{
    int arr[5];
    int *p;
    for( p = &arr[5]; p > arr[0])
    {
        *--p = 0;
    }
    return 0;
}

這個代碼不太標準,看著有點難受,修改一下

#include <stdio.h>
int main()
{
    int arr[5];
    int *p;
    for( p = &arr[4]; p > arr[0]; p--)
    {
        *p = 0;
    }
    return 0;
}

這個代碼是什么意思呢?咱們畫圖理解一下

該代碼的意思是:取出arr陣列后面一個元素的地址,判斷該地址是否大于陣列首元素的地址,如果大于那就把p變數所指向的內容改為0,然后在自減,也就是往arr[0]那邊走,再以同樣的方式賦值,直到p的地址要小于或者是等于arr[0]回圈就結束,

但是請注意:

允許指向陣列元素的指標與指向陣列最后一個元素后面的那個記憶體位置的指標比較,但是不允許與指向第一個元素之前的那個記憶體位置的指標進行比較,

如果還不明白請自己畫圖理解一下,

指標和陣列

指標和陣列的關系:指標是地址嘛,而陣列名是陣列首元素地址, 我們舉個例子

有圖有真相(doge),可以看到arr和&arr[0]的地址是一樣的,所以說,陣列名就是陣列首元素地址,

#include <stdio.h>
int main()
{
    int arr[10]={1,2,3,4,5,6,7,8,9,10};
    int* p = arr;//p存放的就是陣列首元素地址
    return 0;
}

但是陣列名就一定是陣列首元素地址嗎?NONONO,也有例外啦!請記住下面2點

  1. sizeof(陣列名) --> 只有陣列名沒有其他運算子 陣列名表示整個陣列,計算的是整個陣列的大小,單位是位元組,
  2. &陣列名 -- > 取出的是整個陣列的地址 陣列名表示整個陣列

其他情況下,陣列名就是首元素地址,

首元素的地址和陣列的地址有啥區別呢?

靠,這不一樣嘛(手動狗頭)?雀食哈,這列印出來都一樣,但是意義卻截然不同呢,不信再舉個例子:

看到區別沒,arr是陣列名,代表首元素地址,+1 因為陣列型別是int 而int型別指標+1 不就是跳過4個位元組 剛好差4,

而&arr,arr代表整個陣列,+1 跳過了一個陣列,兩個地址之間差 40個位元組,

既然可以把陣列名當成地址存放到一個指標中,我們可以使用指標來一個個的訪問,

#include <stdio.h>
int main()
{
	int arr[10] = { 0 };
	int* p = arr;
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%p <==> %p\n", &arr[i], p + i);
		*(p + i) = i;
	}
	return 0;
}

效果:

所以 p+i 其實計算的是陣列 arr 下標為i的地址 ,

那我們就可以直接通過指標來訪問陣列 ,

int main()
{
	int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
	int* p = arr;//陣列名
    int sz = sizeof(arr)/sizeof(arr[0]);
    int i = 0;
    for(i=0;i<sz;i++)
    {
        printf("%d",*(p+1));
    }
	//[ ]是運算子  2和arr是兩個運算元
	printf("%d \n", 2[arr]);
	printf("%d \n", arr[2]);
	printf("%d \n", 2[p]);//p[2] --> *(p+2)
	//arr[2] --> *(arr+2) --> *(2+arr) --> 2[arr]
	//arr[2]<==> *(arr+2) <==> *(p+2) <==> *(2+p) <==> *(2+arr) == 2[arr]
	//2[arr] <==> *(2+arr)
	return 0;
} 

二級指標

二級指標,有沒有覺得好高級,之前了解到指標本質上還是變數嘛,只是用來存放地址的變數而已,既然是變數那它是不是也會有地址?

那當然,那么存放指標變數的地址就叫二級指標咯,畫圖舉個例子就知道了:

這樣是不是好理解一些,

#include <stdio.h>
int main()
{
    int a= 1;
    int* p = &a;//p是指標變數,一級指標
    int** pa = &p;//pa也是指標變數,二級指標
    return 0;
}

說完了什么是二級指標,那二級指標如何使用呢?其實和一級指標的使用是類似的,

  • *pa 通過對pa的地址解參考,找到p, *pa其實訪問的就是p,

    int b = 1;
    *pa = &a;//等價于 p = &a;
    
  • **pa先通過 *pa找到p,然后對p進行解參考操作: *p,找到a

    **pa = 30;
    //等價于*pa = 30;
    //等價于a = 30;
    

指標陣列

我們學過整型陣列、字符型陣列,那么指標有沒有陣列呢?

答案肯定是有的,還記得陣列的定義是什么嗎?陣列是一組相同型別元素的集合,那么一組相同型別的指標放在一起這算不算是陣列呢?

這肯定是陣列,因為它滿足陣列的定義,那么指標陣列又是怎么樣的呢?

首先指標陣列的定義:一組相同型別的指標的集合

int arr[10];//這是整型陣列,陣列有10個元素,陣列中每個元素都是整型,

char arry[5];//這是字符型陣列,陣列有5個元素,陣列中每個元素都是字符型,

#include <stdio.h>
int main()
{
    int a = 1;
    int b = 2;
    int c = 3;
    int* pa = &a;
    int* pb = &b;
    int* pc = &c;
    return 0;
}

這段代碼中,a、b、c均為整型變數,pa、pb、pc均為整形指標,3個整型變數用3個整型指標來接收豈不是浪費空間了?那我們干脆把這3個整型指標放在一起組成一個整型指標陣列不就好了嘛,誒指標陣列這不就出來了嘛,

首先定義一個陣列 int arr[10]; 既然每個型別都是指標,那么把陣列的型別改一下不就好了嘛, int* arr[10]; 這時我們就說這個陣列是指標陣列嘛,這是一個整型指標陣列,該陣列有10個元素且每一個元素都是整型指標,那么我們畫圖展示一下:

用代碼的形式:

int main()
{
	int arr[10];//整形陣列 - 存放整形的陣列就是整形陣列
	char ch[5];//字符陣列 - 存放的是字符
	//指標陣列 - 存放指標的陣列
	int* parr[5];//整形指標的陣列
	char* pch[5];//字符型指標陣列
	return 0;
}

想必大家看了這幾幅圖和代碼,對指標陣列應該有大概的了解了吧,


感謝大家的收看,以上都是鄙人學習的個人理解如果有哪些地方說錯了或者是沒有講明白,還請大家多多指點指點,謝謝大家!!!

這部分是鄙人對指標的初步了解后面進階的會在【指標其實也沒有那么難—進階指標】這篇中講解,

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/379038.html

標籤:C

上一篇:根據推薦鏈接自動選擇聯系表7中的欄位

下一篇:離散傅立葉變換:二維周期信號的反相導致頻率加倍

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more