C++知识点总结(6)
1.double和float的存储方式
float遵从的是IEEE R32.24 ,而double 遵从的是R64.53。无论是单精度还是双精度在存储中都分为三个部分:
- 符号位(Sign) : 0代表正,1代表为负
- 指数位(Exponent):用于存储科学计数法中的指数数据,并且采用移位存储
- 尾数部分(Mantissa):尾数部分


<span style="font-size:18px;">float a = 1.0f;
cout<< (int)a <<endl;
cout<< (int&)a <<endl;
cout << boolalpha << ( (int)a==(int&)a ) << endl; // false float b = 0.0f;
cout<< (int)b <<endl;
cout<< (int&)b <<endl;
cout << boolalpha << ( (int)b==(int&)b ) << endl; // true </span>
2.C++构造函数的嵌套调用
class CLS
{
public:
static int i;
int m_i;
static int j;
CLS(int t): m_i(t) {
}
CLS()
{
CLS(100);
}
~CLS(){
}
};
调用1次构造函数相当于生成一个临时对象。此时该对象的m_i被赋值100,调用完后析构了此对象,但是当前的m_i实际没有初始化。
3.vector中的越界问题
int main(void)
{
vector array; array.push_back( 1 );
array.push_back( 2 );
array.push_back( 3 );
for( vector::size_type i=array.size()-1; i>=0; --i ) // 反向遍历array数组
{
cout << array[i] << endl;
}
return 0;
}
size_type默认为无符号unsigned int 整型,当至最小数0-1,则产生的值为最大的数。
4.字符数组的初始化方法
char input[100];
cin.get(input,number,ch);//number表示最多读取的字符,ch表示遇到此字符则截止(默认为'\n'),但是截止符号仍然存在于输入流中
cin.getline(input,number,ch);//同上,唯一不同的是,遇到截止符,截止符号被从输入流中删除。
gets(input);//输入的时候以换行符作为结束,空格键和制表符正常写入。由于此函数不会检查是否溢出,程序员必须保证。
5.qsort和sort的用法总结
qsort
原型:
_CRTIMP void __cdecl qsort (void*, size_t, size_t,int (*)(const void*, const void*));
解释: qsort ( 数组名 ,元素个数,元素占用的空间(sizeof),比较函数)
比较函数是一个自己写的函数 遵循 int com(const void *a,const void *b) 的格式。
当a b关系为 > < = 时,分别返回正值 负值 零 (或者相反)。
使用a b 时要强制转换类型,从void * 转换回应有的类型后,进行操作。
封装的是快速排序。
int num[100];
int cmp ( const void *a , const void *b )//int
{
return *(int *)a - *(int *)b;
}
qsort(num,100,sizeof(num[0]),cmp); char word[100];
int cmp( const void *a , const void *b )//char
{
return *(char *)a - *(int *)b;
}
qsort(word,100,sizeof(word[0]),cmp); double in[100];
int cmp( const void *a , const void *b )//double
{
return *(double *)a > *(double *)b ? 1 : -1;
}
qsort(in,100,sizeof(in[0]),cmp); struct In
{
double data;
int other;
}s[100]
int cmp( const void *a ,const void *b)//结构体一级
{
return ((In *)a)->data > ((In *)b)->data ? 1 : -1;
}
qsort(s,100,sizeof(s[0]),cmp); struct In
{
int x;
int y;
}s[100];
int cmp( const void *a , const void *b )//结构体二级
{
In *c = (In *)a;
In *d = (In *)b;
if(c->x != d->x) return c->x - d->x;
else return d->y - c->y;
}
qsort(s,100,sizeof(s[0]),cmp); struct In
{
int data;
char str[100];
}s[100];
int cmp ( const void *a , const void *b )//结构体按字符串排序
{
return strcmp( ((In *)a)->str , ((In *)b)->str );
} qsort(s,100,sizeof(s[0]),cmp);
sort
- 升序:sort(begin,end,less<data-type>());
- 降序:sort(begin,end,greater<data-type>())
int a[]={2,4,1,23,5,76,0,43,24,65};
double b[]={2.0,4.1,1.2,23.0,5.7,76.23,0.0,43.78,24.14,65.45};
vector<int> vec(a,a+sizeof(a)/sizeof(int));
list<int> List(a,a+sizeof(a)/sizeof(int)); sort(a,a+sizeof(a)/sizeof(int));//升序
sort(a,a+sizeof(a)/sizeof(int),compare1);//降序
sort(a,a+sizeof(a)/sizeof(int),greater<int>());//降序 sort(b,b+sizeof(b)/sizeof(double));//升序
sort(b,b+sizeof(b)/sizeof(double),greater<double>());//降序
sort(b,b+sizeof(b)/sizeof(double),compare2);//降序 sort(vec.begin(),vec.end(),less<int>());//升序
sort(List.begin(),List.end(),greater<int>());//降序
其中,使用的自定义函数compare1和compare2分别为:
bool compare1(int a,int b)
{
return a>b; //降序排列
}
bool compare2(double a,double b)
{
return a>b?true:false; //降序排列
}
7.成员函数指针
class A{
private:
int data;
public:
A(int i=0):data(i){}
string equal(const A& m){
if(m.data==data)
return "true";
else
return "false";
}
}; int main()
{
A a1(8),a2(4);
string (A::*p)(const A&);
p=&(A::equal);
cout<<(a1.*p)(a2)<<endl;
return 0;
}
C++知识点总结(6)的更多相关文章
- ASP.NET Core 中的那些认证中间件及一些重要知识点
前言 在读这篇文章之间,建议先看一下我的 ASP.NET Core 之 Identity 入门系列(一,二,三)奠定一下基础. 有关于 Authentication 的知识太广,所以本篇介绍几个在 A ...
- ASP.NET MVC开发:Web项目开发必备知识点
最近加班加点完成一个Web项目,使用Asp.net MVC开发.很久以前接触的Asp.net开发还是Aspx形式,什么Razor引擎,什么MVC还是这次开发才明白,可以算是新手. 对新手而言,那进行A ...
- UWP开发必备以及常用知识点总结
一直在学UWP,一直在写Code,自己到达了什么水平?还有多少东西需要学习才能独挡一面?我想对刚接触UWP的开发者都有这种困惑,偶尔停下来总结分析一下还是很有收获的! 以下内容是自己开发中经常遇到的一 ...
- C#高级知识点&(ABP框架理论学习高级篇)——白金版
前言摘要 很早以前就有要写ABP高级系列教程的计划了,但是迟迟到现在这个高级理论系列才和大家见面.其实这篇博客很早就着手写了,只是楼主一直写写停停.看看下图,就知道这篇博客的生产日期了,谁知它的出厂日 ...
- lucene 基础知识点
部分知识点的梳理,参考<lucene实战>及网络资料 1.基本概念 lucence 可以认为分为两大组件: 1)索引组件 a.内容获取:即将原始的内容材料,可以是数据库.网站(爬虫).文本 ...
- DoraCMS 源码知识点备注
项目需要研究了下DoraCMS这款开源CMS,真心做的不错:).用的框架是常用的express 4 + mongoose,代码也很规范,值得学习. 源码中一些涉及到的小知识点备注下: https:// ...
- atitit 商业项目常用模块技术知识点 v3 qc29
atitit 商业项目常用模块技术知识点 v3 qc29 条码二维码barcodebarcode 条码二维码qrcodeqrcode 条码二维码dm码生成与识别 条码二维码pdf147码 条码二维码z ...
- HTML5知识点总结
HTML5知识点总结(一) 一.HTML新增元素 1.IE9版本以下支持HTML5的方法 <!--[if lt IE9]> <script src="http://cdn. ...
- JavaScript易错知识点整理
前言 本文是我学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由浅入深的介绍和讲解,其中也涉及了一 ...
- Sqlserver中一直在用又经常被忽略的知识点一
已经有快2个月没有更新博客了,实在是因为最近发生了太多的事情,辞了工作,在湘雅医院待了一个多月,然后又新换了工作...... 在平时的工作中,Sqlserver中许多知识点是经常用到的,但是有时候我们 ...
随机推荐
- java:内存处理ByteArrayOutputStream,ByteArrayInputStream
//用内存,将小写字母替换成大写字母 String str = "helloworld,goodmorning"; ByteArrayOutputStream bos = null ...
- Vue中mixin的用法
在项目中我们经常会遇到多个组件调用同一个方法的问题,为了避免每次都在.vue文件中定义并调用,我们可采用vue的mixin的用法: 具体使用如下: 我们需要在main.js中引入mixins文件夹下的 ...
- 26 python 并发编程之多进程理论
一 什么是进程 进程:正在进行的一个过程或者说一个任务.而负责执行任务则是cpu. 举例(单核+多道,实现多个进程的并发执行): egon在一个时间段内有很多任务要做:python备课的任务,写书的任 ...
- 网络编程基础----并发编程 ---守护进程----同步锁 lock-----IPC机制----生产者消费者模型
1 守护进程: 主进程 创建 守护进程 辅助主进程的运行 设置进程的 daemon属性 p1.daemon=True 1 守护进程会在主进程代码执行结束后就终止: 2 守护进程内无法再开启子进程 ...
- JFreeChart - 简记
一.步骤:(发现另一位博主写的更详细:https://www.cnblogs.com/dmir/p/4976550.html) 创建数据集(准备数据) 根据数据集生成JFreeChart对象,并对其做 ...
- SQL夯实基础(二):连接操作中使用on与where筛选的差异
一.on筛选和where筛选 在连接查询语法中,另人迷惑首当其冲的就要属on筛选和where筛选的区别了,如果在我们编写查询的时候, 筛选条件的放置不管是在on后面还是where后面, 查出来的结果总 ...
- 幸运数字(数位dp)
个人心得:数位dp处理起来是真的麻烦,本来动态规划就够头疼的了,菜的一批. 来看这个题目吧,题目在下面. 把题目变成可以求得就是求前n个数中1-n*9的情况的总和,所以用dp[i][j],表示前i个数 ...
- Unity物体上下反复漂浮效果
using UnityEngine;using System.Collections;// 主界面的开始按钮使用该脚本,控制上下来回浮动public class Floating : MonoBeha ...
- BZOJ4303:数列
浅谈\(K-D\) \(Tree\):https://www.cnblogs.com/AKMer/p/10387266.html 题目传送门:https://lydsy.com/JudgeOnline ...
- 基于springboot+kotlin+gradle构建的框架的坑
项目采用以上技术构建,于是本人就尝试构建自己的脚手架,然后遇到一大推问题. 使用的是springinitials构建,IDE是:IDEA 现在也是知其然不知其所以然,但是先记录下来修改过程,以后等知识 ...