精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

聊一聊 C# 中讓人惶恐的 Bitmap

開發 前端
Bitmap使用不當危害巨大,所以一定要謹記 盡早釋放 的原則,如果真的不幸被吃了很多內存,也一定要明白那些未知的大內存段是不是被 Bitmap 所關聯,從而盡早的找到真正的禍根。

一、背景

1. 講故事

在.NET高級調試的旅程中,我常常會與 Bitmap 短兵相接,它最大的一個危害就是會讓程序拋出匪夷所思的 OutOfMemoryException,也常常會讓一些.NET開發者們陷入其中不能自拔,痛不欲生,基于此,這一篇我從dump分析的角度給大家深挖一下 Bitmap 背后的故事。

二、Bitmap 背后的故事

1. Bitmap 能吃多少內存

相信有很多朋友都知道 bitmap 吃的是非托管內存,但相信也有很多朋友不知道這玩意竟然能吃掉bitmap自身大小的幾十倍,甚至上百倍??赡苓@么說有點抽象,舉一個例子說明一下,用 chatgpt 生成的參考代碼如下:

static void Main(string[] args)
{
    // 創建一個新的Bitmap對象,大小為100x100像素  
    Bitmap bitmap = new Bitmap(21000, 21000);

    // 獲取Bitmap的Graphics對象,用于繪制  
    using (Graphics g = Graphics.FromImage(bitmap))
    {
        // 設置背景色為藍色  
        g.Clear(Color.Blue);

        // 示例:在Bitmap上繪制一個紅色的圓  
        // 設置畫筆顏色為紅色  
        using (Pen pen = new Pen(Color.Red, 10000)) // 10為畫筆粗細  
        {
            // 繪制圓,圓心為(50, 50),半徑為30  
            g.DrawEllipse(pen, 10000, 10000, 15000, 15000);
        }

        // 示例:在Bitmap上繪制文本  
        // 設置字體  
        using (Font font = new Font("Arial", 1600))
        {
            // 設置畫刷顏色為白色  
            using (Brush brush = new SolidBrush(Color.White))
            {
                // 在Bitmap上繪制文本,位置為(10, 70)  
                g.DrawString("Hello, Bitmap!", font, brush, new PointF(100, 700));
            }
        }
    }

    // 保存Bitmap到文件  
    bitmap.Save("example.png", System.Drawing.Imaging.ImageFormat.Png);

    Console.ReadLine();

    // 釋放Bitmap資源  
    bitmap.Dispose();

    Console.WriteLine("Bitmap saved as example.png");

    Debugger.Break();
    Console.ReadLine();
}

在 bitmap.Dispose(); 之前加上一個 Console.ReadLine(); 故意不銷毀 bitmap 來觀察下內存消耗,真是不看不知道,一看嚇一跳,居然吃了高達 1.7G 的內存。

圖片圖片

接下來按一下 Enter 觀察一下 bitmap 在磁盤上的大小,居然小到無語的2M ,這差距咂舌的 1000 倍啊,截圖如下:

圖片圖片

這就是 bitmap 的恐怖之處,也是很多程序員疑惑的地方。

2. Bitmap 吃的是哪里的內存

縱然有很多朋友知道是非托管內存,但還是有必要用數據來展示一下,這個非常簡單,可以用 !address -summary 觀察下提交內存,用 !eeheap -gc 觀察下托管堆即可。

0:006> !address -summary

--- Type Summary (for busy) ------ RgnCount ----------- Total Size -------- %ofBusy %ofTotal
MEM_MAPPED                              168      200`03998000 (   2.000 TB)  88.58%    1.56%
MEM_PRIVATE                              96       42`01319000 ( 264.019 GB)  11.42%    0.20%
MEM_IMAGE                               265        0`03820000 (  56.125 MB)   0.00%    0.00%

--- State Summary ---------------- RgnCount ----------- Total Size -------- %ofBusy %ofTotal
MEM_FREE                                 73     7dbd`f7b1f000 ( 125.742 TB)           98.24%
MEM_RESERVE                              83      241`94389000 (   2.256 TB)  99.92%    1.76%
MEM_COMMIT                              446        0`74148000 (   1.814 GB)   0.08%    0.00%

0:006> !eeheap -gc

