代码改变世界

阅读排行榜

C++对象模型

2015-08-25 16:54 by codinglol, 342 阅读, 收藏,
摘要: 本文主要对C++对象模型做一个简单总结。主要讨论以下几种情况下的C++对象的内存布局情况。1) 单一的一般继承2) 单一的虚拟继承 3) 多重继承 4) 重复多重继承 5) 钻石型的虚拟多重继承虚函数先简单介绍一下虚函数的机制。虚函数的主要作用是实现了多态的机制。对于多态,简而言之就是用父类型的指... 阅读全文

旋转字符串

2015-08-13 12:02 by codinglol, 335 阅读, 收藏,
摘要: 题目描述给定一个字符串,要求把字符串前面的若干个字符移动到字符串的尾部,如把字符串“abcdef”前面的2个字符'a'和'b'移动到字符串的尾部, 使得原字符串变成字符串“cdefab”。请写一个函数完成此功能,要求对长度为n的字符串操作的时间复杂度为 O(n),空间复杂度为 O(1)。分析与解法对... 阅读全文

单词翻转

2015-08-13 15:59 by codinglol, 318 阅读, 收藏,
摘要: 题目描述输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变,句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。例如,输入“I am a student.”,则输出“student. a am I”。分析与解法方案一:首先将整个字符串反转,得到".tneduts a ma I... 阅读全文

链表翻转

2015-08-13 15:06 by codinglol, 260 阅读, 收藏,
摘要: 题目描述给出一个链表和一个数k,比如,链表为1→2→3→4→5→6,k=2,则翻转后2→1→6→5→4→3,若k=3,翻转后3→2→1→6→5→4,若k=4,翻转后4→3→2→1→6→5,用程序实现。分析与解法这个问题与旋转字符串类似,根据给出的k,将链表分为两段X和Y,将他们分别反转即可得到结果。... 阅读全文

术语,概念

2016-09-19 16:31 by codinglol, 258 阅读, 收藏,
摘要: 并发vs并行 异步vs同步 非阻塞vs阻塞 当我们谈到阻塞时,一般是指一个线程的延迟能会导致其它一些线程无限期的延迟。这里有一个例子,有一个资源只能被一个线程使用互斥手段独占使用。如果一个线程永远不释放资源(比如意外地进入了某个无限循环),其它等待的线程将不能进行工作。相对的,非阻塞就是指一个线程不 阅读全文