C、C++动态分配函数暨几种参数传递疑难解析

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介:

C语言的动态分配函数

malloc(m):开辟m字节长度的地址空间,并返回这段空间的首地址

sizeof(x):计算变量x的长度

free(p):释放指针p所指变量的存储空间,即彻底删除一个变量

C++的动态存储分配

new 类型名T(初值列表)
功能:申请用于存放T类型对象的内存
int *p1=new int;
或 int *p1=new int(10);
结果值:
成功:T类型的指针,指向新分配的内存
失败:0(NULL)
delete 指针p
功能:释放指针P所指向的内存。P必须是new操作的返回值

C++中的参数传递

函数调用时传送给形参表的实参必须与形参在类型、个数、顺序上保持一致
参数传递有两种方式

  • 传值方式(参数为整型、实型、字符型等)
  • 传地址
    • 参数为指针变量
    • 参数为引用类型
    • 参数为数组名

传值方式

  • 把实参的值传递给函数局部工作区相应的副本中,函数使用
  • 这个副本执行必要的功能。函数修改的是副本的值,实参的值不变

    void swap(float m,float n)
    {
    float temp;
    temp=m;
    m=n;
    n=temp;
    }

传地址方式—指针变量作为参数

void swap1(float *m,float *n)
{
//形参变化影响实参
float t;
t=*m;
*m=*n;
*n=t;
}

传地址方式—指针变量作参数

void swap2(float *m,float *n)
{
   //形参变化不影响实参,只改变两个值的地址,值并没有变
    float *t;

    cout<<n<<m<<endl;
    t=m;

    m=n;
    n=t;
    cout<<n<<m<<endl;
}

传地址方式—引用类型作参数

void swap3(float &m,float &n)
{
float temp;
temp=m;
m=n;
n=temp;
}

// 主函数main()
int main(int argc, const char * argv[]) {         
float a,b;
cin>>a>>b;
swap(a,b);
  float a,b,*p1,*p2;
cin>>a>>b;
p1=&a;p2=&b;
swap1(p1, p2);
  float a,b,*p1,*p2;
cin>>a>>b;
p1=&a; p2=&b;
swap2(p1,p2);
   cout<<a<<endl<<b<<endl;
   // 引用:它用来给一个对象提供一个替代的名字
     float a,b;
cin>>a>>b;
swap3(a, b);
cout<<a<<endl<<b<<endl;
return 0;
}       

传地址方式—-数组名作参数

  • 传递的是数组的首地址
  • 对形参数组所做的任何改变都将反映到实参数组中

     #include  <iostream>
    using namespace std;
    void sub(char b[]);
    
    int main(int argc, const char * argv[]) {
    char a[10]="hello";
    sub(a);
    cout<<a<<endl;
    return 0;
    }
    void sub(char b[])
    {     
    for (int i=0;i<9;i++) {
       b[i]='d';
    }
    }
    

引用类型作参数的三点说明

  • 传递引用给函数与传递指针的效果是一样的,形参变化实参也发生变化。

  • 引用类型作形参,在内存中并没有产生实参的副本,它直接对实参操作;而一般变量作参数,形参与实参就占用不同的存储单元,所以形参变量的值是实参变量的副本。因此,当参数传递的数据量较大时,用引用比用一般变量传递参数的时间和空间效率都好。

  • 指针参数虽然也能达到与使用引用的效果,但在被强调函数中需要重复使用“ *指针变量名”的形式进行运算,这很容易产生错误和程序的阅读性较差;另一方面,在主调函数的调用处,必须用 变量的地址作为实参
目录
相关文章
|
20天前
|
编译器 C++ 容器
【C++】String常见函数用法
【C++】String常见函数用法
13 1
|
28天前
|
C++
c++常见函数及技巧
C++编程中的一些常见函数和技巧,包括生成随机数的方法、制表技巧、获取数字的个位、十位、百位数的方法、字符串命名技巧、避免代码修改错误的技巧、暂停和等待用户信号的技巧、清屏命令、以及避免编译错误和逻辑错误的建议。
18 6
|
28天前
|
存储 C++
c++学习笔记05 函数
C++函数使用的详细学习笔记05,包括函数的基本格式、值传递、函数声明、以及如何在不同文件中组织函数代码的示例和技巧。
27 0
c++学习笔记05 函数
|
27天前
|
存储 C++
【C/C++学习笔记】string 类型的输入操作符和 getline 函数分别如何处理空白字符
【C/C++学习笔记】string 类型的输入操作符和 getline 函数分别如何处理空白字符
30 0
|
1月前
|
Dart 编译器 API
Dart ffi 使用问题之在C++线程中无法直接调用Dart函数的问题如何解决
Dart ffi 使用问题之在C++线程中无法直接调用Dart函数的问题如何解决
|
1月前
|
存储 算法 搜索推荐
【C++】类的默认成员函数
【C++】类的默认成员函数
|
1月前
|
JavaScript C++
【C++ visual studio】解决VS报错:error C2447: “{”: 缺少函数标题(是否是老式的形式表?)【亲测有效,无效捶我】
【C++ visual studio】解决VS报错:error C2447: “{”: 缺少函数标题(是否是老式的形式表?)【亲测有效,无效捶我】
|
18天前
|
监控 网络协议 Java
Tomcat源码解析】整体架构组成及核心组件
Tomcat,原名Catalina,是一款优雅轻盈的Web服务器,自4.x版本起扩展了JSP、EL等功能,超越了单纯的Servlet容器范畴。Servlet是Sun公司为Java编程Web应用制定的规范,Tomcat作为Servlet容器,负责构建Request与Response对象,并执行业务逻辑。
Tomcat源码解析】整体架构组成及核心组件
|
1月前
|
存储 NoSQL Redis
redis 6源码解析之 object
redis 6源码解析之 object
53 6
|
3天前
|
存储 缓存 Java
什么是线程池?从底层源码入手,深度解析线程池的工作原理
本文从底层源码入手,深度解析ThreadPoolExecutor底层源码,包括其核心字段、内部类和重要方法,另外对Executors工具类下的四种自带线程池源码进行解释。 阅读本文后,可以对线程池的工作原理、七大参数、生命周期、拒绝策略等内容拥有更深入的认识。
什么是线程池?从底层源码入手,深度解析线程池的工作原理

推荐镜像

更多