首页 > 编程语言 >C++学习(22)

C++学习(22)

时间:2024-06-19 17:28:48浏览次数:12  
标签:std now 22 chrono int clock C++ 学习 include

#学习自用#

计时

计时可以计算出执行代码时花费了多长时间,对于同样的目的,我们可以通过不同的代码实现,而执行时间长短是评价一串代码性能如何的指标。

#include<iostream>
#include<string>
#include<chrono>
#include<thread>
using namespace std;

int main()
{
	
	auto start=chrono::high_resolution_clock::now();//这个是当前时间  now函数的返回类型std::chrono::steady_clock::time_point
	this_thread::sleep_for(1s);
	auto end = chrono::high_resolution_clock::now();

	std::chrono::duration<float> duration = end - start;
	cout << duration.count() << ' s' << endl;

}

chrono::high_resolution_clock::now();这个是记录当前时间,now函数的返回类型std::chrono::steady_clock::time_point,类型名过长所以用auto,std::chrono::duration<float>设置了结束和开始时间之差的结果float类型,但是这个结果并不能直接用float类型去接收。

#include<iostream>
#include<chrono>
using namespace std;
struct Timer
{
	std::chrono::steady_clock::time_point start, end;
	std::chrono::duration<float> duration;
	Timer()
	{
		start = chrono::high_resolution_clock::now();
	}
	~Timer()
	{
		end = chrono::high_resolution_clock::now();
		duration = (end - start);
		float ms = duration.count() * 1000.0f;
		cout << ms << "ms " << endl;
	}
};

void func()
{
	Timer timer;
	for (int i = 0; i < 100; i++)
	{
		cout << "Hello!\n";
	}
}

int main()
{
	func();
	cin.get();
}

Timer结构体运用了构造函数和析构函数的特性,在创建实例时使用构造函数,在生命周期结束时执行析构函数,只需要在函数开始时创建一个结构体实例,就能计算函数的执行时间,有多个需要计算时间的函数时,使用 Timer 就不需要重复写那几行代码了。

多维数组

多维数组如二维、三维等,在C和C++中的使用都不太方便,内存分配比较复杂,这里只做简单介绍。

#include<iostream>
using namespace std;
int main()
{
	
	int** a2d = new int* [5];
	for (int i = 0; i < 5; i++)
		a2d[i] = new int[5];
	for (int i = 0; i < 5; i++)
		delete[] a2d[i];
	delete[] a2d;
	cin.get();
}

一个n维数组的数组名就相当于一个n级指针,所以在堆上分配二维数组时需要分配两次,第一次分配各一级指针的内存,第二次分配各元素的内存。要回收二维数组的内存也需要迭代,如果先delete[] a2d,会导致找不到各元素的位置,无法使用delete[] a2d[i]可能导致内存泄漏。这里25个元素,我们创建了5个单独的缓冲区,每个缓冲区五个元素,但是缓冲区的位置在内存中是完全随机的,可能很近也可能很远,当我们对元素进行遍历时,必须在内存中跳转到另一个位置来读写数据,这会导致缓存不命中(cache miss),花费大量时间在ram中读取数据,如果是紧密分配在一起的就不会有这样的问题。所以比起多维数组,不如建立一个内存空间大一点的一维数组,一维数组也不需要分配额外的空间来记录5个单独的缓冲区的首元素地址。

排序

std::sort 是C++内置的排序函数,使用sort 要引入头文件algorithm ,sort有三个参数,1.排序起始位置,2.排序结束位置,这两个位置都是需要用迭代器,不能用普通数组只能用模板类,3.排序方式,这个参数可以不填,如果不填默认是升序排序。

#include<iostream>
#include<vector>
#include<algorithm>
#include<functional>
using namespace std;
int main()
{
	vector<int> values = { 3,2,1,5,4 };
	sort(values.begin(), values.end());//默认升序
	for (int value : values)
		cout << value << ',';
	cout<<endl;

	sort(values.begin(), values.end(),greater<int>());//降序
	for (int value : values)
		cout << value << ',';
	cout << endl;

	sort(values.begin(), values.end(), [](int a, int b) {return (a < b); });
	for (int value : values)
		cout << value << ',';

	cin.get();
}

排序方式可以传入模板类,也可以传函数,a和b,如果你先让a排前面就返回true否则返回false。

return (a<b), a<b为真,a就排前面,所以是升序排列,如果是return (a>b),a>b为真,a排前面所以为降序,这也是greater的原理。

