总是用指针太头疼?这两个自定义函数会简化一些

#include <iostream>


//我写了两个个新函数

int addressOut(int *p){
    
    return *p;
}


// 创建一个新指针,指向一个动态分配的整数,并初始化为给定值
int* addressIn(int value) {
    // 使用new操作符动态分配内存,并返回指向该内存的指针
    return new int(value);
}

int main() {
    
    int num = 10;
     // 输出这个新整数的值 
    std::cout << addressOut(&num)<< std::endl;

    int *ptr =addressIn(20);
   // 输出这个新整数的地址
    std::cout << ptr<< std::endl; 
    
    // 记住要释放动态分配的内存,避免内存泄漏
    delete ptr;
    
    /*代替传统的
    int *p= &num;(这种写法容易引起误解,特别是新手,认为是把&num赋值给了*p,但实际上是赋值给p,只是利用*进行解引用)
     std::cout << *p<< std::endl;   
    */
   
return 0;
}

展示了两个重要的C++概念:动态内存分配和指针的使用。这里是你代码中定义的两个函数及其作用,以及main函数中的使用方式:

addressOut 函数

 
cppint addressOut(int *p) {
return *p;
}
  • 功能:这个函数接受一个指向整数的指针p作为参数,并返回该指针所指向的整数的值。
  • 使用:在main函数中,通过传递num的地址给addressOut函数,并输出返回的值(即num的值,这里是10)。

addressIn 函数

 
cppint* addressIn(int value) {
return new int(value);
}
  • 功能:这个函数接受一个整数value作为参数,并使用new操作符动态地在堆上分配一个整数大小的内存,将value初始化这块内存,并返回指向这块内存的指针。
  • 使用:在main函数中,通过调用addressIn(20)动态地分配了一个整数,其值为20,并将返回的指针赋值给ptr。然后,输出了这个指针的值(即新分配的内存的地址)。

main 函数中的其他要点

  • 你正确地使用了delete ptr;来释放通过addressIn函数动态分配的内存,这是防止内存泄漏的重要步骤。
  • 你还提到了使用指针时的一个常见误解,即int *p = &num;这行代码实际上是将num的地址赋值给指针p,而不是将&num赋值给*p。这里的*是解引用操作符的前缀,但它在这里并不执行解引用操作,而是作为指针声明的一部分。

完整性和安全性

你的代码展示了如何安全地使用指针和动态内存分配。确保在使用完动态分配的内存后释放它,是避免内存泄漏的重要实践。同时,通过函数封装动态内存分配的逻辑,可以使代码更加模块化和易于管理。

总结

你的代码示例清晰地展示了C++中指针和动态内存分配的基本用法,以及如何通过函数来封装这些操作。这是一个很好的学习C++指针和内存管理的例子。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天若有情673

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值