精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

国产精品美女午夜av| 精品网站999www| 18视频在线观看娇喘| 亚洲第一成年人网站| 99这里有精品| 中文字幕精品网| 日本少妇xxx| 成人性生交大片免费网站| 国产精品乱人伦| 性xx色xx综合久久久xx| 亚洲第一福利网站| 91人人澡人人爽人人精品| av电影高清在线观看| 91丨porny丨蝌蚪视频| 国产精品自拍视频| 色网站在线播放| 亚洲国产成人精品女人| 国产视频精品免费播放| 亚洲色图欧美自拍| www.成人爱| 一区二区三区四区在线播放| 欧美日韩精品综合| 亚洲va欧美va| 久久精品国产一区二区| 欧美性一区二区三区| 久久成人国产精品入口| heyzo久久| 日韩av综合中文字幕| 亚洲精品mv在线观看| 欧美色网一区| 午夜欧美一区二区三区在线播放| 亚洲国产精品影视| 高清日韩av电影| 97se亚洲国产综合自在线不卡| 92看片淫黄大片看国产片| 天天干天天插天天射| 中文在线不卡| 久久久亚洲天堂| 成人免费视频网站入口::| 成人a'v在线播放| 亚洲乱码一区av黑人高潮| 潘金莲一级淫片aaaaaaa| 九七影院97影院理论片久久| 在线免费观看日韩欧美| 久久久久久久久久久视频| 免费电影网站在线视频观看福利| 综合婷婷亚洲小说| 在线国产99| 在线观看的av| 国产精品久久久久婷婷二区次| 欧美日本韩国一区二区三区| 亚洲 欧美 自拍偷拍| 成人私拍视频| 成人性生交大片免费看中文| 亚洲自拍偷拍区| 91国产免费视频| 毛片基地黄久久久久久天堂| 国产精品久久综合av爱欲tv| av手机天堂网| 蜜桃视频第一区免费观看| 国产精品777| 国产一级片一区二区| 日韩成人精品视频| 国产精品永久免费观看| 波多野结衣人妻| 日韩高清一区在线| 国产伦精品一区二区三区精品视频| 免费黄色一级大片| 久久www免费人成看片高清| 国产精品一二三在线| 亚洲一线在线观看| 国产高清亚洲一区| 国产欧美日本在线| 九色视频在线播放| 国产精品午夜久久| 最新中文字幕久久| 成全电影大全在线观看| 欧美日韩在线看| 天堂社区在线视频| 电影一区中文字幕| 精品国产一区二区三区不卡| 超碰97在线资源站| 国内黄色精品| 久久大大胆人体| 国产成人自拍视频在线| 日一区二区三区| 亚洲一区中文字幕在线观看| 日本人妻丰满熟妇久久久久久| 91美女在线视频| 亚洲欧洲日韩综合二区| 亚洲奶水xxxx哺乳期| 婷婷国产在线综合| 亚洲最大成人在线观看| 日韩成人18| 亚洲日本中文字幕免费在线不卡| 日韩福利小视频| 中文日韩欧美| 成人免费福利视频| 天天操天天干天天插| 中文字幕不卡的av| 国产freexxxx性播放麻豆| 伊人久久精品一区二区三区| 欧美女孩性生活视频| 香港三日本8a三级少妇三级99| 欧美精品一区二区久久| 欧美国产在线电影| 中文字幕 国产| 成人动漫av在线| 一级日韩一区在线观看| 国产在线精彩视频| 欧美高清性hdvideosex| 最新在线黄色网址| 91精品秘密在线观看| 日本伊人精品一区二区三区介绍 | 欧美激情二区| 欧美日韩国产综合新一区| 四虎成人在线播放| 成人午夜国产| 欧美在线视频网站| 免费观看a视频| 亚洲免费视频成人| 欧美伦理片在线观看| 色婷婷综合久久久久久| 久久99精品久久久久久噜噜 | 久久国产波多野结衣| 免费一区视频| 国产亚洲一区在线播放| 成人在线播放免费观看| 欧美系列日韩一区| 草草影院第一页| 一本色道久久精品| 成人综合av网| 国产极品在线视频| 在线观看网站免费入口在线观看国内| 欧美一区二区三区在线观看| 国产三级黄色片| 日韩精品国产欧美| 免费h精品视频在线播放| 丁香花在线电影| 精品盗摄一区二区三区| 黄视频网站免费看| 国产又粗又猛又爽又黄91精品| 亚洲精品9999| 91成人在线| 一区二区三区日韩在线| 亚洲精品国产无码| 国产性天天综合网| 黄色片在线免费| 精品日本12videosex| 国产精品69av| 91精品国产91久久久久游泳池| 91高清视频免费看| 在线视频第一页| 免费高清视频精品| 手机成人av在线| 国产高清日韩| 欧美日韩爱爱视频| 免费观看的毛片| 精品久久久久久久中文字幕| a视频免费观看| 老司机午夜精品视频| 日本一区二区在线视频观看| 精品视频在线一区二区在线| 中文字幕久热精品视频在线| 国产又粗又猛视频| 亚洲欧美日韩久久| 国产情侣久久久久aⅴ免费| 99精品视频免费| 日韩精品久久一区二区三区| 国产精品亚洲d| 久久精品国产2020观看福利| 国产黄色免费大片| 精品毛片三在线观看| 久久久久亚洲av无码专区桃色| 丝袜美腿亚洲色图| 99精品视频网站| 亚洲一区二区三区中文字幕在线观看 | 亚洲精品社区| 欧美深深色噜噜狠狠yyy| 日韩毛片一区| 欧美精品激情在线| 韩国免费在线视频| 在线不卡欧美精品一区二区三区| 免费在线观看av网址| 久久人人超碰精品| 中文字幕一区久久| 国产一区二区三区的电影| 新呦u视频一区二区| 中文字幕亚洲在线观看| 国产99久久精品一区二区 夜夜躁日日躁| 在线国产91| 亚洲黄色av女优在线观看| 五月激情丁香网| 亚洲精品成a人| 亚洲最大成人综合网| 国产剧情在线观看一区二区| 色欲av无码一区二区人妻| 国产精品国产三级国产在线观看| 国产精品久久久久久久免费大片 | 日韩视频在线观看免费视频| 国产麻豆成人精品| 成人在线看视频| 欧美日韩福利| 亚洲在线不卡| 性人久久久久| 成人动漫在线视频| 成人全视频免费观看在线看| 亚洲2020天天堂在线观看| 国产在线观看a| 亚洲深夜福利在线| 蜜臀av中文字幕| 欧美精品第1页| 中文精品久久久久人妻不卡| 亚洲制服丝袜一区| 一区二区三区影视| 国产亚洲成年网址在线观看| 又黄又爽的网站| 国产成人免费视| 九九热精品国产| 日本不卡一二三区黄网| 欧美激情 国产精品| 国产精品草草| mm131午夜| 小小影院久久| 在线视频欧美一区| 成人6969www免费视频| 欧美一区观看| 亚洲精品一级二级三级| 国产亚洲第一区| 亚洲天堂av资源在线观看| 91牛牛免费视频| 不卡一区视频| 国产日韩欧美黄色| 国产精品99久久久久久董美香 | 日韩欧美在线免费观看视频| 在线日韩中文| 青青草国产精品视频| 国产精品二区影院| 国产在线xxxx| 亚洲一级影院| 欧美在线一区视频| 亚洲每日更新| 国产极品在线视频| 国产亚洲精品v| 玩弄中年熟妇正在播放| 国产欧美日本| 国产精品99久久免费黑人人妻| 国产欧美三级| 精品久久久久久久免费人妻| 亚洲欧美bt| 国产综合免费视频| 视频一区二区三区中文字幕| 欧美日韩在线成人| 蜜桃av一区二区三区| 午夜宅男在线视频| 九九九久久久精品| 波多野结衣电影免费观看| 国产99久久久国产精品| 日本一卡二卡在线| 26uuu国产日韩综合| 69精品无码成人久久久久久| 国产日韩欧美精品电影三级在线| 国产成人免费观看网站| 国产精品国产三级国产aⅴ入口| 免费一级suv好看的国产网站| 中文字幕一区二区三区不卡 | 国产xxxxxxxxx| 久久久久88色偷偷免费| 国产一级淫片久久久片a级| 亚洲靠逼com| 国产精品第二十页| 一本色道a无线码一区v| 中文字幕视频二区| 日韩欧美一区在线| 视频在线观看你懂的| 中文字幕在线看视频国产欧美在线看完整 | 亚洲怡红院av| 日韩女优av电影| 四虎国产精品永远| 中文字幕在线精品| 黄色成人在线网| 国产成人精品电影久久久| 日韩电影精品| 国产伦精品一区二区三区免费视频 | 精品福利一二区| 国产尤物视频在线| 久久69精品久久久久久久电影好| 精精国产xxx在线视频app| 国产玖玖精品视频| 高清日韩欧美| 亚洲乱码一区二区三区| 在线观看视频免费一区二区三区| 91淫黄看大片| 成人av在线电影| 性色国产成人久久久精品| 亚洲国产视频一区二区| 国产精品传媒在线观看| 精品女同一区二区| 草碰在线视频| 97香蕉超级碰碰久久免费的优势| 精品美女一区| 日本a级片久久久| 尤物网精品视频| 成人黄色一级大片| 久久久美女艺术照精彩视频福利播放| 色欲人妻综合网| 91精品91久久久中77777| 亚洲欧美黄色片| 啊v视频在线一区二区三区| 樱花草涩涩www在线播放| 99re在线国产| 99热在线成人| 国产成人综合一区| aaa亚洲精品一二三区| 日本妇女毛茸茸| 在线不卡一区二区| h网站在线免费观看| 欧美亚洲国产成人精品| 亚洲三区欧美一区国产二区| 中文字幕欧美人与畜| 日韩av不卡在线观看| 亚洲精品中文字幕在线播放| 一二三四社区欧美黄| 国产影视一区二区| 日韩中文字幕免费看| 日韩三区在线| 欧美极品一区二区| 国产日韩一区二区三区在线| 香蕉视频免费网站| 亚洲欧美国产毛片在线| 中文字幕有码无码人妻av蜜桃| 亚洲精品中文字| 一个人www视频在线免费观看| 国产一区二区三区无遮挡| 午夜国产精品视频免费体验区| 天堂在线中文在线| 国产精品视频一区二区三区不卡| 国产嫩bbwbbw高潮| 亚洲美女视频网站| 亚洲天堂电影| 久久综合入口| 免费在线欧美黄色| 右手影院亚洲欧美| 色呦呦国产精品| 精品美女视频在线观看免费软件| 日韩av三级在线观看| 国产亚洲欧美日韩在线观看一区二区 | 精品久久久久99| 波多野结衣乳巨码无在线观看| 成人免费视频网站入口| 亚洲国产精品一区制服丝袜| 老司机免费视频| 欧美日韩亚洲视频一区| 免费毛片在线| 国产日产久久高清欧美一区| 91麻豆国产自产在线观看亚洲| 中文字幕亚洲欧洲| 亚洲色图视频网| 亚洲精品久久久久久久久久久久久久 | 男人的j进女人的j一区| 国产一区二区三区视频播放| 91精品国产高清一区二区三区| 污污的网站在线看| 精品无码久久久久久久动漫| 日韩精品一区第一页| 久久午夜精品视频| 欧美一区二区三级| xxx性欧美| 欧美一级二级三级| 久久99精品视频| 亚洲精品在线观看av| 亚洲欧美日韩高清| 日韩电影免费观看高清完整版在线观看| 日韩第一页在线观看| 成人精品视频一区二区三区 | 98色花堂精品视频在线观看| 欧美日韩精品久久| 精品亚洲免费视频| 日本特黄一级片| 中文字幕免费精品一区高清| 亚洲视频精选| 超碰影院在线观看| 伊人性伊人情综合网| 深夜福利在线看| 成人黄在线观看| 妖精视频成人观看www| 91视频免费看片| 亚洲国产第一页| www.久久| 欧美乱大交xxxxx潮喷l头像| 中文字幕欧美日韩一区| 亚洲乱码精品久久久久.. | 日本xxxxxxxxxx75| 中文字幕成人网| 香港三日本三级少妇66| 91精品啪在线观看麻豆免费| 一区二区国产精品| 欧美成人精品一区二区免费看片| 日韩毛片在线看| 视频一区中文字幕精品|