========================================
Number of GC Heaps: 1
----------------------------------------
....
------------------------------
GC Allocated Heap Size:    Size: 0x1d7f8 (120824) bytes.
GC Committed Heap Size:    Size: 0x45000 (282624) bytes.

從卦中可以清晰的看到 MEM_COMMIT=1.814 GB 同時 GC Committed Heap Size=2.8M ,妥妥的非托管泄漏。

3. 能找到 Bitmap 所屬的內存段嗎

要想知道 bitmap 所侵占的內存段,如果用 windbg 去調試的話,可以對 KERNELBASE!VirtualAlloc 下一個 bp 斷點即可,參考如下:

0:000> k 5
 # Child-SP          RetAddr               Call Site
00 00000010`5257e198 00007ffb`c2ec7662     KERNELBASE!VirtualAlloc
01 00000010`5257e1a0 00007ffb`c2ec684b     gdiplus!GpMemoryBitmap::AllocBitmapData+0xc6
02 00000010`5257e1e0 00007ffb`c2e8a355     gdiplus!GpMemoryBitmap::AllocBitmapMemory+0x3f
03 00000010`5257e220 00007ffb`c2e8a47a     gdiplus!GpMemoryBitmap::InitNewBitmap+0x49
04 00000010`5257e260 00007ffb`c2e8a2cb     gdiplus!CopyOnWriteBitmap::CopyOnWriteBitmap+0x8a
...

但可惜的是你拿到的是 dump 文件,無法使用 bp 下斷點,那怎么辦呢?只要這輩子積攢的福報夠多,自然不會有絕人之路,首先從托管類 Bitmap 上挖起。

0:000> !DumpObj /d 000001ef0b809648
Name:        System.Drawing.Bitmap
MethodTable: 00007ffa86f0cf90
EEClass:     00007ffa86f34760
Tracked Type: false
Size:        40(0x28) bytes
File:        D:\code\MyCode\ConsoleApplication1\bin\x64\Debug\net8.0\System.Drawing.Common.dll
Fields:
              MT    Field   Offset                 Type VT     Attr            Value Name
00007ffa86e370a0  400019c       18        System.IntPtr  1 instance 000001EF08B222F0 _nativeImage
00007ffa86d85fa8  400019d        8        System.Object  0 instance 0000000000000000 _userData
00007ffa86fc01a8  400019e       10        System.Byte[]  0 instance 0000000000000000 _rawData
00007ffa86f0cee8  4000014       10 System.Drawing.Color  1   static 0000000000000000 s_defaultTransparentColor

從 Bitmap 的字段布局來是用 _nativeImage 字段來持有著對原生 bitmap 的引用,下面的截圖也可以佐證。

圖片圖片

說了這么多,其實我想表達的是什么呢?雖然我不知道 gdiplus 的底層源碼,但有一點可以確認的是,VirtualAlloc 返回的 ptr 和 這里的 _nativeImage 肯定是有偏移關系的,有可能是一級關系,有可能是 二級關系,在我的內存地址視察下,總結如下:

  • 在 Windows10 x64 環境下偏移為 +0x570 。
  • 在 Windows10 x86 環境下偏移為 +0x2e8 。

接下來就可以在 windbg 中輕松做驗證,先攔截 VirtualAlloc 找到大的地址段。

0:000> bp KERNELBASE!VirtualAlloc ".if (@rdx>=0x200000) {  .printf  \"============ %lu bytes  ================\\n\",@rdx; k } .else {gc}"
breakpoint 0 redefined

0:000> g
============ 1764000000 bytes  ================
 # Child-SP          RetAddr               Call Site
00 00000060`d9f7e7b8 00007ffb`c2ec7662     KERNELBASE!VirtualAlloc
01 00000060`d9f7e7c0 00007ffb`c2ec684b     gdiplus!GpMemoryBitmap::AllocBitmapData+0xc6
02 00000060`d9f7e800 00007ffb`c2e8a355     gdiplus!GpMemoryBitmap::AllocBitmapMemory+0x3f
03 00000060`d9f7e840 00007ffb`c2e8a47a     gdiplus!GpMemoryBitmap::InitNewBitmap+0x49
04 00000060`d9f7e880 00007ffb`c2e8a2cb     gdiplus!CopyOnWriteBitmap::CopyOnWriteBitmap+0x8a
05 00000060`d9f7e8c0 00007ffb`c2e8a1b4     gdiplus!GpBitmap::GpBitmap+0x6b
06 00000060`d9f7e900 00007ffa`86e91f95     gdiplus!GdipCreateBitmapFromScan0+0xc4

