其实在学习C++之前,是因为自己想学AI,但是发现好多AI教程都是使用C语言来进行讲解的,真心感觉到C真的计算机的基础语言行业的共同语言。至于为什么是C++,主要是C++是从C语言演变而来的,兼容C,并且支持面向对象的方法。虽然C++被认为是较难使用的专业开发语言,但自己也有一定的OOP思想,应该专心学期来没有什么多大的困难。
对于一个外行的自己,总是觉得自己对计算机的基础部分认识的太少,因此,本人也非常注重基础常识部分。昨晚申请的这个博客就当存放自己笔记的平台吧!
cygwin是在windows系统上运行的类unix模拟环境,它包括一套库,可以跟windows的win API一起运行,因此能链接到任意软件,但它不支持Unicode。在cygmin安装文件夹下有个.bat文件,里面已经配置好了一些最重要的环境变量,也可以任意编辑该文件。
GCC(GNU Compiler Collection)包括C、C++、Objective-C、Fortran、Java、Ada和Go 编程语言的前端。
定点数:计算机中采用数的一种方法,原码,反码和补码;
原码(true form):在二进制中,将符号位数字化为0或1,数字的绝对值与符号一起编码,即所谓的”符号-绝对值表示“的编码,称为原码。优点:简单直观,便于输入输出。如:+11的原码为00001011,-11的原码就是10001011。缺点:不能直接参加运算,可能会出错,加减运算时较为复杂。
反码(one's complement):是一种编码方式和求补码的中间码,很少使用。负数反码的符号位与原码相同,其余的取反(0变1,1变0)。数字0的反码有两种:[+0]反=0 000000B,[-0]反=1 1111111B。8位二进制反码的表示范围:-127~+127;
补码(two's complement representation):在计算机中数值一律使用补码来表示和存储。补码可以将符号位和数值域统一处理;同时加减也可以统一处理。一个负整数与其补码相加和为模;对于整数的补码再求补码等于自身;补码的正零和负零表示方法相同。[X+Y]补 = [X]补 + [Y]补;[X-Y]补 = [X]补 - [Y]补 = [X]补 + [-Y]补;[X*Y]补=[X]补*[Y]补;[X*Y]补=[[X]补*Y]补;对于一个负数,其补码等于该数的反码的最末位加1求得。
下面是C++的Hello World程序:
1 #include <iostream>
2 using namespace std;
3
4 int main() {
5 cout << "feiruo !Hello World!" << endl; // prints !!!Hello World!!!
6 /*
7 * "<<"表示一个输出流对象,是C++系统预定义的对象
8 * endl表示一个换行符;
9 * return 0;/表示退出main()函数并以0作为返回值。main()函数的返回值是0,表示程序正常结束,如果main()以非0值返回,则意味着程序异常结束。
10 * #include<iostream>//指示编译器在程序进行预处理时,将文件iostream中的代码嵌入到程序中该指令所在的地方,其中#include被称为预处理指令。cout和<<操作的有关信息就是在iostream文件中声明的。由于这些文件常被嵌入到程序的开始处,因此成为“头文件”。
11 * using namespace std;//"using namespace"是针对命名空间的指令。
12 *
13 */
14 return 0;
15 }
-----------feiruo----------
2015.07.14.20:20:02