__nullable 消除


警告;Pointer is missing a nullability type specifier.....

我觉得我是一个强迫症,写完代码都会去去掉所有的警告,,,(有的我也去不掉好闹心)今天介绍一个警告的去掉方法。

例子:

刚刚遇见这个警告的时候脑子有点蒙,这是为什么呢,,我觉得写法没什么问题的说,

后来经过多番查找,发现这是Xcode 6.3的一个新特性,即nullability annotations

我们都知道在swift中,可以使用!和?来表示一个对象是optional的还是non-optional,如view?和view!。而在Objective-C中则没有这一区分,view即可表示这个对象是optional,也可表示是non-optioanl。这样就会造成一个问题:在Swift与Objective-C混编时,Swift编译器并不知道一个Objective-C对象到底是optional还是non-optional,因此这种情况下编译器会隐式地将Objective-C的对象当成是non-optional。

为了解决这个问题,苹果在Xcode 6.3引入了一个Objective-C的新特性:nullability annotations。这一新特性的核心是两个新的类型注释:__nullable__nonnull。从字面上我们可以猜到,__nullable表示对象可以是NULL或nil,而__nonnull表示对象不应该为空。当我们不遵循这一规则时,编译器就会给出警告。

解决方法:可以使用const关键字的地方都可以使用__nullable和__nonnull,不过这两个关键字仅限于使用在指针类型上。而在方法的声明中,我们还可以使用不带下划线的nullable和nonnull,

继续扩展:当我们有很多属性或者方法都要加nonnull属性时这就变成了一个麻烦的事,没关系苹果还是很人性化的他给了我们两个宏定义来解决这样的情况。开始:NS_ASSUME_NONNULL_BEGIN  结束:NS_ASSUME_NONNULL_END  这两个要配合使用,在其区间的属性都会获得nonnull属性,下面是截图:



在这条ClickHouse DDL语句,有几个问题需要修复: 1. 缺少表名后的括号:在`CREATE TABLE`语句,应该在表名后添加括号来定义表的列和其他属性。 2. 缺少`ENGINE`选项:需要指定表的存储引擎。 3. `PRIMARY KEY`后面应该跟括号,指定主键列。 4. `ORDER BY`子句应该指定用于排序的列。 下面是修正后的DDL语句: ``` CREATE TABLE `ODS`.`ods_tb_ring_report_value` on cluster ransgu_v2 ( `tbm_id` Int64 COMMENT '盾构机ID', `tunnel_code` String COMMENT '区间隧道编号', `ring_number` Int64 COMMENT '环号', `para_detail_id` Int64 COMMENT '环报参数值ID', `para_id` Nullable(Int64) COMMENT '环报参数ID', `ring_data_class` Nullable(String) COMMENT '环报数据分类(通用:ring_data_class)', `para_vaule` Nullable(String) COMMENT '环报参数值', `alarm_rule_detail_id` Nullable(Int64) COMMENT '预警规则详细ID', `delete_flag` Int8 COMMENT '删除标志', `update_count` Int64 COMMENT '更新次数', `create_user` Nullable(String) COMMENT '创建人', `create_date` Nullable(DateTime) DEFAULT now() COMMENT '创建时间', `update_user` Nullable(String) COMMENT '更新人', `update_date` Nullable(DateTime) COMMENT '更新时间', `uuid` String COMMENT 'uuid(),唯一标识' ) ENGINE = ReplicatedReplacingMergeTree('/clickhouse/tables/{shard}/ODS/ods_tb_ring_report_value', '{replica}') PRIMARY KEY (`tbm_id`) ORDER BY (`tbm_id`) SETTINGS index_granularity = 8192, storage_policy = 'default'; ``` 注意,我还添加了`ENGINE`选项,并使用了适当的主键和排序列来定义表的结构。根据您的具体需求,您可能需要更改存储引擎和其他设置来优化表的性能和可伸缩性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值