遗漏一:‘&&’,‘||’语法现象
&&是与条件符,||是或条件符,这两个条件符都遵从优先判断第一个条件;区别是’&&‘第一个错误就停止判断而‘||’是第一个正确就停止判断
e.g. :fork()||fork()
如上述代码,该行代码将创建三个线程分别是
1:第一个fork()为false,需要判断第二个fork(),而第二个fork()有两个状态,true&false,所以创建了两个线程。
2:第一个fork()为true,不进行第二个线程的判断,创建一个线程
2+1 == 3
e.g.2. :fork()&&fork()
同理也是三个,但是相反的是当第一个fork()为false的时候,不再去判断第二个线程了!!!
遗漏二:递归的用法
递归中
func(...){
statement1;
func();
statement2;
}
如上递归中statement1
按函数调用的顺序执行,而statement2
将按函数调用相反的顺序执行!!!
这样遇到递归的code题就不害怕了比如
226.翻转二叉树【leetcode】 源码贴下面
struct TreeNode* invertTree(struct TreeNode* root) {
if (root == NULL) {
return NULL;
}
struct TreeNode* left = invertTree(root->left);
struct TreeNode* right = invertTree(root->right);
root->left = right;
root->right = left;
return root;
}
递归的原理我在复习完CSAPP后会给大家补上的