分享方式:


內建函式

SAL 中的運算式可以是 C/C++ 運算式 (假設該運算式沒有副作用的話),例如 ++、-- 和函式呼叫在這個內容中全都有副作用。 不過,SAL 確實提供一些類似函式的物件,以及可用於 SAL 運算式的一些保留符號。 這些稱為內建函式

一般用途

下列內建函式註釋提供 SAL 的一般公用程式。

註釋 描述
_Curr_ 目前標註之物件的同義字。 正在使用 _At_ 註釋時,_Curr__At_ 的第一個參數相同。 否則,它會是與註釋在語彙上相關聯的參數或整個函式/傳回值。
_Inexpressible_(expr) 表示緩衝區的大小太複雜而無法使用註釋運算式表示的情況,例如,透過掃描輸入資料集,然後計算所選取成員的方式計算。
_Nullterm_length_(param) param是緩衝區中的元素數量,最多但不包括 Null 終端子。 它可以套用至任何非彙總、非 void 類型的緩衝區。
_Old_(expr) 在前置條件下進行評估時,_Old_ 會傳回輸入值 expr。 在後置條件下進行評估時,它會傳回值 expr,因為它已在前置條件下進行評估。
_Param_(n) 函式的第 n 個參數,從 1 到 n 計算,而 n 是常值整數常數。 如果參數已命名,這個註釋會與依名稱存取參數相同。 注意: n 可能會參考省略符號所定義的位置參數,或是在不使用名稱的函式原型中使用。
return C/C++ 保留關鍵字 return 可用於 SAL 運算式,以指出函式的傳回值。 值只能在後置狀態下使用,因此在前置狀態下使用就是語法錯誤。

字串特定

下列內建函式註釋可讓您操作字串。 這四種函式的目的都相同:傳回 null 結束字元之前所找到類型的項目數。 差異在於項目中參考的資料類型。 請注意,如果您要指定不是以字元組成之以 null 終止的緩衝區長度,請使用前一節中的 _Nullterm_length_(param) 註釋。

註釋 描述
_String_length_(param) param是字串中的元素數量,最多但不包括 Null 終端子。 此註釋會保留給 string-of-character 類型。
strlen(param) param是字串中的元素數量,最多但不包括 Null 終端子。 這個註釋會保留供字元陣列使用,而且類似 C 執行階段函式 strlen()
wcslen(param) param是字串中的元素數量,最多但不包括 Null 終端子。 這個註釋會保留供寬字元陣列使用,而且類似 C 執行階段函式 wcslen()

另請參閱