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_零碎的知识的更多相关文章

  1. IP地址和子网划分学习笔记之《预备知识:进制计数》

    一.序:IP地址和子网划分学习笔记开篇 只要记住你的名字,不管你在世界的哪个地方,我一定会去见你.——新海诚 电影<你的名字> 在我们的日常生活中,每个人的名字对应一个唯一的身(敏)份(感 ...

  2. tensorflow学习笔记(3)前置数学知识

    tensorflow学习笔记(3)前置数学知识 首先是神经元的模型 接下来是激励函数 神经网络的复杂度计算 层数:隐藏层+输出层 总参数=总的w+b 下图为2层 如下图 w为3*4+4个   b为4* ...

  3. ios开发学习笔记001-C语言基础知识

    先来学习一下C语言基础知识,总结如下: 在xcode下编写代码. 1.编写代码 2.编译:cc –c 文件名.c 编译成功会生成一个 .o的目标文件 3.链接:把目标文件.o和系统自带的库合并在一起, ...

  4. java学习之路--零碎的知识笔记

    java运算符: 自增自减运算符: int b = ++a; 拆分运算过程为: a=a+1=4; b=a=4, 最后结果为b=4,a=4 前缀自增自减法(++a,--a): 先进行自增或者自减运算,再 ...

  5. Python学习笔记_零碎知识

    1. 变量本身类型不固定的语言称之为动态语言,与之对应的是静态语言.静态语言在定义变量时必须指定变量类型,如果赋值的时候类型不匹配,就会报错. 2. Python有两种除法: /除法计算结果是浮点数, ...

  6. https学习笔记二----基础密码学知识和python pycrypto库的介绍使用

    在更详细的学习HTTPS之前,我也觉得很有必要学习下HTTPS经常用到的加密编码技术的背景知识.密码学是对报文进行编解码的机制和技巧.可以用来加密数据,比如数据加密常用的AES/ECB/PKCS5Pa ...

  7. 学习笔记:delphi多线程知识

    最近一直在温习旧的知识,刚好学习了一下Java的线程安全方面的知识,今天想起之前一直做的Delphi开发,所以还是有必要温习一下,看看这些不同的编程语言有什么不同之处. Delphi的线程同步方法: ...

  8. 《Python基础教程(第二版)》学习笔记 -> 第一章 基础知识

    写笔记的原因:书也看了一遍,视频也看了,但总是感觉效果不好,一段时间忘记了,再看又觉得有心无力,都是PDF的书籍,打开了就没有心情了,上班一天了,回家看这些东西,真的没多大精力了,所以,我觉得还是把p ...

  9. 【 学习笔记 】memcached基础知识

    源地址:http://kb.cnblogs.com/page/42731/ 仔细学习了下,以下是记录的笔记备忘内容. 一.memcached是什么?    memcached是高性能的分布式内存缓存服 ...

随机推荐

  1. vue-cli搭建项目引入jquery和jquery-weui步骤详解

    vue简介 Vue.js 是一套用于构建用户界面的渐进式框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用. Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合 ...

  2. export import 的用法和注意之处

       1.整体引入: 会将若干export导出的内容组合成一个对象返回: import *as  api from  utils.https; api为自定义名称,可直接指定此文件中的某个方法,uti ...

  3. IoC 之加载 Bean:总结

    上文中我们将bean已经加载到了IOC容器中,接下来我们将把IOC加载Bean出来进行代码解析 备注:(有些解释是参考别个博客的相关解释 )一起探讨请加我QQ:1051980588 bean 的初始化 ...

  4. 09-01 Tensorflow1基本使用

    目录 Tensorflow基本使用 一.确认安装Tensorflow 二.获取MNIST数据集 三.使用Tensorflow训练--Softmax回归 四.使用Tensorflow训练--卷积神经网络 ...

  5. BBEdit 13.0 for Mac 打开大文件不吃力

    BBEdit 是一款拥有 16 年历史的 HTML 和文本编辑器,拥有高性能且流畅的文本处理能力,适用于 Web 和软件开发者,具备功能丰富且强大的智能搜索.代码折叠.FTP 和 SFTP 管理等功能 ...

  6. 攻防世界(XCTF)WEB(进阶区)write up(四)

    ics-07  Web_php_include  Zhuanxv Web_python_template_injection ics-07 题前半部分是php弱类型 这段说当传入的id值浮点值不能为1 ...

  7. Python之网络编程Socket

    Python 提供了两个级别访问的网络服务.: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口的全部方法. 高级别的网络 ...

  8. [BZOJ1833][ZJOI2010]数字计数

    Description 给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次. Input 输入文件中仅包含一行两个整数a.b,含义如上所述. Output 输出文 ...

  9. MyCat教程二:mysql主从复制实现

      单个mysql数据库在处理业务的时候肯定是有限的,这时我们扩展数据库的第一种方式就是对数据库做读写分离(主从复制),本文我们就先来介绍下怎么来实现mysql的主从复制操作. 1. 读写分离   原 ...

  10. HDU 6607 Time To Get Up(状态压缩+枚举)

    题目网址: http://acm.hdu.edu.cn/showproblem.php?pid=6077 思路: 先预处理一下,将每个数字块的“X”看作1,“.”看作0,进行状态压缩转换成二进制数,用 ...