c++基础语法规则
1,c++存储类:定义函数或者变量的生命周期
auto 关键字用于两种情况:声明变量时根据初始化表达式自动推断该变量的类型、声明函数时函数返回值的占位符。
register 存储类用于定义存储在寄存器中而不是 RAM (内存)中的局部变量,寄存器是cpu中的相关部件,具体干啥是不明。
static 存储类指示编译器在程序的生命周期内保持局部变量的存在(就是cpp的整个生命进程内),当全局变量用也是可以的。而不需要在每次它进入和离开作用域时进行创建和销毁。这个比较常用,看个实例吧
#include <iostream> // 函数声明
void func(void); static int count = ; /* 全局变量 */ int main()
{
while(count--)
{
func();
}
return ;
}
// 函数定义
void func( void )
{
static int i = ; // 函数每次被调用都会声明局部静态变量为5,但是这并不管用,第一次调用的时候确实为5,第二次的时候就成了6,第三次7,,,如果去掉static,那i就每次都变成5了
i++;
std::cout << "变量 i 为 " << i ;
std::cout << " , 变量 count 为 " << count << std::endl;
}
有关静态全局变量,总结起来有三个好处:
仅对本文件内有效;类似全局变量但是变量属于函数本身,不会随着函数结束而被销毁;仅仅第一次调用的时候初始化,往后再调用就跳过。具体解释看教程:https://blog.csdn.net/majianfei1023/article/details/45290467
extern存储类就是调用前一个文件里的全局变量,省的自己去定义了,或者自己无法初始化,所以‘继承’一个过来。
实例:
/*first file:hello.cpp*/
#include <iostream> int count ;
extern void write_extern(); int main()
{
count = ;
write_extern();
} /*second file:hello2.cpp*/
#include <iostream> extern int count; void write_extern(void)
{
std::cout << "Count is " << count << std::endl;
} /*g++ hello.cpp hello2.cpp -o write
bb一句,原来c++中两个文件可以放到一块编译,编译完了就是一个文件;尤其是两个看起来没啥关系的文件*/
mutable 说明符仅适用于类的对象,不知所以,留后。
thread_local存储类,使用 thread_local 说明符声明的变量仅可在它在其上创建的线程上访问。 变量在创建线程时创建,并在销毁线程时销毁。 每个线程都有其自己的变量副本。
2,运算符
算数运算符:假设b为20,a为10
| 运算符 | 描述 | 实例 |
|---|---|---|
| + | 把两个操作数相加 | A + B 将得到 30 |
| - | 从第一个操作数中减去第二个操作数 | A - B 将得到 -10 |
| * | 把两个操作数相乘 | A * B 将得到 200 |
| / | 分子除以分母 | B / A 将得到 2,地板除,21/10=2 |
| % | 取模运算符,整除后的余数 | B % A 将得到 0 |
| ++ | 自增运算符,整数值增加 1 | A++ 将得到 11 |
| -- | 自减运算符,整数值减少 1 | A-- 将得到 9 |
关系运算符:
假设变量 A 的值为 10,变量 B 的值为 20,则:
| 运算符 | 描述 | 实例 |
|---|---|---|
| == | 检查两个操作数的值是否相等,如果相等则条件为真。 | (A == B) 不为真。 |
| != | 检查两个操作数的值是否相等,如果不相等则条件为真。 | (A != B) 为真。 |
| > | 检查左操作数的值是否大于右操作数的值,如果是则条件为真。 | (A > B) 不为真。 |
| < | 检查左操作数的值是否小于右操作数的值,如果是则条件为真。 | (A < B) 为真。 |
| >= | 检查左操作数的值是否大于或等于右操作数的值,如果是则条件为真。 | (A >= B) 不为真。 |
| <= | 检查左操作数的值是否小于或等于右操作数的值,如果是则条件为真。 | (A <= B) 为真。 |
逻辑运算符:
假设变量 A 的值为 1,变量 B 的值为 0,则:
| 运算符 | 描述 | 实例 |
|---|---|---|
| && | 称为逻辑与运算符。如果两个操作数都非零,则条件为真。 | (A && B) 为假。 |
| || | 称为逻辑或运算符。如果两个操作数中有任意一个非零,则条件为真。 | (A || B) 为真。 |
| ! | 称为逻辑非运算符。用来逆转操作数的逻辑状态。如果条件为真则逻辑非运算符将使其为假。 | !(A && B) 为真。 |
位运算符:
| p | q | p & q | p | q | p ^ q |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 1 | 0 |
| 1 | 0 | 0 | 1 | 1 |
&约等于and,|约等于或,^不同为真
假设如果 A = 60,且 B = 13,现在以二进制格式表示,它们如下所示:
A = 0011 1100
B = 0000 1101
-----------------
A&B = 0000 1100 得到十进制12
A|B = 0011 1101 得到61
A^B = 0011 0001 得到49
~A = 1100 0011 按位取反,得到-61
| 运算符 | 描述 | 实例 |
|---|---|---|
| & | 如果同时存在于两个操作数中,二进制 AND 运算符复制一位到结果中。 | (A & B) 将得到 12,即为 0000 1100 |
| | | 如果存在于任一操作数中,二进制 OR 运算符复制一位到结果中。 | (A | B) 将得到 61,即为 0011 1101 |
| ^ | 如果存在于其中一个操作数中但不同时存在于两个操作数中,二进制异或运算符复制一位到结果中。 | (A ^ B) 将得到 49,即为 0011 0001 |
| ~ | 二进制补码运算符是一元运算符,具有"翻转"位效果,即0变成1,1变成0。 | (~A ) 将得到 -61,即为 1100 0011,一个有符号二进制数的补码形式。 |
| << | 二进制左移运算符。左操作数的值向左移动右操作数指定的位数。 | A << 2 将得到 240,即为 1111 0000 |
| >> | 二进制右移运算符。左操作数的值向右移动右操作数指定的位数。 | A >> 2 将得到 15,即为 0000 1111 |
赋值运算符
| 运算符 | 描述 | 实例 |
|---|---|---|
| = | 简单的赋值运算符,把右边操作数的值赋给左边操作数 | C = A + B 将把 A + B 的值赋给 C |
| += | 加且赋值运算符,把右边操作数加上左边操作数的结果赋值给左边操作数 | C += A 相当于 C = C + A |
| -= | 减且赋值运算符,把左边操作数减去右边操作数的结果赋值给左边操作数 | C -= A 相当于 C = C - A |
| *= | 乘且赋值运算符,把右边操作数乘以左边操作数的结果赋值给左边操作数 | C *= A 相当于 C = C * A |
| /= | 除且赋值运算符,把左边操作数除以右边操作数的结果赋值给左边操作数 | C /= A 相当于 C = C / A |
| %= | 求模且赋值运算符,求两个操作数的模赋值给左边操作数 | C %= A 相当于 C = C % A |
| <<= | 左移且赋值运算符 | C <<= 2 等同于 C = C << 2 |
| >>= | 右移且赋值运算符 | C >>= 2 等同于 C = C >> 2 |
| &= | 按位与且赋值运算符 | C &= 2 等同于 C = C & 2 |
| ^= | 按位异或且赋值运算符 | C ^= 2 等同于 C = C ^ 2 |
| |= | 按位或且赋值运算符 | C |= 2 等同于 C = C | 2 |
其他运算符:
| 运算符 | 描述 |
|---|---|
| sizeof | sizeof 运算符返回变量的大小。例如,sizeof(a) 将返回 4,其中 a 是整数。 |
| Condition ? X : Y | 条件运算符。如果 Condition 为真 ? 则值为 X : 否则值为 Y。 |
| , | 逗号运算符会顺序执行一系列运算。整个逗号表达式的值是以逗号分隔的列表中的最后一个表达式的值。 |
| .(点)和 ->(箭头) | 成员运算符用于引用类、结构和共用体的成员。 |
| Cast | 强制转换运算符把一种数据类型转换为另一种数据类型。例如,int(2.2000) 将返回 2。 |
| & | 指针运算符 & 返回变量的地址。例如 &a; 将给出变量的实际地址。 |
| * | 指针运算符 * 指向一个变量。例如,*var; 将指向变量 var。 |
运算优先级
| 类别 | 运算符 | 结合性 |
|---|---|---|
| 后缀 | () [] -> . ++ - - | 从左到右 |
| 一元 | + - ! ~ ++ - - (type)* & sizeof | 从右到左 |
| 乘除 | * / % | 从左到右 |
| 加减 | + - | 从左到右 |
| 移位 | << >> | 从左到右 |
| 关系 | < <= > >= | 从左到右 |
| 相等 | == != | 从左到右 |
| 位与 AND | & | 从左到右 |
| 位异或 XOR | ^ | 从左到右 |
| 位或 OR | | | 从左到右 |
| 逻辑与 AND | && | 从左到右 |
| 逻辑或 OR | || | 从左到右 |
| 条件 | ?: | 从右到左 |
| 赋值 | = += -= *= /= %=>>= <<= &= ^= |= | 从右到左 |
| 逗号 | , | 从左到右 |
3,循环
while循环和do...while循环:小心死循环
#include <iostream>
using namespace std; int main ()
{
// 局部变量声明
int a = ;
// while 循环执行
while( a < )
{
cout << "a 的值:" << a << endl;
a++;
}
return ;
}
do...while:
#include <iostream>
using namespace std;
int main ()
{
// 局部变量声明
int a = ;
// do 循环执行
do
{
cout << "a 的值:" << a << endl;
a = a + ;
}while( a < );
return ;
}
for循环:和js,php差不多
#include <iostream>
using namespace std; int main ()
{
//for 循环执行完了以后会调到紧跟着for循环的语句上去执行
for( int a = ; a < ; a = a + )
{
cout << "a 的值:" << a << endl;
} return ;
}
嵌套循环:2到100的质数
#include <iostream>
using namespace std; int main ()
{
int i, j;
for(i=; i<; i++) { //i是2-100的数
for(j=; j <= (i/j); j++) { //j是i的除数,而且j只需要比i/j小就行了,这样可以减少循环次数
if(!(i%j)) { //可以整除说明有因数
break; // 如果找到,则不是质数
}
}
if(j > (i/j)) { //此处不好描述,我们只需要知道当i=11,j=2时候j大于5就不用继续找比5大的因数了,因为木有了
cout << i << " 是质数 \n";
}
}
return ;
}
4,判断
if...else...实例:
#include <iostream>
using namespace std; int main ()
{
// 局部变量声明
int a = 100; // 检查布尔条件
if( a < 20 )
{
// 如果条件为真,则输出下面的语句
cout << "a 小于 20" << endl;
}
else
{
// 如果条件为假,则输出下面的语句
cout << "a 大于 20" << endl;
}
cout << "a 的值是 " << a << endl; return 0;
}
swich:
#include <iostream>
using namespace std; int main ()
{
// 局部变量声明
char grade = 'D'; switch(grade) //以grade作为判断依据
{
case 'A' :
cout << "很棒!" << endl;
break;
case 'B' : //此处的意思是B和C都输出‘做的好’
case 'C' :
cout << "做得好" << endl;
break;
case 'D' :
cout << "您通过了" << endl;
break;
case 'F' :
cout << "最好再试一下" << endl;
break;
default :
cout << "无效的成绩" << endl;
}
cout << "您的成绩是 " << grade << endl; return 0;
}
三元运算符:
if(y < ){
var = ;
}else{
var = ;
}
写成以下语句:
var = (y < ) ? : ;
//如果y<10那就让var=30,否则等于40
5,函数
主函数main(),每个c++程序都有至少一个主函数main
自定义函数:
返回类型 函数名称( 参数类型 参数)
{
函数主体
}
自定义函数实例:
#include <iostream>
using namespace std; // 函数声明,this is necessary !
int max(int num1, int num2); int main ()
{
// 局部变量声明
int a = ;
int b = ;
int ret; // 调用函数来获取最大值
ret = max(a, b); cout << "Max value is : " << ret << endl; return ;
} // 函数返回两个数中较大的那个数
int max(int num1, int num2)
{
// 局部变量声明
int result; if (num1 > num2)
result = num1;
else
result = num2; return result;
}
函数三种参数调用方式:重点
1,传值调用:(默认)把变量的实际值赋值给形参
#include <iostream>
using namespace std; // 函数声明
int max(int num1); //注意,此处不提前写函数声明会报错,
int main ()
{
// 局部变量声明
int a = ;
int x;
cout <<"original a is:" << a <<endl; //原来的a是100
x = max(a); cout << "new value is : " << a<< endl; //后来的a仍旧是100
return ;
} // 函数返回两个数中较大的那个数
int max(int num1)
{
int result=num1++;
return result;
}
2,指针调用:把变量的地址赋值给形参
#include <iostream>
using namespace std; // 函数声明
void swap(int *x, int *y); //星号大约是表示参数为指针类型 int main ()
{
// 局部变量声明
int a = ;
int b = ; cout << "交换前,a 的值:" << a << endl;
cout << "交换前,b 的值:" << b << endl; /* 调用函数来交换值
* &a 表示指向 a 的指针,即变量 a 的地址
* &b 表示指向 b 的指针,即变量 b 的地址
*/
swap(&a, &b); cout << "交换后,a 的值:" << a << endl;
cout << "交换后,b 的值:" << b << endl; return ;
}
//一开始a=100,b=200,后来a为200,1为100
// 函数定义
void swap(int *x, int *y)
{
int temp;
temp = *x; /* 保存地址 x 的值 */
*x = *y; /* 把 y 赋值给 x */
*y = temp; /* 把 x 赋值给 y */ return;
}
3,引用调用:把变量的引用的地址赋值给形参
#include <iostream>
using namespace std; // 函数声明
void swap(int &x, int &y); //引用用&符号来表示
//我理解的引用就是,把a的引用赋值给swap的形参,因为引用指向的就是原存储地址,所以,引用调用实际上也会改变原数据的大小
int main ()
{
// 局部变量声明
int a = ;
int b = ; cout << "交换前,a 的值:" << a << endl; //100 200
cout << "交换前,b 的值:" << b << endl; /* 调用函数来交换值 */
swap(a, b); cout << "交换后,a 的值:" << a << endl;
cout << "交换后,b 的值:" << b << endl; //200 100 return ;
}
// 函数定义
void swap(int &x, int &y)
{
int temp;
temp = x; /* 保存地址 x 的值 */
x = y; /* 把 y 赋值给 x */
y = temp; /* 把 x 赋值给 y */ return;
}
为函数设置默认值
#include <iostream>
using namespace std;
int sum(int a, int b=) //设置默认的参数b为20
{
int result;
result=a+b;
return(result);
}
int main()
{
int c=;
int result;
result=sum(c); //a参数是传进去的值,b参数采用默认
cout<<result<<endl;
return ;
}
lambda匿名函数
这是什么鬼,看了半天也不能理解
c++基础语法规则的更多相关文章
- react基础语法(一)元素渲染和基础语法规则
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Markdown基础语法规则
你好,世界.粗体,斜体,测试,弟弟,H2O 论文题目 一级标题 二级标题 三级标题 1 2 3 点击此链接打开网址 公式 \(y = \sin x\) \[ y = \frac{1}{x} \] dd ...
- python基础语法之基础语法规则以及设置
1. 编码格式 在python3以上版本中,py文件默认采用UTF-8格式编码,所有的字符串都是unicode字符串.当然,我们也可以自己为源码文件指定不同的编码,以utf-8为例,相关代码如下所示: ...
- CSS 的基础语法
1.基础语法规则 CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明. 每条声明由一个属性和一个值组成.每个属性有一个值.属性和值被冒号分开. selector {property: val ...
- Java基础-正则表达式(Regular Expression)语法规则简介
Java基础-正则表达式(Regular Expression)语法规则简介 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.正则表达式的概念 正则表达式(Regular Exp ...
- JavaScript进阶 - 第2章 你要懂的规则(JS基础语法)
第2章 你要懂的规则(JS基础语法) 2-1什么是变量 什么是变量? 从字面上看,变量是可变的量:从编程角度讲,变量是用于存储某种/某些数值的存储器.我们可以把变量看做一个盒子,盒子用来存放物品,物品 ...
- iOS-----正则表达式的基础语法
正则表达式简单语法总结 一.什么是正则表达式 从概念上来说,正则表达式也是一门小巧而精炼的语言,它可以用来简化检索特定的字符串,替换特定字符等功能,有许多开发语言工具,都内嵌支持正则表达式.那么一个正 ...
- javaScript基础语法(上)
相关理论概念: 直接量的概念:直接描述某个(些)存储空间的值的量,如变量的值.对象的值.数组的值. 数据类型:在数据结构中的定义是一个值的集合以及定义在这个值集上的一组操作. 1.变量的声明和使用 变 ...
- emmet 系列(1)基础语法
emmet 系列(1)基础语法 emmet 是一个能显著提升开发html和css开发效率的web开发者工具 emmet基本上目前已知的编辑器都有相应的插件,各个编辑器的emmet插件的下载地址:点我下 ...
随机推荐
- BurpSuite 汉化版(含注册机)安装教程
1.注册机使用方法 首先需要完成java安装及环境变量配置. 打开burp-loader-keygen.jar(注册机)--点击run--license text (随意写)--然后将生成的lic ...
- 在java中调用mockjs生成模拟数据
一.手写版 在前端有个模拟数据的神器 Mock.js 能生成随机数据,拦截 Ajax 请求,然后我觉得他的这个生成随机数据不错.然后我就到度娘一顿操作,没找到类似的java实现,于是就有了下面的代码: ...
- Redis03——Redis之单线程+多路IO复用技术
Redis 是单线程+多路IO复用技术 多路复用:使用一个线程来检查多个文件描述符的就绪状态 如果有一个文件描述符就绪,则返回 否则阻塞直到超时 得到就绪状态后进行真正的操作可以在同一个线程里执行,也 ...
- Spark学习之路 (二)Spark2.3 HA集群的分布式安装[转]
下载Spark安装包 从官网下载 http://spark.apache.org/downloads.html 从微软的镜像站下载 http://mirrors.hust.edu.cn/apache/ ...
- Monkey and Banana HDU - 1069 有点像背包,又像最长上升序列
#include<iostream> #include<algorithm> #include<cstring> #include<vector> us ...
- P1002 过河卒【dp】
P1002 过河卒 题目描述 棋盘上AAA点有一个过河卒,需要走到目标BBB点.卒行走的规则:可以向下.或者向右.同时在棋盘上CCC点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制 ...
- 分类问题(三)混淆矩阵,Precision与Recall
混淆矩阵 衡量一个分类器性能的更好的办法是混淆矩阵.它基于的思想是:计算类别A被分类为类别B的次数.例如在查看分类器将图片5分类成图片3时,我们会看混淆矩阵的第5行以及第3列. 为了计算一个混淆矩阵, ...
- Unable to create initial connections of pool. spring boot mysql
Unable to create initial connections of pool. 在链接url里添加 将useSSL=true改为useSSL=false 只能说明服务器没有打开SSL功能
- 【转】Java(多)线程中注入Spring的Bean
问题说明 今天在web应用中用到了Java多线程的技术来并发处理一些业务,但在执行时一直会报NullPointerException的错误,问题定位了一下发现是线程中的Spring bean没有被注入 ...
- SpringBoot学习- 10、设计用户角色权限表
SpringBoot学习足迹 前几节已经基本了解了SpringBoot框架常用的技术,其他的消息队列,定时器等技术暂时用不到,真正项目中如果基于微信系,阿里系开发的话,还要了解平台专用的技术知识,学习 ...