Python 面向對象進階

来源:https://www.cnblogs.com/chenyanbin/archive/2019/02/19/10403152.html
-Advertisement-
Play Games

sys模塊 1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 import sys 4 ''' 5 sys.argv : 在命令行參數是一個空列表,在其他中第一個列表元素程式本身的路徑 6 sys.exit(n) :退出程式,正常退出時exit(0 ...


 sys模塊

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 import sys
 4 '''
 5 sys.argv : 在命令行參數是一個空列表,在其他中第一個列表元素程式本身的路徑
 6 sys.exit(n) :退出程式,正常退出時exit(0)
 7 sys.version :獲取python解釋程式的版本信息
 8 sys.path :返回模塊的搜索路徑,初始化時使用 python PATH環境變數的值
 9 sys.platform :返回操作系統平臺的名稱
10 sys.stdin :輸入相關
11 sys.stdout :輸出相關
12 sys.stderror :錯誤相關
13 '''
14 print(sys.argv)  # ['H:/pythons3_/2019-02-17-面向對象進階/sys複習.py']
15 print(sys.version)  # 3.7.2 (tags/v3.7.2:9a3ffc0492, Dec 23 2018, 23:09:28) [MSC v.1916 64 bit (AMD64)]
16 print(sys.path)  # ['H:\\pythons3_\\2019-02-17-面向對象進階', 'H:\\pythons3_', 'D:\\Python\\insert3\\python37.zip', 'D:\\Python\\insert3\\DLLs', 'D:\\Python\\insert3\\lib', 'D:\\Python\\insert3', 'D:\\Python\\insert3\\lib\\site-packages', 'D:\\Python\\ide\\PyCharm 2018.2.4\\helpers\\pycharm_matplotlib_backend']
17 print(sys.platform)  # win32
import sys

os模塊

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 import os
 4 '''
 5 os.getcwd() :獲取當前工作目錄,即當前Python腳本工作的目錄路徑
 6 os.chdir('dirname') :改變當前腳本工作目錄;相當於shell下的cd
 7 os.curdir  :返回當前目錄:('.')
 8 os.pardir : 獲取當前目錄的父目錄字元串名('..')
 9 os.makedirs('dirname1/dirname2') :可生成多層遞歸目錄
