Swift:如何优雅地使用 print()(一)

作者:Andyy Hope,原文链接,原文日期:2016-04-06
译者:Darren;校对:pucca601;定稿:CMB

如果说 Log 是一种时尚,那你就是时尚设计师。

Swift beta 版一出世,社区中最具好奇心的开发者们立刻上了这班车,对新版语言的特性进行试验,并撰文讨论他们从中获取的经验。
关于 Swift, 有太多提到 Tailor Swift 的 Twitter 了以至于我没办法列举出最好的, 但直到现在这也很有趣,没有人知道为什么😂。另一个人们讨论得很多的话题是 Swift 代码中可以使用 emoji 表情了。

func combinedWeatherConditions(lhs: Int, _ rhs: Int) -> Int {
    return lhs + rhs
}
let 🌨 = -10, 🌤 = 10, 💧 = 0
if combinedWeatherConditions(🌨, 🌤) == 💧 {
    print(“😔 — No 🏂 Today.”)
}

我纯粹是因为表情功能而开始写 Swift 的。—— 没有人这样说

这是一个非常新颖的特性,尽管你也许永远不会需要在你的代码里使用 emoji 或者用在打印语句中。但是既然我们讲到了打印语句,在新的控制台上 print 语句相比古老的前身 NSLog 已经被优雅地简化了。

NSLog

作为初学者调试的主力,NSLog 用起来相当简单,常作为在运行时检测变量值和通知开发者事件的合适工具。你可以随心所欲地打印所需消息或者对象。但在我看来,默认的 NSLog 消息包含了大量的垃圾:

2016–04–02 09:15:25.660 Blog_Print[13053:3567169] Hello, cruel world. Why don’t you love me? Whyyy!!!

不要误会,我敢肯定创造 NSLog 的工程师在设计一个好的日志上的花了很大的心思。让我们把它拆开来看看:

[日期戳] [时间戳] [工程名] [进程 ID: 线程 ID] [消息]

但是,的确,这种体量的日志相比于我们所需的信息显得有些过剩了。日期/时间戳、进程/线程ID组合标签占用了大量空间,尤其是当你的控制台窗口在 Xcode 窗口的底部中间偏右时,因为空间本来就不大,再打印这么冗长的信息就显得太小了。

print

没必要从 NSLog简化,print从原始信息中去掉了冗余的信息。

Hello, beautiful world! I love you.

但是也许,只是也许,我觉得有时它的确有点太简化了…我知道你现在会怎么想我,😝但请不要介意。

『这家伙一会抱怨 NSLog 太多, 一会又抱怨 print 太少?真难伺候。』—— 你

就像衣服,你根据不同的场合有不同用途穿不同的服装。你不会在雪地里穿短裤和背心,对吧?
print 也是如此,有时你需要打印日期,或者打印 API 调用,而有时你会希望你的 log 在其他多余信息中突出,相信我,你会希望你的 log 突出的。这就是我们所要讨论的时尚。
如果你在项目中使用过第三方库,你可能会注意到你的控制台充满了垃圾,各种垃圾,就像让 Wall-e(译者注:《机器人总动员》中的机器人瓦力)郁闷的那些垃圾一样。没错,说的就是你,Urban Airship。

多多益善的表情

就像我刚提到的,使用表情符号是一个新特性,但它实际上相当有用。当你通过控制台的分析打印语句时,打印语句中的表情符号减少了你的认知负荷其实是提高了调试的效率。

Pro tip:
在 OSX 系统中,在任意文本框中点击 Ctrl + Cmd + Space 将会打开一个 emoji 弹出框。

Strings

let string = "Emojis are life"
print("🔹 " + string)
// 🔹 Emojis are life

NSDate

let date = NSDate()
print("🕒 " + String(date))
// 🕒 2016-04-02 00:14:18 +0000

NSURL

let url = NSURL(string: "http://www.andyyhope.com")
print("🌏 " + String(url))
// 🌏 http://www.andyyhope.com

NSError

let userInfo = [NSLocalizedDescriptionKey: "File not found"]
let error = NSError(domain: "Domain", code: 404, userInfo: userInfo)
print(“❗️ “ + “\(error.code): “ + error.localizedDescription)
// ❗️ 404: File not found

AnyObject

let anyObject = UIColor.redColor()
print("◽️ " + String(anyObject))
// ◽️ UIDeviceRGBColorSpace 1 0 0 1

和同事开个小玩笑

let joke = "What is this... A center for ANTS?!"
print("🏫🐜 " + joke)
// 🏫🐜 What is this... A center for ANTS?!

鉴于 iOS 9.1 有 184 种表情可供选择,并且将来还会出现更多,你的大多数日志的需求都能用表情来满足。

实现

不要误会,上面的实现挺烂的…实际上它烂到 Hoover (译者注:一种吸尘器品牌)想把它扫走。把所有不是字符串的东西都包进 String 的括号里,以及找到合适的表情是一件很痛苦的事,如果你正在寻找的表情并不经常用到,通常不太可能找到。
我认为系统能感知到你在寻找哪个表情,故意把它藏在第五个维度来惹你,让你觉得你快疯了。

『也许便便的表情不存在了?或者它从来就没有存在过?』 —— 你

『哦,等等,它在这里。我发誓我看到过的?什么鬼!』 —— 你(十分钟后)

然而,这第一篇文章只是为了演示一下,如何在你的日志中使用表情符号,来区分不同形式的日志,并减少认知负荷。

如果你看完第一部分还能忍受,这个系列的下一部分和最后一部分将具体实现,告诉你如何使这种表情日志的方式更有用。

这篇文章的示例代码可以在 Github 上找到。

第二部分将包含在 log 中使用表情的代码实现。敬请期待!

本文由 SwiftGG 翻译组翻译,已经获得作者翻译授权,最新文章请访问 http://swift.gg

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,204评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,091评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,548评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,657评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,689评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,554评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,302评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,216评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,661评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,851评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,977评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,697评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,306评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,898评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,019评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,138评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,927评论 2 355

推荐阅读更多精彩内容