前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何正确使用const(常量),define(宏)

如何正确使用const(常量),define(宏)

作者头像
Scott_Mr
发布2018-07-05 15:21:42
8570
发布2018-07-05 15:21:42
举报

前言

在开发中,也许我们会经常使用到宏定义,或者用const修饰一些数据类型,经常有开发者不知道怎么正确使用,导致项目中乱用宏定义与const修饰符。本篇主要介绍在开发中怎么正确使用constdefine(宏定义)

当我们想定义全局共用的一些数据时,比如通知名字,动画时长等等,我们可以用常量变量

  • 宏: // 注意后面不需要带符号 #define ScottDidLoginSuccess @"登陆成功"
  • 变量: // 注意后面一定要带符号 NSString *scottDidLoginSuccess = @"登陆成功";
  • 常量: // 四种写法 static const NSString *scottDidLoginSuccess = @"登陆成功"; const NSString *scottDidLoginSuccess = @"登陆成功"; NSString const *scottDidLoginSuccess = @"登陆成功"; NSString *const scottDidLoginSuccess = @"登陆成功";

那么问题来了,我们到底该如何选择呢? 让我来先将一下我对它们之间的理解吧:

  • 宏:只是在预处理阶段进行文本替换,没有类型,不做任何类型检查,编译器可以对相同的字符串进行优化,只保存一份到数据段。甚至有相同后缀的字符串也可以优化,你可以使用GCC编译测试,Hello worldworld两个字符串,只存储前面一个。取的时候只需要给前面和中间的地址,如果是整型、浮点型会有多分拷贝,但这些数写在指令中,占的只是代码片段而且,大量使用宏会导致二进制文件变大。
  • 变量:共享一块内存空间,就算项目中N处用到,也不会分配N块内存空间,可以被修改,在编译阶段做类型检查。
  • 常量:共享一块内存空间,就算项目中N处用到,也不会分配N块内存空间,可以根据const修饰的位置设定能够修改,在编译阶段做类型检查。

常量区分

  • 全局常量:不管你定义在任何文件夹,外部都能访问 const NSString *scottDidLoginSuccess = @"登陆成功";
  • 局部常量:用static修饰后,不能供外界访问 static const NSString *scottDidLoginSuccess = @"登陆成功";

const修饰位置不同,代表什么

代码语言:javascript
复制
    // 1.
    const NSString *scottDidLoginSuccess = @"登陆成功";
    // 2.
    NSString const *scottDidLoginSuccess = @"登陆成功";
    // 3.
    NSString * const scottDidLoginSuccess = @"登陆成功";

咋一看,WTF,这不都张一样嘛,其实不一样,下面解释一下各代表什么

  1. *scottDidLoginSuccess不能被修改,scottDidLoginSuccess能被修改
  2. *scottDidLoginSuccess不能被修改,scottDidLoginSuccess能被修改,也就是和第一种情况是一样的
  3. scottDidLoginSuccess不能被修改,*scottDidLoginSuccess能被修改。

结论:const右边的总不能被修改

所以我们一般定义一个常量又不想被修改,应该这样定义: NSString *const scottDidLoginSuccess = @"登陆成功";

两者之间的区别

  • define在预处理阶段进行替换,const常量在编译阶段使用;
  • define不做类型检查,只进行替换,const常量有数据类型,会执行类型检查;
  • define不能调试,const常量可以调试;
  • define定义的常量在替换后运行过程中,会不断占用内存,而const定义的常量存储在数据段,只有一份拷贝,效率更高;
  • define可以定义函数,const不可以。
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-04-25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 常量区分
  • const修饰位置不同,代表什么
  • 两者之间的区别
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档