您好,登錄后才能下訂單哦!
本篇內容主要講解“C++中為什么不要定義C風格的可變參數函數”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“C++中為什么不要定義C風格的可變參數函數”吧!
ES.34:不要定義C風格的可變參數函數
Not type safe. Requires messy cast-and-macro-laden code to get working right.
這種方式不是類型安全的。需要繁雜的類型轉換和宏裝載代碼來保證正確動作。
Example(示例)
#include <cstdarg>
// "severity" followed by a zero-terminated list of char*s; write the C-style strings to cerr
void error(int severity ...)
{
va_list ap; // a magic type for holding arguments
va_start(ap, severity); // arg startup: "severity" is the first argument of error()
for (;;) {
// treat the next var as a char*; no checking: a cast in disguise
char* p = va_arg(ap, char*);
if (!p) break;
cerr << p << ' ';
}
va_end(ap); // arg cleanup (don't forget this)
cerr << '\n';
if (severity) exit(severity);
}
void use()
{
error(7, "this", "is", "an", "error", nullptr);
error(7); // crash
error(7, "this", "is", "an", "error"); // crash
const char* is = "is";
string an = "an";
error(7, "this", "is", an, "error"); // crash
}
Alternative: Overloading. Templates. Variadic templates.
可選項:重載,模板,可變參數模板。
#include <iostream>
void error(int severity)
{
std::cerr << '\n';
std::exit(severity);
}
template <typename T, typename... Ts>
constexpr void error(int severity, T head, Ts... tail)
{
std::cerr << head;
error(severity, tail...);
}
void use()
{
error(7); // No crash!
error(5, "this", "is", "not", "an", "error"); // No crash!
std::string an = "an";
error(7, "this", "is", "not", an, "error"); // No crash!
error(5, "oh", "no", nullptr); // Compile error! No need for nullptr.
}
This is basically the way printf is implemented.
這是實現printf的基本方法。
Enforcement(實施建議)
Flag definitions of C-style variadic functions.
標記定義了C風格可變參數函數的情況。
Flag #include <cstdarg> and #include <stdarg.h>
標記代碼中包含#include <cstdarg> 和 #include <stdarg.h>的情況。
到此,相信大家對“C++中為什么不要定義C風格的可變參數函數”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。