标签:std,now,22,chrono,int,clock,C++,学习,include
From: https://blog.csdn.net/oddsss/article/details/139798861

相关文章

  • 深度学习原理
    1简介        AIGC(ArtificialIntelligenceGeneratedContent,即人工智能生成内容)是一种利用人工智能技术自动创建文本、图像、音频和视频等内容的技术。AIGC的核心是通过机器学习和深度学习算法,让计算机模型学会理解和生成人类语言,从而能够自动产生有价值的内容。......
  • C/C++ 对文件目录进行操作的常用函数
    在C语言中,对目录进行操作的常用函数主要包括但不限于以下几个:opendir(constchar*name):功能:打开指定路径的目录。返回值:成功时返回一个指向DIR结构体的指针,失败则返回NULL。头文件:<dirent.h>readdir(DIR*dirp):功能:从打开的目录中读取下一个目录条目。返回值:成......
  • DevOps学习回顾02-实践的通用路径-需求分析的拆解-CI的理解-质量体系的实践路径
    参考来源:极客时间专栏:DevOps实战笔记,作者:石雪峰课程链接:https://time.geekbang.org/column/intro/235DevOps学习回顾02-实践的通用路径-需求分析的拆解-CI的理解-质量体系的实践路径DevOps实践的通用路径第一步:寻找合适的试点项目一个合适的项目应该具备以下几个特......
  • 机器学习(一)
    机器学习1.机器学习概述1.1人工智能概述1.1.1机器学习与人工智能、深度学习的关系1.1.2人工智能的起点1.1.3机器学习、深度学习能做什么?1.2什么是机器学习?1.2.1定义1.2.2数据集的构成1.3机器学习算法1.4机器学习开发流程2.特征工程2.1数据集2.1.1可用数据......
  • nodejs学习08——会话控制 session cookie token
    会话控制一、介绍所谓会话控制就是对会话进行控制HTTP是一种无状态的协议,它没有办法区分多次的请求是否来自于同一个客户端,无法区分用户而产品中又大量存在的这样的需求,所以我们需要通过会话控制来解决该问题常见的会话控制技术有三种:cookiesessiontoken二、cooki......
  • 莫比乌斯反演学习笔记
    \[\]前段时间学习了莫比乌斯反演,现在补一篇学习笔记吧。Step1:莫比乌斯函数首先我们来定义一下莫比乌斯函数\(\mu\),它的取值如下:\[\mu(n)=\left\{ \begin{array}{ll} 1\qquad\quadn=1\\ (-1)^k\quadn=p_1p_2\cdotsp_k\\ 0\qquad\quadotherwise \end{array}......
  • 筛法学习笔记
    0.更新upd2023.5.21更新了关于powerfulnumber数量的证明upd2023.5.25更新了关于杜教筛的时间复杂度证明正文1.筛质数筛法其实就是判断质数的一个算法,但是是解决\([1,n]\)这一段区间的算法筛质数是最简单的一个用法1.1暴力最简单的方式就是对于每一个数去判断......
  • 狄利克雷卷积学习笔记
    0.更新upd2023.5.18更新了狄利克雷卷积新的一个性质,更新了常用结论的证明1.正文这玩意儿是这么说的:定义一个运算:$*$为狄利克雷卷积。他是干啥的呢?把两个数论函数进行一个运算。\[h(n)=(f*g)(n)=\sum_{d|n}f(d)g(\frac{n}{d})\]当\(f,g\)都是积性函数时,他们的狄利......
  • Cisco ASAv 9.20.2.22 Interim - 思科自适应安全虚拟设备 (ASAv)
    CiscoASAv9.20.2.22Interim-思科自适应安全虚拟设备(ASAv)CiscoAdaptiveSecurityVirtualAppliance(ASAv)请访问原文链接:https://sysin.org/blog/cisco-asav/,查看最新版。原创作品,转载请保留出处。作者主页:sysin.org思科自适应安全虚拟设备(ASAv):跨物理和虚拟环......
  • Cisco ASA 9.20.2.22 Interim - 思科自适应安全设备 (ASA) 软件
    CiscoASA9.20.2.22Interim-思科自适应安全设备(ASA)软件CiscoAdaptiveSecurityAppliance(ASA)请访问原文链接:https://sysin.org/blog/cisco-asa/,查看最新版。原创作品,转载请保留出处。作者主页:sysin.org思科自适应安全设备(ASA)软件成熟的防火墙和网络安全平......