C++学习笔记8_零碎的知识
1.
int main(void)
{
int arr[] = {1,2,3,4};
//数组的长度
int len = sizeof(arr)/sizeof(int);
//由此可以看出,sizeof(数组名),是可以知道整个数组所占的内存多大
//arr是属于int *类
}
2. int* A类,A能A[0],A[1]...这样子用,因为可以int *A =new int[10];
3. 防止头文件重复包含
(头文件是在源文件中直接展开的)
方法一:
#ifndef 自定义的串
#define 自定义的串
//头文件的内容
#endif
方法二:
#pragma once
//头文件内容
4.对右值取引用
void fun(int &a);
void fun2(int && a);//&&符号,是对“右值”取引用, a=100;100是右值,应该是一个匿名的临时变量
int main()
{
int a=1;
func(a);//这样将a本身传入去
func(100);//这样就不行,因为100不是引用
fun2(100);//这样就可以
}
5. C++类型转换
Type b =(Type)a;//没有类型检查
static_cast 对基本数据类型进行检查,转换有继承关系的指针和引用
int main()
{
int a =10;
char c =static_cast<char>(a);
}
class A;
class B;
class Aplus :public A;
int main()
{
int *p=NULL;
char* cp =static_cast<char*>(p);//报错,不能转
Aplus * ap =NULL;
A* a = NULL;
B *b = statiic_cast<B*>(ap);//没有继承关系,不能通过
A *a = static_cast<A*>(ap);//子转父, 可以通过
Aplus * ap_=static_cast<Aplus*>(a);/父转子,也可以通过
}
int main()
{
Aplus aptemp;
Aplus & ap =aptemp;
A atemp=atemp;
A& a = atemp;
A&a = static_cast<A&>(ap);//子转父, 可以通过
Aplus & ap_=static_cast<Aplus&>(a);/父转子,也可以通过
}
dynamic_cast 检查具有继续关系的指针或引用,在转换前,会进行对象类型检查
int main()
{
int a = 10;
char c = dynamic_cast<char>(a);//不能转换简单的类型。
A *a=NULL;
B * b = dynamic_cast<B*>(a);//报错
Aplus *ap=dynamic_cast<Aplus *>(a);//父转子,报错。
a =dynamic_cast<a*>(ap);//子转父,通过
}
const_cast,用于(指针,引用,或对象指针)去除指针或引用取消const属性。
void main()
{
int a=10;
const int &b=a;//不能通过b修改a
int & c= const_cast<int &>(b);
c=20;//此时,a应该变为20了。但是应该还是不能通过b来改A
}
reinterpret_cast 超强制指针转换,任何指针都可以转任何指针(包括函数指针)
6. 对组pair
int main()
{
pair<int,int> pair1(10,20);
cout<<pair1.first<<pair1.sercond<<endl;
pair<int,stirng> pair2(1,"aaa");
pair<int,string> pair3=pair2;//拷贝
}
C++学习笔记8_零碎的知识的更多相关文章
- IP地址和子网划分学习笔记之《预备知识:进制计数》
一.序:IP地址和子网划分学习笔记开篇 只要记住你的名字,不管你在世界的哪个地方,我一定会去见你.——新海诚 电影<你的名字> 在我们的日常生活中,每个人的名字对应一个唯一的身(敏)份(感 ...
- tensorflow学习笔记(3)前置数学知识
tensorflow学习笔记(3)前置数学知识 首先是神经元的模型 接下来是激励函数 神经网络的复杂度计算 层数:隐藏层+输出层 总参数=总的w+b 下图为2层 如下图 w为3*4+4个 b为4* ...
- ios开发学习笔记001-C语言基础知识
先来学习一下C语言基础知识,总结如下: 在xcode下编写代码. 1.编写代码 2.编译:cc –c 文件名.c 编译成功会生成一个 .o的目标文件 3.链接:把目标文件.o和系统自带的库合并在一起, ...
- java学习之路--零碎的知识笔记
java运算符: 自增自减运算符: int b = ++a; 拆分运算过程为: a=a+1=4; b=a=4, 最后结果为b=4,a=4 前缀自增自减法(++a,--a): 先进行自增或者自减运算,再 ...
- Python学习笔记_零碎知识
1. 变量本身类型不固定的语言称之为动态语言,与之对应的是静态语言.静态语言在定义变量时必须指定变量类型,如果赋值的时候类型不匹配,就会报错. 2. Python有两种除法: /除法计算结果是浮点数, ...
- https学习笔记二----基础密码学知识和python pycrypto库的介绍使用
在更详细的学习HTTPS之前,我也觉得很有必要学习下HTTPS经常用到的加密编码技术的背景知识.密码学是对报文进行编解码的机制和技巧.可以用来加密数据,比如数据加密常用的AES/ECB/PKCS5Pa ...
- 学习笔记:delphi多线程知识
最近一直在温习旧的知识,刚好学习了一下Java的线程安全方面的知识,今天想起之前一直做的Delphi开发,所以还是有必要温习一下,看看这些不同的编程语言有什么不同之处. Delphi的线程同步方法: ...
- 《Python基础教程(第二版)》学习笔记 -> 第一章 基础知识
写笔记的原因:书也看了一遍,视频也看了,但总是感觉效果不好,一段时间忘记了,再看又觉得有心无力,都是PDF的书籍,打开了就没有心情了,上班一天了,回家看这些东西,真的没多大精力了,所以,我觉得还是把p ...
- 【 学习笔记 】memcached基础知识
源地址:http://kb.cnblogs.com/page/42731/ 仔细学习了下,以下是记录的笔记备忘内容. 一.memcached是什么? memcached是高性能的分布式内存缓存服 ...
随机推荐
- vue-cli搭建项目引入jquery和jquery-weui步骤详解
vue简介 Vue.js 是一套用于构建用户界面的渐进式框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用. Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合 ...
- export import 的用法和注意之处
1.整体引入: 会将若干export导出的内容组合成一个对象返回: import *as api from utils.https; api为自定义名称,可直接指定此文件中的某个方法,uti ...
- IoC 之加载 Bean:总结
上文中我们将bean已经加载到了IOC容器中,接下来我们将把IOC加载Bean出来进行代码解析 备注:(有些解释是参考别个博客的相关解释 )一起探讨请加我QQ:1051980588 bean 的初始化 ...
- 09-01 Tensorflow1基本使用
目录 Tensorflow基本使用 一.确认安装Tensorflow 二.获取MNIST数据集 三.使用Tensorflow训练--Softmax回归 四.使用Tensorflow训练--卷积神经网络 ...
- BBEdit 13.0 for Mac 打开大文件不吃力
BBEdit 是一款拥有 16 年历史的 HTML 和文本编辑器,拥有高性能且流畅的文本处理能力,适用于 Web 和软件开发者,具备功能丰富且强大的智能搜索.代码折叠.FTP 和 SFTP 管理等功能 ...
- 攻防世界(XCTF)WEB(进阶区)write up(四)
ics-07 Web_php_include Zhuanxv Web_python_template_injection ics-07 题前半部分是php弱类型 这段说当传入的id值浮点值不能为1 ...
- Python之网络编程Socket
Python 提供了两个级别访问的网络服务.: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口的全部方法. 高级别的网络 ...
- [BZOJ1833][ZJOI2010]数字计数
Description 给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次. Input 输入文件中仅包含一行两个整数a.b,含义如上所述. Output 输出文 ...
- MyCat教程二:mysql主从复制实现
单个mysql数据库在处理业务的时候肯定是有限的,这时我们扩展数据库的第一种方式就是对数据库做读写分离(主从复制),本文我们就先来介绍下怎么来实现mysql的主从复制操作. 1. 读写分离 原 ...
- HDU 6607 Time To Get Up(状态压缩+枚举)
题目网址: http://acm.hdu.edu.cn/showproblem.php?pid=6077 思路: 先预处理一下,将每个数字块的“X”看作1,“.”看作0,进行状态压缩转换成二进制数,用 ...