10 os.removedirs('dirname1') :若目錄為空,則刪除,並遞歸到上一級目錄,如若也為空,則刪除
11 os.mkdir('dirname') :生成單級陌路;相當於shell中的mkdir dirname
12 os.rmdir('dirname') :刪除單級空目錄,若目錄不為空則無法刪除,報錯;相當於shell中rmdir dirname
13 os.listdir('dirname') :列出指定目錄下的所有文件和子目錄,包括隱藏目錄,並以列表方式列印
14 os.remove() :刪除一個文件
15 os.rename('oldname', 'newname') :重命名文件/目錄
16 os.stat('path/filename') :獲取文件/目錄信息
17 os.sep :輸出當前平臺使用的行終止符,win下為“\\”,Linux下為“/”
18 os.linesep :輸出當前平臺使用的行終止符,win下為“\t\n”,Linux下為“\n”
19 os.pathsep :輸出用於分割文件路徑的字元串win下為“;”,Linux下為“:”
20 os.name :輸出字元串指示當前使用平臺。win->“nt”,Linux->“posix”
21 os.system('bash command') :運行shell命令,直接顯示
22 os.environ :獲取系統環境變數
23 os.path.abspath(path) :返回path規範化的絕對路徑
24 os.path.split(path) :將path分割成目錄和文件名二元組返回
25 os.path.dirname(path) :返回path的目錄,其實就是os.path.split(path)的第一個元素
26 os.path.basename(path) :返回path最後的文件木
27 '''
28 # print(os.getcwd())  # H:\pythons3_\2019-02-17-面向對象進階
29 # os.chdir(r'C:\\')  # 前面小r 轉義的意思,將一個“\”轉換為“\\”
30 # print(os.getcwd())  # C:\
31 # os.makedirs(r'aa\bb\cc')  # 生成多層遞歸目錄
32 # os.removedirs(r'aa\bb\cc')  # 遞歸刪除目錄
33 # print(os.listdir(os.getcwd()))  # 列出指定目錄下的所有文件和子目錄;['os複習.py', 'sys複習.py']
34 # print(os.stat('os複習.py'))  # os.stat_result(st_mode=33206, st_ino=3096224743817390, st_dev=245858372, st_nlink=1, st_uid=0, st_gid=0, st_size=1816, st_atime=1550417104, st_mtime=1550417104, st_ctime=1550417104)
35 # print(os.stat(r'C:\Users\Administrator\Desktop\ASCII表.jpg').st_size)  # 獲取文件/圖片大小信息;376278
36 # print(os.environ)  # environ({'ALLUSERSPROFILE': 'C:\\ProgramData', 'APPDATA': 'C:\\Users\\Administrator\\AppData\\Roaming', 'ASL.LOG': 'Destination=file', 'COMMONPROGRAMFILES': 'C:\\Program Files\\Common Files', 'COMMONPROGRAMFILES(X86)': 'C:\\Program Files (x86)\\Common Files', 'COMMONPROGRAMW6432': 'C:\\Program Files\\Common Files', 'COMPUTERNAME': 'MAC', 'COMSPEC': 'C:\\Windows\\system32\\cmd.exe', 'FPS_BROWSER_APP_PROFILE_STRING': 'Internet Explorer', 'FPS_BROWSER_USER_PROFILE_STRING': 'Default', 'HOMEDRIVE': 'C:', 'HOMEPATH': '\\Users\\Administrator', 'LOCALAPPDATA': 'C:\\Users\\Administrator\\AppData\\Local', 'LOGONSERVER': '\\\\MAC', 'NUMBER_OF_PROCESSORS': '8', 'OS': 'Windows_NT', 'PATH': 'D:\\Python\\安裝\\;D:\\Python\\安裝\\Scripts;C:\\Windows\\system32;C:\\Windows;C:\\Windows\\System32\\Wbem;C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\;E:\\sql2008 x86共用\\100\\Tools\\Binn\\;E;\\sql2008共用\\100\\Tools\\Binn\\;E;\\sql2008共用\\100\\DTS\\Binn\\;E;\\sql2008 x86共用\\100\\Tools\\Binn\\VSShell\\Common7\\IDE\\;C;\\Program Files (x86)\\Microsoft Visual Studio 9.0\\Common7\\IDE\\PrivateAssemblies\\;E:\\sql2008 x86共用\\100\\DTS\\Binn\\;%;SERPROFILE%\\.dnx\\bin;C:\\Program Files\\Microsoft DNX\\Dnvm\\;C:\\Program Files\\Microsoft SQL Server\\130\\Tools\\Binn\\;C:\\Program Files\\Microsoft SQL Server\\120\\Tools\\Binn\\;C:\\Program Files (x86)\\nodejs\\;C:\\Program Files\\Git\\cmd;C:\\Program Files (x86)\\Windows Kits\\10\\Windows Performance Toolkit\\;E:\\sql2008 x86共用\\90\\Tools\\binn\\;C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Launcher\\;C:\\Users\\Administrator\\AppData\\Roaming\\npm;D:\\Python\\insert;D:\\Python\\insert3', 'PATHEXT': '.COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH;.MSC', 'PROCESSOR_ARCHITECTURE': 'AMD64', 'PROCESSOR_IDENTIFIER': 'Intel64 Family 6 Model 142 Stepping 10, GenuineIntel', 'PROCESSOR_LEVEL': '6', 'PROCESSOR_REVISION': '8e0a', 'PROGRAMDATA': 'C:\\ProgramData', 'PROGRAMFILES': 'C:\\Program Files', 'PROGRAMFILES(X86)': 'C:\\Program Files (x86)', 'PROGRAMW6432': 'C:\\Program Files', 'PSMODULEPATH': 'C:\\Windows\\system32\\WindowsPowerShell\\v1.0\\Modules\\', 'PUBLIC': 'C:\\Users\\Public', 'PYCHARM_HOSTED': '1', 'PYCHARM_MATPLOTLIB_PORT': '35491', 'PYTHONIOENCODING': 'UTF-8', 'PYTHONPATH': 'D:\\Python\\ide\\PyCharm 2018.2.4\\helpers\\pycharm_matplotlib_backend;H:\\pythons3_', 'PYTHONUNBUFFERED': '1', 'SESSIONNAME': 'Console', 'SYSTEMDRIVE': 'C:', 'SYSTEMROOT': 'C:\\Windows', 'TEMP': 'C:\\Users\\ADMINI~1\\AppData\\Local\\Temp', 'TMP': 'C:\\Users\\ADMINI~1\\AppData\\Local\\Temp', 'USERDOMAIN': 'MAC', 'USERDOMAIN_ROAMINGPROFILE': 'MAC', 'USERNAME': 'Administrator', 'USERPROFILE': 'C:\\Users\\Administrator', 'VS100COMNTOOLS': 'e:\\vs2010 64位\\安裝\\Common7\\Tools\\', 'VS110COMNTOOLS': 'C:\\Program Files (x86)\\Microsoft Visual Studio 11.0\\Common7\\Tools\\', 'VS120COMNTOOLS': 'C:\\Program Files (x86)\\Microsoft Visual Studio 12.0\\Common7\\Tools\\', 'VS140COMNTOOLS': 'E:\\C#安裝2015\\Common7\\Tools\\', 'VS90COMNTOOLS': 'E:\\vs 2008 c語言\\安裝\\Common7\\Tools\\', 'VSSDK140INSTALL': 'E:\\C#安裝2015\\VSSDK\\', 'WINDIR': 'C:\\Windows'})
37 # os.system('dir')
38 # print(__file__)  # 當前文件所在的文件名;H:/pythons3_/2019-02-17-面向對象進階/os複習.py
39 # print(os.path.abspath(__file__))
40 # print(os.path.split(__file__))  # ('H:/pythons3_/2019-02-17-面向對象進階', 'os複習.py')
import os

 isinstance(obj,cls):檢查obj是否是類cls的對象,返回布爾值:True/False

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 
 4 
 5 class Foo:
 6     pass
 7 
 8 
 9 class FooTest:
10     pass
11 
12 
13 obj = Foo()
14 print(isinstance(obj, Foo))  # True
15 print(isinstance(obj, FooTest))  # False
isinstance(obj,cls)

issubclass(sub,super):檢查sub類是否是super類的派生類,返回布爾值:True/False

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 
 4 
 5 class Foo:
 6     pass
 7 
 8 
 9 class Bar(Foo):
10     pass
11 
12 
13 print(issubclass(Bar, Foo))  # True
14 print(issubclass(Foo, Bar))  # False
issubclass(sub,super)

 __setitem__,__getitem__,__delitem__

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 
 4 
 5 class Foo:
 6     def __getitem__(self, item):
 7         print('getitem')
 8         return self.__dict__[item]
 9 
10     def __setitem__(self, key, value):
11         print('setitem')
12         self.__dict__[key] = value
13 
14     def __delitem__(self, key):
15         print('delitem')
16         self.__dict__.pop(key)
17 
18 
19 
20 f1 = Foo()
21 # print(f1.__dict__)  # {}
22 f1.name = 'alex'
23 f1['age'] = 16  # setitem
24 f1['name']  # getitem
25 del f1['name']  # delitem
26 print(f1.__dict__)  # {'name': 'alex', 'age': 16}
item系列

str和repr

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 
 4 
 5 class Foo:
 6     def __str__(self):
 7         return '自定製的對象的顯示方式'
 8 
 9 
10 f1 = Foo()
11 print(f1)  # 自定製的對象的顯示方式
12 
13 
14 class Foo2:
15     def __init__(self, name, age):
16         self.name = name
17         self.age = age
18 
19     def __str__(self):
20         return '姓名:%s,年齡:%s' % (self.name, self.age)
21 
22 
23 f2 = Foo2('alex', 15)
24 print(f2)  # 姓名:alex,年齡:15
25 
26 
27 # repr 在解釋器中有用
28 class Foo3:
29     def __init__(self, name, age):
30         self.name = name
31         self.age = age
32 
33     def __repr__(self):
34         return '姓名:%s,年齡:%s' % (self.name, self.age)
str和repr

 format

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 
 4 x = '{0}{0}{0}'.format('alex')
 5 print(x)  # alexalexalex
 6 
 7 
 8 class Date:
 9     def __init__(self, year, month, day):
10         self.year = year
11         self.month = month
12         self.day = day
13 
14 
15 d1 = Date(2019, 2, 18)
16 y = '{0.year}{0.month}{0.day}'.format(d1)
17 print(y)  # 2019218
18 
19 
20 format_dic = {
21     'y:m:d': '{0.year}:{0.month}:{0.day}',
22     'm-d-y': '{0.month}-{0.day}-{0.year}'
23 }
24 
25 
26 class Date2:
27     def __init__(self, year, month, day):
28         self.year = year
29         self.month = month
30         self.day = day
31 
32     def __format__(self, format_spec):
33         if not format_spec:
34             format_spec = 'y-m-d'
35         fmt = format_dic[format_spec]
36         return fmt.format(self)
37 
38 
39 d2 = Date2(2019, 2, 18)
40 print(format(d2, 'y:m:d'))  # 2019:2:18
format

 __slots__

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 '''
 4 1.__slots__:是一個類變數,變數值可以是列表,元祖,或者可迭代對象,也可以是字元串(滋味著所有勢力只有數據屬性)
 5 2.使用“.”來訪問屬性本質上就是訪問類或者對象的__dict__屬性字典(類的字典是共用的,而每個實例是獨立的)
 6 3.為何使用 __slots__:字典會占用大量記憶體,如果你有一個屬性很少的類。但是有很多實例,為了節省記憶體可以使用__slots__取代實例的__dict__
 7 當你定義__slots__後,__slots__就會為實例使用一種更加緊湊的內部表示,實例通過一個很小的固定大小的數組來構建,而不是為每個勢力定義一個
 8 字典,這跟元組或列表很類似。在__slots__中列出的屬性名在內部被映射到這個數組的指定小標上,使用__slots__一個不好的地方就是我們不能再給實例添加新的屬性了,
 9 只能使用__slots__中定義的那些屬性名。
