今天由传智播客老师给大家讲解计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法.
对于很多初学Linux 的同学,大多选择使用虚拟机来展开学习。可以方便的做实验,修改、测试,不必害怕出问题,可以随便折腾!大不了换一个虚拟机,原来的系统不受任何影响。但由于不是实体pc机,使用难免受限。如果配置不好,后期开发必受其累!
对于这种x +=5 ==4表达式的编码风格,我们在开发中是不建议的,这样写虽然高效简洁、正确运行、看起来很酷,但是存在一个风险,即需要人进一步确认这种表达式是否就是开发人员的真正意图。我们在公司开发的时候,通常是很多同事协同开发,当同事看到这类代码的时候,会产生怀疑,从而增加彼此的沟通成本。我们在编码的时,尽量不要让人产生歧义,如果一定想要写这种风格的代码,我建议加上括号,即:x +=(5 == 4),这样语义更加明确,从而也避免造成同事因揣摩代码而带来的苦恼。
编写程序过程中,名称(name)可以是符号常量、变量、函数、结构、枚举、类和对象等等。工程越大,名称互相冲突性的可能性越大。另外使用多个厂商的类库时,也可能导致名称冲突。为了避免,在大规模程序的设计中,以及在程序员使用各种各样的 C++ 库时,这些标识符的命名发生冲突,标准 C++ 引入关键字 namespace(命名空间/名字空间/名称空间),可以更好地控制标识符的作用域。
存放 CPU 执行的机器指令。通常代码区是可共享的(即另外的执行程序可以调用它),使其可共享的目的是对于频繁被执行的程序,只需要在内存中有一份代码即可。代码区通常是只读的,使其只读的原因是防止程序意外地修改了它的指令。另外,代码区还规划了局部变量的相关信息。
如果你开始探索C#或决定扩展你的知识,那么你应该学习这些有用的语言功能,这样做有助于简化代码,避免错误,节省大量的时间。
C语言和C++语言都提供了枚举类型,两者是有一定区别. 我们接下来通过代码进行演示:
内存泄露问题非常难定位,对于小工程项目来说,简单去检查代码中new和delete的匹配对数就基本能定位到问题,但是一旦代码量上升到以万单位时,仅靠肉眼检查来定位问题那就非常困难了,所以我们需要利用工具帮助我们找出问题所在。在Linux系统下内存检测工具首推Valgrind,一款非常好用的开源内存管理工具。Valgrind其实是一个工具集,内存错误检测只是它众多功能的一个,但我们用得最多的功能正是它——memcheck。