July 23, 2014
MySQL 更新并返回计数
"\u003cp\u003e对于想使用 MySQL 实现简单 ID 分配器, 一般就是设置一个整数字段, 然后想分配的时候加 1 并返回. 新手往往犯错误, 先执行一条 update 语句, 然后再 select 那个字段. 但这是错误的!\u003c/p\u003e\n\u003cdiv class=\"highlight\"\u003e\u003cpre tabindex=\"0\" style=\"color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;\"\u003e\u003ccode class=\"language-sql\" data-lang=\"sql\"\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\u003cspan style=\"color:#66d9ef\"\u003eCREATE\u003c/span\u003e \u003cspan style=\"color:#66d9ef\"\u003eTABLE\u003c/span\u003e \u003cspan style=\"color:#f92672\"\u003e`\u003c/span\u003emytable\u003cspan style=\"color:#f92672\"\u003e`\u003c/span\u003e (\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\u003cspan style=\"color:#f92672\"\u003e`\u003c/span\u003ecounter\u003cspan style=\"color:#f92672\"\u003e`\u003c/span\u003e int(\u003cspan style=\"color:#ae81ff\"\u003e10\u003c/span\u003e) \u003cspan style=\"color:#66d9ef\"\u003eNOT\u003c/span\u003e \u003cspan style=\"color:#66d9ef\"\u003eNULL\u003c/span\u003e \u003cspan style=\"color:#66d9ef\"\u003eDEFAULT\u003c/span\u003e \u003cspan style=\"color:#e6db74\"\u003e\u0026#39;0\u0026#39;\u003c/span\u003e\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e) ENGINE\u003cspan style=\"color:#f92672\"\u003e=\u003c/span\u003eInnoDB \u003cspan style=\"color:#66d9ef\"\u003eDEFAULT\u003c/span\u003e CHARSET\u003cspan style=\"color:#f92672\"\u003e=\u003c/span\u003eutf8;\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\u003cspan style=\"color:#66d9ef\"\u003einsert\u003c/span\u003e \u003cspan style=\"color:#66d9ef\"\u003einto\u003c/span\u003e mytable \u003cspan style=\"color:#66d9ef\"\u003evalues\u003c/span\u003e(\u003cspan style=\"color:#ae81ff\"\u003e1\u003c/span\u003e);\n\u003c/span\u003e\u003c/span\u003e\u003c/code\u003e\u003c/pre\u003e\u003c/div\u003e\u003cp\u003e正确的方式应该是使用 last_insert_id() 函数:\u003c/p\u003e\n\u003cdiv class=\"highlight\"\u003e\u003cpre tabindex=\"0\" style=\"color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;\"\u003e\u003ccode class=\"language-sql\" data-lang=\"sql\"\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\u003cspan style=\"color:#66d9ef\"\u003eupdate\u003c/span\u003e mytable \u003cspan style=\"color:#66d9ef\"\u003eset\u003c/span\u003e counter\u003cspan style=\"color:#f92672\"\u003e=\u003c/span\u003elast_insert_id(counter\u003cspan style=\"color:#f92672\"\u003e+\u003c/span\u003e\u003cspan style=\"color:#ae81ff\"\u003e1\u003c/span\u003e);\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\u003cspan style=\"color:#66d9ef\"\u003eselect\u003c/span\u003e last_insert_id();\n\u003c/span\u003e\u003c/span\u003e\u003c/code\u003e\u003c/pre\u003e\u003c/div\u003e\u003cp\u003e另一种方法(http://imysql.cn/2010/07/01/mysql-faq-using-mysql-as-serial-generator.html):\u003c/p\u003e\n\u003cdiv class=\"highlight\"\u003e\u003cpre tabindex=\"0\" style=\"color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;\"\u003e\u003ccode class=\"language-sql\" data-lang=\"sql\"\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\u003cspan style=\"color:#66d9ef\"\u003eSELECT\u003c/span\u003e \u003cspan style=\"color:#f92672\"\u003e`\u003c/span\u003eID\u003cspan style=\"color:#f92672\"\u003e`\u003c/span\u003e \u003cspan style=\"color:#66d9ef\"\u003eFROM\u003c/span\u003e \u003cspan style=\"color:#f92672\"\u003e`\u003c/span\u003eID_RANGE_XX\u003cspan style=\"color:#f92672\"\u003e`\u003c/span\u003e \u003cspan style=\"color:#66d9ef\"\u003eORDER\u003c/span\u003e \u003cspan style=\"color:#66d9ef\"\u003eBY\u003c/span\u003e ID \u003cspan style=\"color:#66d9ef\"\u003eLIMIT\u003c/span\u003e \u003cspan style=\"color:#ae81ff\"\u003e1\u003c/span\u003e \u003cspan style=\"color:#66d9ef\"\u003eFOR …\u003c/span\u003e\u003c/span\u003e\u003c/span\u003e\u003c/code\u003e\u003c/pre\u003e\u003c/div\u003e"
June 20, 2014
golint—golang代码质量检测
"\u003cp\u003egithub: \u003ca href=\"https://github.com/golang/lint\"\u003ehttps://github.com/golang/lint\u003c/a\u003e\u003c/p\u003e\n\u003cp\u003egolint是类似javascript中的jslint的工具,主要功能就是检测代码中不规范的地方。golint用于检测go代码。\u003c/p\u003e\n\u003ch2 id=\"使用\"\u003e使用\u003c/h2\u003e\n\u003cpre tabindex=\"0\"\u003e\u003ccode\u003e$ go get github.com/golang/lint\n$ go install github.com/golang/lint\n\u003c/code\u003e\u003c/pre\u003e\u003cp\u003e\u003ccode\u003egolint 文件名或者目录\u003c/code\u003e\n检测对应的代码。\u003c/p\u003e\n\u003cp\u003egolint会输出一些代码存在的问题:\n比如:\u003c/p\u003e\n\u003cpre tabindex=\"0\"\u003e\u003ccode\u003erecorder.go:55:5: exported var RecordBind should have comment or be unexported\nrecorder.go:158:1: exported function Record_ErrorRecord should have comment or be unexported\nrecorder.go:173:6: don\u0026#39;t use underscores in Go names; type Data_MemStats should be DataMemStats …\u003c/code\u003e\u003c/pre\u003e"
June 19, 2014
Swift中的标准函数
"\u003cp\u003eSwift中共有74个内建函数,但是在Swift官方文档(“ \u003ca href=\"https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/index.html#//apple_ref/doc/uid/TP40014097\"\u003eThe Swift Programming Language\u003c/a\u003e”)中只记录了7中。剩下的67个都没有记录。\u003c/p\u003e\n\u003cp\u003e本文将列举Swift所有的内建函数。本文中提到的所谓的内建函数是指那些在Swift中不需要导入任何模块(如Foundation等)或者引用任何类就可以使用的函数。\u003c/p\u003e\n\u003cp\u003e\u003cstrong\u003eabs(signedNumber)\u003c/strong\u003e: 返回给定的有符号数字的绝对值。很简单,但是没有在文档中记录。\u003c/p\u003e\n\u003col\u003e\n\u003cli\u003eabs(-1) == 1\u003c/li\u003e\n\u003cli\u003eabs(-42) == 42\u003c/li\u003e\n\u003cli\u003eabs(42) == 42\u003c/li\u003e\n\u003c/ol\u003e\n\u003cp\u003e\u003cstrong\u003econtains(sequence, element)\u003c/strong\u003e: 如果给定的序列(如数组)包含特定的元素,则返回true。\u003c/p\u003e\n\u003col\u003e\n\u003cli\u003evar languages = [“Swift”, “Objective-C”]\u003c/li\u003e\n\u003cli\u003econtains(languages, “Swift”) == true\u003c/li\u003e\n\u003cli\u003econtains(languages, “Java”) == false\u003c/li\u003e\n\u003cli\u003econtains([29, 85, 42, 96, 75], 42) == true\u003c/li\u003e\n\u003c/ol\u003e\n\u003cp\u003e\u003cstrong\u003edropFirst(sequence)\u003c/strong\u003e: 返 …\u003c/p\u003e"
June 17, 2014
进程管理工具Supervisord
"\u003ch2 id=\"supervisord-简介\"\u003eSupervisord 简介\u003c/h2\u003e\n\u003cp\u003e上面已经介绍了Go目前是有两种方案来实现他的daemon,但是官方本身还不支持这一块,所以还是建议大家采用第三方成熟工具来管理我们的应用程序,这里我给大家介绍一款目前使用比较广泛的进程管理软件: \u003ca href=\"http://supervisord.org/\"\u003eSupervisord\u003c/a\u003e。Supervisord是用Python实现的一款非常实用的进程管理工具。supervisord会帮你把管理的应用程序转成daemon程序,而且可以方便的通过命令开启、关闭、重启等操作,而且它管理的进程一旦崩溃会自动重启,这样就可以保证程序执行中断后的情况下有自我修复的功能。\u003c/p\u003e\n\u003cblockquote\u003e\n\u003cp\u003e我前面在应用中踩过一个坑,就是因为所有的应用程序都是由Supervisord父进程生出来的,那么当你修改了操作系统的文件描述符之后,别忘记重启Supervisord,光重启下面的应用程序没用。当初我就是系统安装好之后就先装了Supervisord,然后开始部署程序,修改文件描述符,重启程序,以为文件描述符已经是100000了,其实Supervisord这个时候还是默认的1024个,导致他管理的进程所有的描述符也是1024.开放之后压力一上来系统就开始报文件描述符用光 …\u003c/p\u003e\u003c/blockquote\u003e"
June 17, 2014
京东网站url规划分析
"\u003cp\u003e对于一些大型产品网站,当不同产品项的过滤条件不一样的时候,多个过滤条件会完全不一样。如服装行业与电脑配置的许多参数都不一样。而他们又是如何实现自动通过程序来调用的呢,是一个很值得学习的知识的。\u003c/p\u003e\n\u003cp\u003e下面我们来通过京东其中一个服装url来看一下,他们是如何实现这一点的。\u003c/p\u003e\n\u003cp\u003e\u003ca href=\"http://blog.haohtml.com/wp-content/uploads/2014/06/jd_url_parse1.png\"\u003e\u003cimg src=\"https://blogstatic.haohtml.com//uploads/2023/09/jd_url_parse1.png\" alt=\"jd_url_parse1\"\u003e\u003c/a\u003e上图是对于一些大类频道的url规划信息。非常的清楚,就不再一一讲述了。下面我们主要讲右侧”条件筛选“这一块.\u003c/p\u003e\n\u003cp\u003e分析url:\n\u003ca href=\"http://list.jd.com/list.html?cat=1315%2C1342%2C9733\u0026amp;brand=35553%2Ctzmall\u0026amp;page=1\u0026amp;ext=53345%3A%3A1373%5E%5E64135%3A%3A8646%5E%5E95400%3A%3A8648%5E%5E10669%3A%3A1656%5E%5E29520%3A%3A1589%5E%5E110357%3A%3A10991%5E%5E\u0026amp;delivery=2\u0026amp;sort=sort_dredisprice_asc\"\u003ehttp://list.jd.com/list.html?cat=1315%2C1342%2C9733\u0026amp;brand=35553%2Ctzmall\u0026amp;page=1\u0026amp;ext=53345%3A%3A1373%5E%5E64135%3A%3A8646%5E%5E95400%3A%3A8648%5E%5E10669%3A%3A1656%5E%5E29520%3A%3A1589%5E%5E110357%3A%3A10991%5E%5E\u0026amp;delivery=2\u0026amp;sort=sort_dredisprice_asc\u003c/a\u003e\u003c/p\u003e\n\u003cp\u003e经过用js的unescape(url)反编码后,得出url …\u003c/p\u003e"
June 16, 2014
iOS的主要框架介绍(转)
"\u003cp\u003e框架是一个目录,这个目录包含了共享库,访问共享库里代码的头文件,和其它的图片和声音的资源文件。一个共享库定义的方法或函数可以被应用程序调用。\u003c/p\u003e\n\u003cp\u003eIOS提供了很多你可以在应用程序里调用的框架。要使用一个框架,需要将它添加到你的项目中,你的项目才可以使用它。许多应用程序都使用了如Foundation、UIKit、和Core Graphics这些框架。根据你为应用程序选择的模版,相关的框架就已经被自动引入了。如果默认加入的框架不能满足你的应用程序的需求,你也可以加入需要的框架。\u003c/p\u003e\n\u003cp\u003e看看HelloWorld.xcodeproj项目里都包含了哪些框架(注:HelloWorld.xcodeproj是《\u003cem\u003eYour First iOS App\u003c/em\u003e tutorial 》这篇教程里的一个项目)\u003c/p\u003e\n\u003cp\u003e1.在XCode里打开HelloWorld.xcodeproj项目(如果还没有打开)\u003c/p\u003e\n\u003col start=\"2\"\u003e\n\u003cli\u003e在project navigator窗口里点击,点击Frameworks目录前面的三角形图标。你会看到:\u003c/li\u003e\n\u003c/ol\u003e\n\u003cp\u003eUIKit.framework,Foundation.framework, 和CoreGraphics.framework\u003c/p\u003e\n\u003col start=\"3\"\u003e\n\u003cli\u003e点击 …\u003c/li\u003e\u003c/ol\u003e"
June 15, 2014
Swift中的柯里化函数
"\u003cp\u003e柯里化函数(curried function)的类型相当于一个嵌套函数类型。例如,下面的柯里化函数 \u003ccode\u003eaddTwoNumber()()\u003c/code\u003e 的类型是 \u003ccode\u003eInt -\u0026gt; Int -\u0026gt; Int\u003c/code\u003e:\u003c/p\u003e\n\u003cpre tabindex=\"0\"\u003e\u003ccode class=\"language-lang-swift\" data-lang=\"lang-swift\"\u003efunc addTwoNumbers(a: Int)(b: Int) -\u0026gt; Int{\n return a + b\n}\naddTwoNumbers(4)(5) // returns 9\n\u003c/code\u003e\u003c/pre\u003e\u003cp\u003e柯里化函数的函数类型从右向左组成一组。例如,函数类型 \u003ccode\u003eInt -\u0026gt; Int -\u0026gt; Int\u003c/code\u003e 可以被理解为 \u003ccode\u003eInt -\u0026gt; (Int -\u0026gt; Int)\u003c/code\u003e——也就是说,一个函数传入一个 \u003ccode\u003eInt\u003c/code\u003e 然后输出作为另一个函数的输入,然后又返回一个 \u003ccode\u003eInt\u003c/code\u003e。例如,你可以使用如下嵌套函数来重写柯里化函数 \u003ccode\u003eaddTwoNumbers()()\u003c/code\u003e:\u003c/p\u003e\n\u003cpre tabindex=\"0\"\u003e\u003ccode class=\"language-lang-swift\" data-lang=\"lang-swift\"\u003efunc addTwoNumbers(a: Int) -\u0026gt; (Int -\u0026gt; Int){\n func addTheSecondNumber(b: Int) -\u0026gt; Int{\n return a + b\n } …\u003c/code\u003e\u003c/pre\u003e"
June 12, 2014
Swift中的结构体与类的区别(有坑存在)
"\u003ch2 id=\"-\"\u003e结构体和枚举是值类型\u003c/h2\u003e\n\u003cp\u003e在 Swift 中,所有的基本类型:整数(Integer)、浮点数(floating-point)、布尔值(Booleans)、字符串(string)、数组(array)和字典(dictionaries),都是值类型,并且都是以结构体的形式在后台所实现。\u003c/p\u003e\n\u003cp\u003e在 Swift 中,所有的结构体和枚举都是值类型。这意味着它们的实例,以及实例中所包含的任何值类型属性,在代码中传递的时候都会被复制。\u003c/p\u003e\n\u003ch2 id=\"-\"\u003e类是引用类型\u003c/h2\u003e\n\u003cp\u003e与值类型不同,引用类型在被赋予到一个变量,常量或者被传递到一个函数时,操作的并不是其拷贝。因此,引用的是已存在的实例本身而不是其拷贝。\u003c/p\u003e\n\u003ch1 id=\"恒等运算符\"\u003e恒等运算符\u003c/h1\u003e\n\u003cp\u003e因为类是引用类型,有可能有多个常量和变量在后台同时引用某一个类实例。(对于结构体和枚举来说,这并不成立。因为它们作值类型,在被赋予到常量,变量或者传递到函数时,总是会被拷贝。)\u003c/p\u003e\n\u003cp\u003e如果能够判定两个常量或者变量是否引用同一个类实例将会很有帮助。为了达到这个目的,Swift 内建了两个恒等运算符:\u003c/p\u003e\n\u003cul\u003e\n\u003cli\u003e\n\u003cp\u003e等价于 ( === )\u003c/p\u003e\n\u003c/li\u003e\n\u003cli\u003e\n\u003cp\u003e不等价于 ( !== )\u003c/p\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003cp\u003e以下是运用这两个运算符检测两个常量或者变量是否引用同一个实例:\u003c/p\u003e\n\u003cp\u003eif …\u003c/p\u003e"
June 12, 2014
Swift中的函数
"\u003cp\u003e对于Swift语言中的函数还是有许多与其它语言不同的地方的。如下:\u003c/p\u003e\n\u003cp\u003e\u003cstrong\u003e1. 对于指定函数黑夜参数值的函数,在调用函数的时候,如果需要指定参数值的话,需要以“参数名:值”这种格式调用\u003c/strong\u003e\nfunc join(s1:String, s2: String, joinstr: String = “-“) -\u0026gt; String {\nreturn s1 + joinstr + s2\n}\u003c/p\u003e\n\u003cp\u003elet result = join(“hello”, “world”, joinstr:”===”) //或者直接写前两个值\nprintln(result)\u003c/p\u003e\n\u003cp\u003e\u003cstrong\u003e2. 常量参数和变量参数(Constant and Variable Parameters)\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003e数参数默认是常量。试图在函数体中更改参数值将会导致编译错误。这意味着你不能错误地更改参数值。\u003c/p\u003e\n\u003cp\u003e但是,有时候,如果函数中有传入参数的变量值副本将是很有用的。你可以通过指定一个或多个参数为变量参数,从而避免自己在函数中定义新的变量。变量参数不是常量,你可以在函数中把它当做新的可修改副本来使用。\u003c/p\u003e\n\u003cp\u003e通过在参数名前加关键字 \u003ccode\u003evar\u003c/code\u003e 来定义变量参数:\u003c/p\u003e\n\u003cp\u003efunc …\u003c/p\u003e"
June 11, 2014
Swift编程语言中的optional(可选)
"\u003ch2 id=\"-\"\u003e可选\u003c/h2\u003e\n\u003cp\u003e使用可选来处理值可能缺失的情况。可选表示:\u003c/p\u003e\n\u003cul\u003e\n\u003cli\u003e有值,等于 x\u003c/li\u003e\n\u003c/ul\u003e\n\u003cp\u003e或者\u003c/p\u003e\n\u003cul\u003e\n\u003cli\u003e没有值\u003c/li\u003e\n\u003c/ul\u003e\n\u003cblockquote\u003e\n\u003cp\u003e注意:C 和 Objective-C 中并没有可选这个概念。最接近的是 Objective-C 中的一个特性,一个方法要不返回一个对象要不返回 \u003ccode\u003enil\u003c/code\u003e, \u003ccode\u003enil\u003c/code\u003e 表示“缺少一个合法的对象”。然而,这只对对象起作用——对于结构体,基本的 C 类型或者枚举类型不起作用。对于这些类型,Objective-C 方法一般会返回一个特殊值(比如 \u003ccode\u003eNSNotFound\u003c/code\u003e)来暗示值缺失。这种方法假设方法的调用者知道并记得对特殊值进行判断。然而,Swift 的可选可以让你暗示任意类型的值缺失,并不需要一个特殊值。\u003c/p\u003e\u003c/blockquote\u003e\n\u003cp\u003e来看一个例子。Swift 的 \u003ccode\u003eString\u003c/code\u003e 类型有一个叫做 \u003ccode\u003etoInt\u003c/code\u003e 的方法,作用是将一个 \u003ccode\u003eString\u003c/code\u003e 值转换成一个 \u003ccode\u003eInt\u003c/code\u003e 值。然而,并不是所有的字符串都可以转换成一个整数。字符串 \u003ccode\u003e\u0026quot;123\u0026quot;\u003c/code\u003e 可以被转换成数字 \u003ccode\u003e123\u003c/code\u003e,但是字符串 \u003ccode\u003e\u0026quot;hello, world\u0026quot;\u003c/code\u003e 不行。\u003c/p\u003e\n\u003cp\u003e下面的例子使用 \u003ccode\u003etoInt\u003c/code\u003e 方法来尝试将一个 \u003ccode\u003eString\u003c/code\u003e 转换成 \u003ccode\u003eInt\u003c/code\u003e:\u003c/p\u003e\n\u003cp\u003elet …\u003c/p\u003e"
June 10, 2014
Swift中的字典
"\u003cp\u003e//1.创建字典\u003c/p\u003e\n\u003cp\u003evar dict:Dictionary\u0026lt;Int, String\u0026gt; = [:“美国“,1:“中国“, 2:“英国“]\u003c/p\u003e\n\u003cp\u003evar country = [\u003c/p\u003e\n\u003cp\u003e“china”: “中国“,\u003c/p\u003e\n\u003cp\u003e“en”:“英国“,\u003c/p\u003e\n\u003cp\u003e“usa”:“美国“\u003c/p\u003e\n\u003cp\u003e]\u003c/p\u003e\n\u003cp\u003e//创建一个空的字典\u003c/p\u003e\n\u003cp\u003evar emptyDictionary = Dictionary\u0026lt;String, Float\u0026gt;()\u003c/p\u003e\n\u003cp\u003evar emptyDictionary2 = [:]\u003c/p\u003e\n\u003cp\u003efor (key,value) incountry {\u003c/p\u003e\n\u003cp\u003evar result = key + value\u003c/p\u003e\n\u003cp\u003e}\u003c/p\u003e\n\u003cp\u003e//2.获取字典中的所有键名和键值及字典元素个数\u003c/p\u003e\n\u003cp\u003evar keys = Array(country.keys)\u003c/p\u003e\n\u003cp\u003evar values = Array(country.values)\u003c/p\u003e\n\u003cp\u003evar cnum = country.count\u003c/p\u003e\n\u003cp\u003e//3.访问字典\u003c/p\u003e\n\u003cp\u003evar value = dict[]\u003c/p\u003e\n\u003cp\u003evar value2 = country[“china”]\u003c/p\u003e\n\u003cp\u003e//4.修改字典,修改后,字典中的位置会发生改变\u003c/p\u003e\n\u003cp\u003ecountry[“china”] = “中华人民 …\u003c/p\u003e"
June 10, 2014
swift中的数组操作
"\u003cp\u003evar shopCart: String[] = [“苹果“, “桔子“, “荔枝“]\u003c/p\u003e\n\u003cp\u003evar shoppingList = [“catfilsh”, “water”, “tulips”]\u003c/p\u003e\n\u003cp\u003e//创建一个空数组\u003c/p\u003e\n\u003cp\u003evar emptyArray = String\u003ca href=\"\"\u003e\u003c/a\u003e\u003c/p\u003e\n\u003cp\u003e//数组遍历\u003c/p\u003e\n\u003cp\u003efor str inshopCart {\u003c/p\u003e\n\u003cp\u003e println(str)\u003c/p\u003e\n\u003cp\u003e}\u003c/p\u003e\n\u003cp\u003e//带索引值的遍历\u003c/p\u003e\n\u003cp\u003efor (index, value) inenumerate(shopCart) {\n println(“(index+1):(value)“)\n}\u003c/p\u003e\n\u003cp\u003e//判断数组是否为空及数组元素个数\u003c/p\u003e\n\u003cp\u003eifshopCart.isEmpty {\u003c/p\u003e\n\u003cp\u003eprintln(“购物车中无任何商品,请购买”)\u003c/p\u003e\n\u003cp\u003e} else {\u003c/p\u003e\n\u003cp\u003eprintln(“您当前购物车中共 (shopCart.count) 有件商品”)\u003c/p\u003e\n\u003cp\u003e}\u003c/p\u003e\n\u003cp\u003eprintln(“=================”)\u003c/p\u003e\n\u003cp\u003e//数组元素添加,{苹果 桔子 荔枝 芒果}\u003c/p\u003e\n\u003cp\u003eshopCart.append(“芒果“)\u003c/p\u003e\n\u003cp\u003efor str inshopCart {\u003c/p\u003e\n\u003cp\u003eprintln(str)\u003c/p\u003e\n\u003cp\u003e} …\u003c/p\u003e"
May 28, 2014
Linux中让crontab以秒为单位执行任务
"\u003cp\u003eLinux下实现秒级定时任务的两种方案(Crontab 每秒运行):\u003c/p\u003e\n\u003cp\u003e\u003cstrong\u003e第一种方案,当然是写一个后台运行的脚本一直循环,然后每次循环sleep一段时间。\u003c/strong\u003e\u003c/p\u003e\n\u003cpre tabindex=\"0\"\u003e\u003ccode\u003e#!/bin/bash\nwhile true ;do\n\ncommand\n\nsleep XX //间隔秒数\n\ndone\n\u003c/code\u003e\u003c/pre\u003e\u003cp\u003e或者使用for语句\u003c/p\u003e\n\u003cpre tabindex=\"0\"\u003e\u003ccode\u003e#!/bin/bash\n\nfor((i=1;i\u0026lt;=20;i++));do\n/home/somedir/scripts.sh \u0026gt; /dev/null 2\u0026gt;\u0026amp;1\nsleep 3\ndone\n\u003c/code\u003e\u003c/pre\u003e\u003cp\u003e\u003cstrong\u003e第二种方案,使用crontab。\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003e我们都知道crontab的粒度最小是到分钟,但是我们还是可以通过变通的方法做到隔多少秒运行一次。\u003c/p\u003e\n\u003cp\u003e以下方法将每20秒执行一次\u003c/p\u003e\n\u003cpre tabindex=\"0\"\u003e\u003ccode\u003ecrontab -e\n* * * * * /bin/date\n* * * * * sleep 20; /bin/date.sh\n* * * * * sleep 40; /bin/date.sh\n\u003c/code\u003e\u003c/pre\u003e\u003cp\u003e说明:需要将/bin/date.sh更换成你的命令即可\u003c/p\u003e\n\u003cp\u003e这种做法去处理隔几十秒的定时任务还好,要是每1秒运行一次就得添加60条记录。。。如果每秒运 …\u003c/p\u003e"
April 8, 2014
日600亿消息,月4.65亿用户——WhatsApp的Erlang世界[架构设计](最新版)
"\u003cp\u003e来自 High Scalability。相较 \u003ca href=\"http://highscalability.com/blog/2014/2/26/the-whatsapp-architecture-facebook-bought-for-19-billion.html\"\u003e上篇\u003c/a\u003e,这篇内容更新、更全。 \u003ca href=\"http://www.csdn.net/article/2014-04-04/2819158-how-whatsapp-grew-to-nearly-500-million-users-11000-cores-an\"\u003e译文\u003c/a\u003e a\u003c/p\u003e\n\u003cp\u003e【编者按】在之前我们有分享过HighScalability创始人Tod Hoff总结的 \u003ca href=\"http://www.csdn.net/article/2014-02-27/2818559-an-overview-at-whatsapp%27s-19b-architecture\"\u003eWhatsApp早期架构\u003c/a\u003e,其中包括了大量的Erlang优化来支撑单服务器200万并发连接,以及如何支撑所有类型的手机并提供一个完美的用户体验。然而时过境迁,两年后WhatsApp又是如何支撑10倍于之前的流量,以及应用的飞速扩展,这里我们一起看Tod带来的总结。以下为译文:\u003c/p\u003e\n\u003ch3 id=\"两年内的飞跃\"\u003e两年内的飞跃\u003c/h3\u003e\n\u003cp\u003e天价应用当下的规模显然不能与两年前同日而语,这里总结了一些WhatsApp两年内发生的主要变化:\u003c/p\u003e\n\u003cp\u003e**1. **从任何维度上都可以看到WhatsApp的巨变,但是工程师的数量却一直未变。当下,WhatsApp有更多的主机、更多的数据中心、更多的内存、更多的用户以及更多的扩展性问题,然而最引以为豪的却是那支10人工程团队——每个工程师平均负责4000万个用户。当然,这也是云时代的胜利:工程师只负责软件的开发,网络、硬件及数据中心运维全部假手于人。\u003c/p\u003e\n\u003cp\u003e**2. **在之前,面对负载的激增,他们必须让单服务器支撑尽可能多的连接数,但是现在他 …\u003c/p\u003e"
March 8, 2014
golang中for循环方法的差异
"\u003cp\u003e用for循环遍历字符串时,也有 byte 和 rune 两种方式.第一种试为byte,第二种rune。\u003c/p\u003e\n\u003cp\u003egolang中string rune byte 三者的关系 \u003ca href=\"https://blog.haohtml.com/archives/17646\"\u003ehttps://blog.haohtml.com/archives/17646\u003c/a\u003e\u003c/p\u003e\n\u003cpre tabindex=\"0\"\u003e\u003ccode\u003epackage main\n\nimport (\n \u0026#34;fmt\u0026#34;\n)\n\nfunc main() {\n s := \u0026#34;abc汉字\u0026#34;\n\n for i := 0; i \u0026lt; len(s); i++ {\n fmt.Printf(\u0026#34;%c,\u0026#34;, s[i])\n }\n\n fmt.Println()\n\n for _, r := range s {\n fmt.Printf(\u0026#34;%cn\u0026#34;, r)\n }\n}\n\u003c/code\u003e\u003c/pre\u003e\u003cp\u003e输出结果:\u003c/p\u003e\n\u003cpre tabindex=\"0\"\u003e\u003ccode\u003ea,b,c,æ,±,,å,,,\na\nb\nc\n汉\n字\n\u003c/code\u003e\u003c/pre\u003e"