一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - .NET下模擬數組越界的方法詳解

.NET下模擬數組越界的方法詳解

2020-06-06 16:29K戰神 ASP.NET教程

這篇文章主要給大家介紹了關于.NET下模擬數組越界的相關資料,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

前面一篇文章提到過 數組越界行為,雖然編譯器為我們做了大量的檢查工作讓我們避免這些錯誤。

但是我覺得還是有必要模擬一下數組越界,感受一下這個錯誤。

那么對于.NET來說我們怎么來模擬數組越界呢?

一、 [VS] 項目 -> 右擊 -> 屬性 -> 生成 -> (勾選)允許不安全代碼

.NET下模擬數組越界的方法詳解

二、測試代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
unsafe private static void OutOfIndexMini()
  {
   int* i = stackalloc int[1];
 
   i[0] = 0;
   //i[0] = 1;
 
   //double* d = stackalloc double[1];
   //d[0] = 0.01;
 
   int* a = stackalloc int[3];
 
   for (; i[0] <= 3; i[0]++)
   {
    a[i[0]] = 0;
 
    Console.WriteLine($"int* i = {i[0]}");
 
    Console.WriteLine($"int* a[{i[0]}] = {a[i[0]]}");
   }
 
  }

簡單說明一下:

unsafe 關鍵字 -- 支持不安全代碼,就是說我們可以使用指針了。

stackalloc 關鍵字 -- 允許向堆棧申請內存了。

下面這兩句:我向內存申請 了數組 int[1],容量為一個int,并同時給這個賦值為1

?
1
2
3
int* i = stackalloc int[1];
 
i[0] = 0;

接下來:我緊接著向內存申請了數組 int[3],容量為 3個int.

?
1
int* a = stackalloc int[3];

然后注意:我的for循環數組越界了i[0] <= 3

?
1
2
3
4
5
6
7
8
for (; i[0] <= 3; i[0]++)
{
  a[i[0]] = 0;
 
  Console.WriteLine($"int* i = {i[0]}");
 
  Console.WriteLine($"int* a[{i[0]}] = {a[i[0]]}");
}

初始值 i[ 0 ] = 0,所以進入for循環

i[0] = 0 >>> a[ i[ 0 ] ] =0 >>>a[ 0 ] =0

i[0] = 1 >>> a[ i[ 0 ] ] =0 >>>a[ 1 ] =0

i[0] = 2 >>> a[ i[ 0 ] ] =0 >>>a[ 2 ] =0

i[0] = 3 >>> a[ i[ 0 ] ] =0 >>>a[ 3 ] =0 ?

此時 a[ 3 ] 對于我們平常來說已經數組越界了,但是這里仍然可以正常賦值。那這個值我們給了誰?

我們先給出一個答案:

  a[3] 其實越界到了 i[0] 地盤,也就是 a[3] = i[0] = 0,

  這就造成 當 i[0] = 3 時,a[3] 越界將 i[0] 修改為0,程序進入死循環 ... ...

三、驗證

如果,我將 i[0] 初始值修改一下,改成1

?
1
2
3
4
int* i = stackalloc int[1];
 
//i[0] = 0;
i[0] = 1;

那么在越界后a[3] = i[0] = 0 ,打印出來 i [0] = 0 說明數組確實越界并修改了值。

.NET下模擬數組越界的方法詳解

那么,我在中間再聲明一個不是int類型的數組,導致越界不是修改的 i[0] 這樣就不會死循環了。

?
1
2
3
4
5
6
7
8
9
int* i = stackalloc int[1];
 
//i[0] = 0;
i[0] = 1;
 
double* d = stackalloc double[1];
d[0] = 1;
 
int* a = stackalloc int[3];

.NET下模擬數組越界的方法詳解

四、原理分析

因為數組是相同的數據類型,連續內存。

第一次:i=0 ,a[0] 內存地址 1000

第二次:i=1 ,a[1] 內存地址 1004

第三次:i=2 ,a[2] 內存地址 1008

第四次:i=3 ,a[3] 內存地址 1012,也就是越界到了 i[0]

.NET下模擬數組越界的方法詳解

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:https://www.cnblogs.com/sunchong/p/10249359.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天天碰夜夜操 | 成人涩涩屋福利视频 | 第一次破女视频国产一级 | 996免费视频国产在线播放 | 99re热这里只有精品 | 高级黄色片 | 天天色踪合合 | 男人操女人视频 | 久久性生大片免费观看性 | 国产伦精品一区二区三区免费观看 | 精品综合久久久久久97超人 | 特黄特色大片免费视频大全 | 91成人免费观看 | 欧洲老太玩小伙 | 日韩欧美推理片免费看完整版 | 明星乱亚洲 | 国产清纯91天堂在线观看 | 日韩国产欧美成人一区二区影院 | 亚洲黄色高清 | 亚洲精品老司机福利在线播放 | 日本一卡2卡3卡4卡乱 | 女老板用丝袜脚夹我好爽 | 好大好猛好爽好深视频免费 | 美女脱小内内给男生摸j | 精品国产一区二区 | 青草娱乐极品免费视频 | 好大好爽好舒服视频 | 亚洲国产成人久久综合一 | 嗯啊在线观看免费影院 | 国产精品1024永久免费视频 | 特级淫片大乳女子高清视频 | 日本精品人妖shemale人妖 | 亚洲精品国产一区二区第一页 | 91制片厂制作果冻传媒2021 | 石原莉奈adn093店长未婚妻 | 91污污视频 | 大学生初次破苞免费视频 | 天堂网在线.www天堂在线视频 | 男人晚上适合偷偷看的污污 | 厨房里摸着乳丰满在线观看 | 国产精品久久国产精品99盘 |