Algorithm
905. Sort Array By Parity
LeetCode链接
class Solution {
public int[] sortArrayByParity(int[] A) {
int count = A.length;
int[] arr = new int[count];
int left = 0;
int right = count - 1;
for (int i = 0; i < count; i++) {
if (A[i] % 2 == 0) {
arr[left++] = A[i];
} else {
arr[right--] = A[i];
}
}
return arr;
}
}
Review
Understanding weak and strong in Objective C
代码块很棒。为了防止循环引用我们经常可以看到下面这样weak-strong的写法。
__weak __typeof__(self) weakSelf = self;
self.block = ^{
__typeof__(self) strongSelf = weakSelf;
[strongSelf doSomething];
[strongSelf doSomethingElse];
};
当block创建的时候
当被拷贝的时候Block是对象
block在栈上创建,并在栈帧返回时消失。在栈中,block对其访问的任何内容的存储或生命周期没有影响。
如果在栈帧返回后block需要存在,则可以将它们复制到堆中,并且此操作是显式操作。这种方式,block将获得引用计数和Cocoa中的所有对象一样。复制它们时,它们会捕获它们捕获的范围,保留它们引用的任何对象
block可以从封闭范围捕获值
除了包含可执行代码之外,block还具有从其封闭范围捕获状态的能力。请注意,block会捕获变量及其装饰器(即弱限定符),
=>这解释了为什么你需要声明self
为__weak
执行block时
当block执行时,对于第一个方法(doSomething
),weakSelf
可能是非nil
,而对于第二个方法(doSomethingElse
)则不是
您可能会认为,首先,这是在block
内使用self
避免保留周期警告的技巧。不是这种情况。在块执行时创建对self的强引用,而在块声明时评估块中的self,从而保留对象。
但是,对于最佳实践,您应该使用弱对象创建对象的强引用。这不会产生循环引用,因为block中的强指针只会在block完成之前存在(它的生命周期是block内部)。
=>这解释了为什么你需要定义另一个__strong self
更多解释
正如许多人所指出的那样,“Block在栈上创建,并在栈帧返回时消失。在栈中,一个Block对它访问的任何对象的存储或生命周期没有影响。“
即使Block(在栈上声明的)增加了它访问的所有对象的引用计数,这也无所谓,因为这个Block将在函数返回时销毁
当复制Block时(你看到人们通常声明Block的属性copy
),它会增加它访问的所有对象的引用计数。
为什么?因为Block意味着稍后要执行,所以它需要对它访问的所有对象保持强引用。Block可以执行很多次,所以在这个运行之后它不会释放self。
当你清空Block时,它将销毁,因此它会减少它访问的所有对象的引用计数。
AFNetworking在调用后会将Block置为空,因此您不必使用weakself在Block内部
所以有些情况下你不必在Block内使用weakself
确保未复制Block,您只是声明并运行它
调用Block后确保该block为nil
Tip
最近这几天在为了职级晋升的事情选方向和技能点,做Demo,忙活了两天感觉一无所获,个人的感触就是持续不断的成就感会刺激你更坚定的走下去,而不断的挫折感会打消你的积极性,让你放弃,所以当你去做一件事的时候一定要给予自己足够的正向激励,这样你才能保证持续学习的状态。另外吐槽一点的就是国内网络上很多文章写的都有很大的问题,不能够与时俱进,比如某个方案可能在某个IDE的版本可以但是新版本就不适用了,并且编译原理相关的文章数量极少,且天下文章一大抄,长得都差不多。
这时候突然想着自己这只菜鸡什么时候能够把基础知识夯实,写一些高质量的文章,解救那些刚入门的编程小白,让他们少走一些弯路,帮助别人的同时也在提升自己的输出和表达能力,于是又有了努力学习的动力。
Share
最近在看关于CodeReview方面的文章,又通读了一遍专栏里推荐的这两篇文章,后期还会整理更多这方面的优质文章。