0:000> pt
KERNELBASE!VirtualAlloc+0x5a:
00007ffb`c25df28a c3              ret

0:000> r
rax=0000020759db0000 rbx=0000000000014820 rcx=00007ffbc4acd3c4
rdx=0000000000000000 rsi=000000000026200a rdi=000001c6c4bb2d20
rip=00007ffbc25df28a rsp=00000060d9f7e7b8 rbp=0000000000005208
 r8=00000060d9f7e778  r9=0000000000005208 r10=0000000000000000
r11=0000000000000246 r12=0000000000005208 r13=0000000000000004
r14=0000000000005208 r15=0000000069248100
iopl=0         nv up ei pl nz na po nc
cs=0033  ss=002b  ds=002b  es=002b  fs=0053  gs=002b             efl=00000206
KERNELBASE!VirtualAlloc+0x5a:
00007ffb`c25df28a c3              ret

0:000> !address 0000020759db0000

Usage:                  <unknown>
Base Address:           00000207`59db0000
End Address:            00000207`c2ff9000
Region Size:            00000000`69249000 (   1.643 GB)
State:                  00001000          MEM_COMMIT
Protect:                00000004          PAGE_READWRITE
Type:                   00020000          MEM_PRIVATE
Allocation Base:        00000207`59db0000
Allocation Protect:     00000004          PAGE_READWRITE


Content source: 1 (target), length: 69249000

從卦中可以看到分配的地址段的首地址為 0000020759db0000,解析來到 Bitmap._nativeImage+0x570 處做個驗證即可,可以看到遙相呼應,輸出如下:

0:000> !DumpObj /d 000001c6c7409648
Name:        System.Drawing.Bitmap
MethodTable: 00007ffa86f4cf90
EEClass:     00007ffa86f74760
Tracked Type: false
Size:        40(0x28) bytes
File:        D:\code\MyCode\ConsoleApplication1\bin\x64\Debug\net8.0\System.Drawing.Common.dll
Fields:
              MT    Field   Offset                 Type VT     Attr            Value Name
00007ffa86e770a0  400019c       18        System.IntPtr  1 instance 000001C6C4BB25B0 _nativeImage
00007ffa86dc5fa8  400019d        8        System.Object  0 instance 0000000000000000 _userData
00007ffa870001a8  400019e       10        System.Byte[]  0 instance 0000000000000000 _rawData
00007ffa86f4cee8  4000014       10 System.Drawing.Color  1   static 0000000000000000 s_defaultTransparentColor

