认识NS_REQUIRES_NIL_TERMINATION

本文详细介绍了NS_REQUIRES_NIL_TERMINATION宏在多参数传值中的作用,并通过具体的实例展示了如何使用该宏进行非nil结尾的检查。此外,还提供了一个自定义的实现案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

NS_REQUIRES_NIL_TERMINATION是系统中多参数传值的一个宏,用于编译时非nil结尾的检查。

找到了官网上的一个栗子:

#import <Cocoa/Cocoa.h>

@interface NSMutableArray (variadicMethodExample)

- (void) appendObjects:(id) firstObject, ...; // This method takes a nil-terminated list of objects.

@end

@implementation NSMutableArray (variadicMethodExample)

- (void) appendObjects:(id) firstObject, ...
{
id eachObject;
va_list argumentList;
if (firstObject) // The first argument isn't part of the varargs list,
  {                                   // so we'll handle it separately.
  [self addObject: firstObject];
  va_start(argumentList, firstObject); // Start scanning for arguments after firstObject.
  while (eachObject = va_arg(argumentList, id)) // As many times as we can get an argument of type "id"
      [self addObject: eachObject]; // that isn't nil, add it to self's contents.
  va_end(argumentList);
  }
}

@end

感觉还不错呦,自己也可以模仿着写一个的:

ZW_UIKit.h

#import <Foundation/Foundation.h>

@interface ZW_UIKit : NSObject

+ (NSArray *)getMoreArguments:(NSString *)strs,...NS_REQUIRES_NIL_TERMINATION;

@end

ZW_UIKit.m

#import "ZW_UIKit.h"

@implementation ZW_UIKit

#pragma mark - 获取多参数
+ (NSArray *)getMoreArguments:(NSString *)strs,...
{
    va_list args;
    va_start(args, strs);
    NSMutableArray *allArray = [NSMutableArray array];
    for (NSString *str = strs; str != nil; str = va_arg(args,NSString*)) {
        [allArray addObject:str];
    }
    va_end(args);
    return allArray.copy;
}


@end

调用:

[ZW_UIKit getMoreArguments:@"arg1",@"arg2",@"arg3", nil];
### 关于 PRIVATE_REQUIRES 和 PRIV_REQUIRES 的区别 在 CMake 中,`PRIVATE_REQUIRES` 并不是一个官方定义的关键字或属性,而 `PRIV_REQUIRES` 同样也不是标准的语法[^1]。然而,在某些自定义项目或者扩展工具链中,可能会存在类似的命名约定来描述依赖关系。 #### 官方支持的标准关键字 CMake 提供了一组标准化的目标作用域关键字用于管理目标间的依赖关系,这些关键字包括: - **PUBLIC**: 表示该依赖不仅会被当前目标使用,还会被链接到此目标的其他目标所继承。 - **PRIVATE**: 表明该依赖仅限于当前目标内部使用,不会传递给任何其他目标。 - **INTERFACE**: 意味着该依赖只会影响那些链接到当前目标的对象,但并不会影响当前目标本身的行为。 以上三个关键字通常应用于如下场景: ```cmake add_library(my_lib ...) target_link_libraries(my_lib PUBLIC other_lib) target_link_libraries(my_lib PRIVATE another_lib) target_link_libraries(my_lib INTERFACE yet_another_lib) ``` 如果遇到像 `PRIVATE_REQUIRES` 或者 `PRIV_REQUIRES` 这样的术语,则很可能是某个特定项目的定制化实现或者是文档中的笔误。为了进一步澄清它们的区别以及如何正确应用,请考虑以下几点: 1. 如果是在讨论第三方库(如 Boost.CMake)或者其他框架内的概念,“REQUIRES”可能用来表示一种特殊的依赖声明机制,而非传统意义上的链接操作; 2. 对于非正式名称的情况,具体含义需查阅对应项目的源码或说明文件以获得权威解释; 以下是假设性的例子展示两者可能的不同之处(注意这并非实际存在的功能): ```cmake set_target_properties(example PROPERTIES PRIVATE_REQUIRES some_dependency) # 假设这是私有需求设置方式之一 set_target_properties(another_example PROPERTIES PRIV_REQUIRES alternative_dependency) # 另一形式的设定, 若存在的话. ``` 尽管如此,建议始终优先采用官方推荐的方法来进行构建脚本编写,除非确实有必要遵循特殊项目的规定。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值