10 4.註意事項:__slots__的很多特性都依賴於普通的基於字典的實現。另外,定義了__slots__後的類不在支持一些普通類特性了。比如繼承。
11 大多數情況下,你應該只在那些經常被使用到的用作數據結構的類上定義__slots__比如在程式中需要創建某個類的幾百萬個實例對象。
12 關於__slots__的一個常見誤區是:它可以作為一個封裝工具來防止用戶給實例添加新的屬性。儘管使用__slots__可以達到這樣的目的,但是這個並不是初衷。---->更多的是用來作為一個記憶體優化工具。
13 '''
14 class Foo:
15     # __slots__ = ['name', 'age']  # <==>{'name':None,'age':None}
16     __slots__ = 'name'
17 
18 
19 f1 = Foo()
20 f1.name = 'alex'
21 print(f1.name)
22 # print(f1.__dict__)  # 報錯。因為__slots__定義後取代了__dict__
23 print('---->', f1.__slots__)  # ----> name
24 # f1.age = 18  #  報錯
__slots__

__doc__

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 
 4 # __doc__:文檔註釋
 5 class Foo:
 6     '我是描述信息'
 7     pass
 8 
 9 
10 print(Foo.__doc__)  # 我是描述信息
__doc__
 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 
 4 
 5 # __doc__:文檔註釋
 6 class Foo:
 7     '我是描述信息'
 8     pass
 9 
10 
11 class Bar(Foo):
12     pass
13 
14 
15 print(Bar.__doc__)  # None,不能被繼承文檔註釋
__doc__不能被繼承

 __del__

  析構方法,當對象在記憶體中被 釋放時,自動觸發執行。

:此方法一般無須定義,因為Python是一個高級語言。程式員在使用時無需關心記憶體的分配和釋放,因為此工作都是交給Python解釋器來執行,所以,析構函數的調用時由解釋器在進行垃圾回收時自動觸發執行的。

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 
 4 
 5 class Foo:
 6     def __init__(self, name):
 7         self.name = name
 8 
 9     def __del__(self):
10         print('析構函數已經執行')
11 
12 
13 f1 = Foo('alex')
14 del f1
15 print('----->')
16 '''
17 執行結果如下:
18 析構函數已經執行
19 ----->
20 '''
__del__

__call__

對象後面加括弧,觸發執行。

:構造方法的執行是由創建對象觸發的,即:對象=類();而對於__call__方法的執行是由對象後加括弧觸發的,即:對象()或者類()

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 
 4 
 5 class Foo:
 6     def __call__(self, *args, **kwargs):
 7         print('實例執行了')
 8 
 9 
10 f1 = Foo()
11 f1()  # 實例執行了;調用了Foo下的__call__
__call__

 描述符應用,限制用戶輸入數據類型

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 
 4 
 5 class Typed:
 6     def __init__(self, key):
 7         self.key = key
 8 
 9     def __get__(self, instance, owner):
10         return instance.__dict__[self.key]
11 
12     def __set__(self, instance, value):
13         # if not type(value) is str:
14         if not isinstance(value, str):
15             # print('你輸入數據類型不是str')
16             # return
17             raise TypeError('你輸入數據類型不是str')
18         instance.__dict__[self.key] = value
19 
20     def __delete__(self, instance):
21         instance.__dict__.pop(self.key)
22 
23 
24 class People:
25     name = Typed('name')
26 
27     def __init__(self, name, age):
28         self.name = name
29         self.age = age
30 
31 
32 p1 = People(11, 15)  # 報錯;你輸入數據類型不是str
33 print(p1.__dict__)  # {'age': 15}
34 p2 = People('alex', 16)
35 print(p1.__dict__)  # {'age': 15}

 


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

-Advertisement-
Play Games
更多相關文章
  • [TOC] 今天正月十五,可憐的我還在這裡碼字,首先祝大家“猿宵節”快樂!距離我發佈的 "spring cloud初級教程" 已經有段時間了,這段時間經歷了一個春節,加上年後我又有了點事情要做,所以我在初級教程中預告的spring cloud手腳架項目估計要食言了。不過今天冒個泡,就是讓大家知道,事 ...
  • 情景引入 很早之前,Java就火起來了,是因為它善於開發和處理網路方面的應用。 Java有一個愛好,就是喜歡制定規範標準,但自己又不善於去實現。 反倒是一些服務提供商使用它的規範標準來製造應用伺服器而賺的盆滿缽滿。 企業用戶因要使用這些應用伺服器而向提供商支付高額費用,而且也不是特別好用。 一個青年 ...
  • 1.在windows下打包 微服務應用通過maven進行打包,在項目的pom.xml執行mvn clean package,或者直接通過idea或者eclipse進行maven打包 之上操作將在項目的 target目錄生成文件microservice-discovery-eureka-0.0.1-S ...
  • 最近我們的項目在考慮使用Gateway,考慮使用Spring Cloud Gateway,發現網關的異常處理和spring boot 單體應用異常處理還是有很大區別的。讓我們來回顧一下異常。 ...
  • Semaphore用於管理信號量,在併發編程中,可以控制返訪問同步代碼的線程數量。Semaphore在實例化時傳入一個int值,也就是指明信號數量。主要方法有兩個:acquire()和release()。acquire()用於請求信號,每調用一次,信號量便少一個。release()用於釋放信號,調用 ...
  • 最近在學樹剖,看到了這題就做了 [ZJOI2008]樹的統計 思路 從題面可以知道,這題是樹剖題(要求的和模板沒什麼區別呀喂 就是在普通的樹剖上加了一個最大值 所以可以知道就是樹剖+特殊的線段樹 線段樹要可以求區間最大值和區間和 那麼就很好做了,基本上就是到樹剖模板題 只需要給線段樹加個最大值就行了 ...
  • 對於經常調用的函數,特別是遞歸函數或計算密集的函數,記憶(緩存)返回值可以顯著提高性能。 ...
  • 前言 由於Activiti 預設使用的資料庫是H2資料庫,重啟服務後相關數據會丟失。為了永久保存,所以要配置關係型資料庫,這裡我們選擇 SqlServer ,有錢任性。 環境 Activiti6,SqlServer 2008 配置 文件 修改 然後,引入 lib下引入 sqljdbc4 4.0.ja ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...