0:000> dp 000001C6C4BB25B0+0x570 L2
000001c6`c4bb2b20  00000207`59db0000 00000000`00000003

三、總結

Bitmap使用不當危害巨大,所以一定要謹記盡早釋放 的原則,如果真的不幸被吃了很多內存,也一定要明白那些未知的大內存段是不是被 Bitmap 所關聯,從而盡早的找到真正的禍根。

責任編輯:武曉燕 來源: 一線碼農聊技術
相關推薦

2022-08-30 07:39:57

C++namespace隔離

2021-03-29 00:02:10

C#Attribute元素

2024-06-28 12:47:29

C#弱引用底層

2024-12-26 10:05:58

C#前臺線程

2023-10-12 09:58:45

操作符C++

2020-10-30 07:11:31

C 語言編程

2022-11-02 08:51:01

2023-12-07 07:26:04

2019-12-02 16:23:03

Python編程語言“垃圾”回收

2020-12-11 11:11:44

原子類JavaCAS

2024-01-02 13:26:39

TLSC#線程

2025-01-10 08:15:22

C#異步底層

2020-10-23 07:00:00

C++函數

2021-01-04 08:09:07

Linux內核Watchdog

2021-06-30 07:19:35

微服務業務MySQL

2022-11-09 08:05:15

JavaScriptsuper()

2019-12-12 14:52:10

數據庫腳本

2020-09-08 06:54:29

Java Gradle語言

2024-10-16 15:11:58

消息隊列系統設計

2022-03-06 20:35:41

并發串行CAP
點贊
收藏

51CTO技術棧公眾號

欧美日韩a v| 国产精品无码专区| 菠萝蜜视频国产在线播放| 国产综合色在线视频区| 久久人人看视频| 伊人网在线视频观看| 久久精品黄色| 午夜电影一区二区| 亚洲激情一区二区| 黑人乱码一区二区三区av| 亚洲视频播放| 久久精品亚洲精品| 国产成人无码一区二区在线观看| 久久精品国产福利| 精品久久久久久亚洲精品| 亚洲欧洲精品一区二区三区波多野1战4 | 欧美另类交人妖| 在线不卡av电影| 国产伦乱精品| 91精品国产色综合久久| 欧美污视频网站| 第一av在线| 亚洲色图在线视频| 日韩精品久久久毛片一区二区| 亚洲精品中文字幕成人片| 青青青爽久久午夜综合久久午夜| 欧美激情在线观看视频| 日韩在线视频免费看| 欧美韩一区二区| 日韩欧美色电影| 超碰在线人人爱| 中文字幕在线视频久| 一区二区三区高清在线| 亚洲欧洲久久| 狠狠色伊人亚洲综合网站l| 成人av手机在线观看| 99国产盗摄| 国产精品久久久久久久一区二区| 丝袜诱惑亚洲看片 | 不卡一二三区| 亚洲第一福利一区| 亚洲五码在线观看视频| 黄色网页在线免费看| 国产清纯美女被跳蛋高潮一区二区久久w| 国产精品久久久久久久久久久久冷| 艳妇乳肉豪妇荡乳av| 丝袜国产日韩另类美女| 欧洲美女免费图片一区| 圆产精品久久久久久久久久久| 欧美日韩a区| 久久精品中文字幕免费mv| 中文天堂资源在线| 成人在线国产| 日韩色av导航| 手机在线免费看片| 在线观看国产精品入口| 欧美成在线观看| 精品欧美一区二区久久久久| 亚洲色图欧美| 久久久精品人体av艺术| 91精品网站| 国产夫绿帽单男3p精品视频| 国产不卡视频在线观看| 国产精品日韩欧美一区二区| 亚洲不卡免费视频| 成人午夜电影小说| 玛丽玛丽电影原版免费观看1977 | 亚洲最新av在线| 欧美成人另类视频| 国产电影一区二区在线观看| www.久久色.com| 四虎影院中文字幕| 欧美久久一区| 欧美亚洲午夜视频在线观看| 国产性生活视频| 日本不卡的三区四区五区| 国产欧美日韩91| 国产婷婷在线视频| 成人激情小说网站| 欧美一级爽aaaaa大片| 77导航福利在线| 亚洲免费看黄网站| 久久国产精品网| 国产综合色区在线观看| 欧美久久一二区| 精品国产aⅴ一区二区三区东京热| 中文在线综合| 亚洲欧洲日产国产网站| 九九这里只有精品视频| 国产精品99一区二区| 欧美与欧洲交xxxx免费观看| 91精品免费视频| www.天天色| 日韩精品国产欧美| 成人亚洲综合色就1024| 亚洲欧美强伦一区二区| 久久综合久久综合亚洲| 亚洲欧洲精品一区| av手机在线观看| 欧美亚一区二区| 久久久无码人妻精品无码| 婷婷成人在线| 超碰日本道色综合久久综合| 欧美在线观看不卡| 国内成人精品2018免费看| 精品国产乱码久久久久| 91在线播放网站| 亚洲福利电影网| 国产三级国产精品国产专区50| 日韩欧美中文字幕在线视频| 国产亚洲精品91在线| 黄色一级视频在线观看| 视频在线观看一区二区三区| 亚洲一区二区三区sesese| 美女毛片在线看| 亚洲综合偷拍欧美一区色| www日韩在线观看| avtt综合网| 久久视频这里只有精品| 久久久精品毛片| 不卡av在线网| 日本免费成人网| 久久青草视频| 亚洲一级黄色av| 影音先锋亚洲天堂| 成人小视频免费在线观看| 在线观看成人av| 日韩三级影视| 日韩精品欧美激情| 国产一级视频在线观看| 国产一区在线观看视频| 亚洲精品国产一区| 蜜桃精品在线| 亚洲精品一区av在线播放| 日本一级黄色录像| 成人一区二区三区在线观看| 青青在线免费视频| 亚洲狼人综合| 久久精品国产91精品亚洲| 少妇又紧又色又爽又刺激视频 | 国产精品手机视频| av片在线观看| 欧美一区二区在线播放| 日韩av网站在线播放| 日韩精品成人一区二区在线| 欧美日韩一区二区三| 欧产日产国产精品视频| 亚洲高清在线观看| 日本少妇bbwbbw精品| 高清不卡一二三区| 国产在线播放观看| 欧美日韩一区二区三区在线电影 | 久久免费视频99| 国产精品一区免费视频| a级片一区二区| 1204国产成人精品视频| 久久久亚洲国产天美传媒修理工| 丰满熟女一区二区三区| 午夜亚洲国产au精品一区二区| 四虎永久免费观看| 影音先锋亚洲电影| 久久久久久久久久码影片| 亚洲欧美电影| 国产亚洲一区精品| 97超碰人人草| 亚洲一区二区在线免费看| 中国黄色片视频| 亚洲欧美高清| 日日骚一区二区网站| 欧美黄色网络| 久久99国产精品久久久久久久久| 欧美一级淫片aaaaaa| 五月激情综合色| 日本aaa视频| 蜜臀国产一区二区三区在线播放| 中文字幕免费高| 成人中文字幕视频| 国产精品va在线播放| 黄网站在线免费| 亚洲国产精品久久久久久| 国产免费一级视频| 中文字幕亚洲一区二区av在线 | 中文乱码免费一区二区| 永久免费黄色片| 亚洲美洲欧洲综合国产一区| 日韩欧美电影一区二区| 狂野欧美xxxx韩国少妇| 18久久久久久| 日本在线视频网| 亚洲第一页在线| 久久久久久久久久一级| 一区二区三区精品| 蜜桃无码一区二区三区| 国产一区二区三区蝌蚪| 欧美,日韩,国产在线| 91综合在线| 国产一区二区在线观看免费播放| 99久久er| 91精品国产91久久久久久| 亚洲成人三级| 精品视频在线导航| 99热这里只有精品在线观看| 欧美性生交大片免费| 999久久久国产| av不卡免费在线观看| 中文字幕成人免费视频| 丝袜诱惑制服诱惑色一区在线观看| 免费的av在线| 欧美电影免费播放| 裸模一区二区三区免费| 国产精品午夜av| 92国产精品视频| 九色成人搞黄网站| 欧美性视频精品| 青青青国内视频在线观看软件| 在线一区二区日韩| 性xxxx18| 精品国产一区二区三区av性色 | 亚洲国产精品123| 老牛精品亚洲成av人片| 69堂成人精品视频免费| 成人黄色免费观看| 国产99久久精品一区二区永久免费| 亚洲七七久久综合桃花剧情介绍| 中文字幕v亚洲ⅴv天堂| 欧美欧美欧美| 精品五月天久久| 老牛影视av牛牛影视av| 日韩精品一区二区在线观看| 亚洲资源在线播放| 欧美系列日韩一区| 黄色av一级片| 欧美性猛交xxxx| 欧美另类一区二区| 婷婷国产v国产偷v亚洲高清| 国产精品suv一区二区| 亚洲精品精品亚洲| 18岁成人毛片| 中文字幕欧美区| 免费看的黄色网| 国产喂奶挤奶一区二区三区| 女~淫辱の触手3d动漫| 91年精品国产| 免费中文字幕av| 91浏览器在线视频| 一级国产黄色片| 久久这里都是精品| 欧美丰满少妇人妻精品| 久久久久久久免费视频了| 极品粉嫩小仙女高潮喷水久久| av成人免费在线| 艳妇乳肉亭妇荡乳av| 99精品久久只有精品| 国产精品久久不卡| 99精品视频中文字幕| 午夜一区二区三区免费| 91蝌蚪porny| 99久久精品免费视频| 中文字幕第一区第二区| 任我爽在线视频| 一区在线播放视频| 国产va在线播放| 亚洲成人第一页| chinese国产精品| 欧美在线观看视频在线| 一级黄色大毛片| 欧美一级理论片| 深爱五月激情五月| 亚洲天堂av网| 在线免费观看黄色网址| 久久精品国产99国产精品澳门 | 亚洲图片有声小说| 日本少妇做爰全过程毛片| 精品久久久久久电影| 夜夜爽妓女8888视频免费观看| 欧美性生交片4| 国产女人18毛片水真多| 精品久久久久久久久久久久久久久 | 日韩成人精品在线| 中文字幕55页| 99久久伊人久久99| jizz18女人高潮| 夜色激情一区二区| 国产精品21p| 欧美日韩高清影院| 后进极品白嫩翘臀在线视频| 亚洲欧美日韩网| 黄色网址视频在线观看| 97av在线播放| 不卡一区视频| 精品在线观看一区二区| 色小子综合网| 精品视频免费在线播放| 久久精品国产精品亚洲红杏| 国产香蕉精品视频| 国产欧美一二三区| 久一视频在线观看| 欧美视频中文字幕| 高清乱码毛片入口| 日韩中文字幕视频在线观看| аⅴ资源天堂资源库在线| 国产欧美久久一区二区| 色天下一区二区三区| 中文字幕日韩一区二区三区| 一本一本久久| 亚洲熟女一区二区三区| 国产精品国产三级国产三级人妇| 91在线看视频| 日韩亚洲欧美高清| 午夜免费福利在线观看| 国产做受高潮69| 亚洲国产91视频| 日本不卡高清视频一区| 亚洲人成人一区二区三区| www.国产福利| 欧美激情一二三区| 亚洲免费在线观看av| 欧美xfplay| 高h视频在线观看| 国产精品亚洲自拍| 亚洲人挤奶视频| 激情伊人五月天| 成人在线视频首页| 精品99久久久久成人网站免费 | 亚洲精品一区二区三区区别| 精品国产一区av| 欧美日韩五区| 欧美亚洲精品日韩| 国产欧美激情| 日本少妇xxxx| 亚洲在线观看免费| 国产人妖在线播放| 久久精品视频亚洲| 欧美一区=区三区| 亚洲草草视频| 视频一区欧美精品| 在线观看福利片| 色综合久久天天| 欧美色图另类| 国产成人黄色av| 国产精品欧美三级在线观看| 人妻熟女一二三区夜夜爱| 91丨九色丨蝌蚪丨老版| 天天综合网入口| 亚洲欧美中文字幕在线一区| 伊人久久综合一区二区| 欧美凹凸一区二区三区视频| 午夜亚洲福利在线老司机| 国产激情在线免费观看| 色乱码一区二区三区88| 黄色在线播放| 国产精品视频区| 99久久亚洲精品| 国内av免费观看| 亚洲一区二区三区视频在线 | 国产精品久久久久久久久久辛辛| 99re99热| 成人在线视频一区二区| 日韩高清免费av| 亚洲欧美精品伊人久久| 91大神在线观看线路一区| 亚洲精品中文字幕乱码三区不卡| 久久精品国产成人一区二区三区| 一级片一级片一级片| 日韩欧美一区二区不卡| a级大胆欧美人体大胆666| 久久久久se| 蜜桃av一区二区三区电影| 午夜剧场免费在线观看| 精品不卡在线视频| 天堂av在线网| 亚洲欧洲国产精品久久| 国产iv一区二区三区| 羞羞影院体验区| 中文字幕视频一区二区在线有码 | 精品日韩电影| 奇米影视一区二区三区| 手机在线免费看毛片| 亚洲成av人片在线观看香蕉| 欧美福利在线播放| 黄黄视频在线观看| 91丨porny丨国产| 一级α片免费看刺激高潮视频| 欧美丰满少妇xxxx| 国产不卡一二三区| 日本55丰满熟妇厨房伦| 激情成人中文字幕| 免费的黄网站在线观看| 国内一区在线| 久久99国产精品久久99| 亚洲国产精一区二区三区性色| 国产亚洲欧美视频| julia中文字幕一区二区99在线| 成人午夜视频免费在线观看| 亚洲欧美一区二区不卡| 你懂的在线免费观看| 18成人在线| 日韩电影免费在线观看网站| 日韩激情一区二区三区| 色婷婷久久一区二区|