iOS va_list可变参数使用

使用NS_REQUIRES_NIL_TERMINATION宏
本文介绍了一个Objective-C宏NS_REQUIRES_NIL_TERMINATION的使用方法,并通过一个可变参数函数的实例展示了如何处理带nil终止符的参数列表。


// NS_REQUIRES_NIL_TERMINATION, 自动加上nil
+ (instancetype)itemIdentiferWithIden:(id)identifier, ... NS_REQUIRES_NIL_TERMINATION;


va_list args;
va_start(args, identifier);
while (TRUE)
{
    id obj = va_arg(args, id);
    if (nil == obj)
    {
        break;
    }
  
    // handle ...
}

va_end(args);




// 增强的日志输出函数 宽字符版本 void OutputLogW(const wchar_t* format, ...) { // 获取当前时间 auto now = std::chrono::system_clock::now(); auto now_time = std::chrono::system_clock::to_time_t(now); auto now_ms = std::chrono::duration_cast<std::chrono::milliseconds>(now.time_since_epoch()) % 1000; // 格式化时间 std::wstringstream time_ss; time_ss << std::put_time(std::localtime(&now_time), L"%Y-%m-%d %H:%M:%S") << L"." << std::setfill(L'0') << std::setw(3) << now_ms.count(); // 提取文件名(不含路径) // std::wstring filename(file); // size_t pos = filename.find_last_of(L"\\/"); // if (pos != std::wstring::npos) { // filename = filename.substr(pos + 1); // } // 处理变参数 va_list args; va_start(args, format); // 获取变参长度 int len = _vscwprintf(format, args) + 1; // +1 for '\0' if (len <= 0) { va_end(args); return; } // 分配缓冲区 std::wstring buffer; buffer.resize(len); vswprintf_s(&buffer[0], len, format, args); buffer.resize(len - 1); // 移除末尾的null va_end(args); // 构建完整日志消息 std::wstringstream fullMsg; fullMsg << L"[" << time_ss.str() << L"] " << L"[" << file << L":" << line << L"] " << L"[" << function << L"] " << buffer; // 输出到控制台 std::wcerr << fullMsg.str() << std::endl; // 输出到调试器(Windows) #ifdef _WIN32 OutputDebugStringW(fullMsg.str().c_str()); OutputDebugStringW(L"\n"); #endif }完善为日志宏定义为准 #define LOGW(...) OutputLogW(L"[%s:%s:%d] %s",__FILE__, __FUNCTION__, __LINE__, __VA_ARGS__)
最新发布
08-10
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值