实战篇 | 22 C++ 高性能计算—运算加速

小知识:如何取存在数组中的元素指针怎么样处理需要放在一个容器里放在元素的指针,那个指针该怎么取出来?我们先来看一段代码 咋看起来没什么问题,可是当程序运行之后,你会发现输出来的东西完全不是你想用的,为什么 在上面这个for循环中,我创建了一个局部变量student,然后我把这个student push到一个vector里,这其实是一次拷贝。然后我把这个指针的地址存到另一个v...
摘要由CSDN通过智能技术生成

小知识:如何取存在数组中的元素指针

怎么样处理需要放在一个容器里放在元素的指针,那个指针该怎么取出来?

我们先来看一段代码

咋看起来没什么问题,可是当程序运行之后,你会发现输出来的东西完全不是你想用的,为什么

在上面这个for循环中,我创建了一个局部变量student,然后我把这个student push到一个vector里,这其实是一次拷贝。然后我把这个指针的地址存到另一个vector studentPointer里面。

可是当这个循环结束,局部变量student就会被释放,所以当我们用指针访问这个地址的时候,它就是野指针,输出的内容是不确定的,因为我们不知道这块内存被如何利用。
所以,其实我们是没有办法实现保存局部变量的指针的,是不能这样做的。

那我们的目的是把每一个元素的数组的指针保存到另外一个数组里面去,我怎么做呢?

可是打印出来并不是我们想要的内容,这里面有一个坑,

因为vector他是自动伸缩的,当我们向students里面存第一个元素的时候,它的内容是s1,地址是2000,所以我把2000这个地址存到studentsPointer里面,这是没有问题的。

可是当我在存第二个元素的时候,students发现空间不够了,所以他会再找一块能存两个元素的内存,把我们这两个元素放进去,把原来的那块内存删除,可是我们studentPointers里面还是存的那块元素的地址呀,于是就会出现野指针,找不到真正的元素。

那么如何解决这个问题呢,申请一块空间足够的内存,这样,vector就不会寻找新的内存了。

此时打印的结果是正确的。

完整代码示例:

#include <iostream>
#include <vector>
#include <string>

class Student {
public:
    Student(const std::string& name, int age): _name(name), _age(age) {

    }

    const std::string& GetName() const {
        return _name;
    }

    int GetAge() const {
        return _age;
    }

private:
    std::string _name;
    int _age;
};

int main(int argc, const char * argv[]) {
    std::vector<Student> students;
    std::vector<Student*> studentPointers;

    students.reserve(10);

    for (int i = 0; i < 10; ++ i) {
        // to_string :int convert to string
        Student student(std::string("s") + std::to_string(i), 20 + i);
        students.push
  • 22
    点赞
  • 90
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
课程解决的问题: 作为游戏行业或者图形学从业者,你是否面临以下问题: 到底openGL底层如何实现的? 到底矩阵操作变换是怎么做到的? 到底光栅化的算法以及原理是什么? 到底如何才能从3D世界投射到2D屏幕呢? 图形学有这么多的矩阵操作,到底如何推导如何应用呢? 学完这门课程,你应该就可以从底层了解一个初级的openGL图形接口如何实现,图形学最底层的封装到底面临哪些挑战;跟随我们一行一行写完代码,你就会得到一个迷你版本的openGL图形库,你可以深度体会图形从模型变换,观察矩阵变换,投影矩阵变换一直到光栅化纹理操作的全套模拟流程。 课程介绍: 本课程将带领学员不使用任何图形库,实现从0到1的图形学接口封装以及算法讲解,并且带领大家手敲代码,一行一行进行实现。 涵盖了(环境搭建,绘制点,Bresenham算法绘制完美直线,三角形拆分绘制算法,颜色插值算法,图片操作,图片二次插值放缩算法,纹理系统接口搭建及封装,矩阵操作理论以及实践,openGL类似接口封装,3D世界的图形学理论及接口封装等) 最终将带领大家通过C++实现一个3D世界的图形接口,方便所有人入门图形学,进行接下来的openGL接口以及GPU编程的学习   本课程为系列课程的第一步入门,且带领所有人进行实现,更加实用,可以让大家打牢图形学的基础知识及编程技能
《GPU高性能编程CUDA实战》是一本介绍GPU编程技术的实用指南。它以CUDA(Compute Unified Device Architecture)为核心,向读者展示如何利用GPU的并行计算能力来加速各种应用程序。 本书首先对GPU架构和CUDA编程模型进行了全面介绍,并讲解了CUDA的基本概念和编程原理。读者可以从中了解到GPU相对于传统CPU的优势,以及如何利用CUDA进行高效的并行编程。 接着,书中详细讲解了CUDA的编程语言和工具。读者将学会如何使用CUDA C/C++来编写并行计算的代码,并通过实际案例演示了如何调试和优化CUDA程序。此外,本书还介绍了NVIDIA的性能分析工具和CUDA GPUs的内存管理技巧,帮助读者更好地利用GPU的性能。 《GPU高性能编程CUDA实战》的一个重要特点是它提供了大量的实例代码和实战案例。通过这些案例,读者可以了解到如何用CUDA来加速图像处理、矩阵运算、深度学习等各种应用。这些示例代码都经过优化和测试,读者可以直接运行和验证,并通过它们来学习和实践CUDA编程技术。 总之,《GPU高性能编程CUDA实战》是一本很好的学习资源,特别适合对并行计算和GPU编程感兴趣的开发人员和研究者。通过阅读本书,读者可以系统地了解CUDA编程的基本概念和技术,并通过实战案例来提高自己的GPU编程能力。无论是想加速现有应用程序,还是开发新的GPU应用,都能从这本书中获得很多实用的知识和经验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值