博客
关于我
C++基础知识学习,指针传递,类和结构体的区别,类的标准写法
阅读量:554 次
发布时间:2019-03-09

本文共 1135 字,大约阅读时间需要 3 分钟。

指针传递与C++类的基因素

在C语言编程中,传递数据作为指针是一种非常常见的操作方式。结构体也支持指针的传递方式,该题通过实例动态讲解指针传递的实现方法及其注意事项。

结构体指针传递

对于结构体数据成员的指针操作方式与普通数据类型存在一定差异。在C语言中,结构体指针的 operate behaves quite differently when comparing to simple data types. 结构体的指针操作类似于普通数据类型的操作,具体实现方式请参考下面示例:

struct student {    int id;    char name[100];};void func1(student* ptr) {    ptr->id = 2;    strcpy_s(ptr->name, sizeof(ptr->name), "william_x_f_wang");}

识别关键点

  • 结构体作为数据类型需使用struct关键字前缀定义

  • 结构体变量的获取方式与数组类似,这一点需要注意

  • 当结构体作为函数参数传递时,需传递其地址(即使用&符号)

  • 类与结构体的比较

    结构体与类的最大区别在于访问权限设定。默认情况下,C语言的结构体成员设定为public,而类在C++中默认设定为private。这一概念性差异让我意识到,类似AKA大小写之分。

    两种数据结构在什么情况下使用

  • 仅包含成员变量:结构体是更简单的选择

  • 包含成员函数:类是理想选择

  • 类组件与实现

    C++中的类具有以下特点:

  • 类定义式先出现在.h文件中,类名保持一致

  • 类实现式书写在.cpp文件中

  • 类名由开发者自己总结命名空间环境

  • 通过以上描述,可以清楚地看到,类在面向对象编程中的优势。这种结构使得完整性和隐藏内部实现变得容易实现。

    此处重要提示,指针形式在C++中是首选选择方式。值得注意的是在使用strcpy_s函数时需正确估算数组长度。

    整个程序体例如下:

    student myStudent;myStudent.id = 1;strcpy_s(myStudent.name, sizeof(myStudent.name), "william_x_f_wang");func1(&myStudent);

    经测试,该程序能够正常运行且遵循传统的函数编程风格。

    在编写C++代码时,其中关于指针操作仍存在一定的困惑。为了协调结构化使用习惯,建议从基础出发逐步积累自给自足的开发技能。

    通过以上实例说明,可以看出,在编写C程序代码时,结构体与类的选择以及指针操作方式有着直接影响整个程序的体态和设计风格。

    这种细节处理反映在代码书写习惯和问题解决方式中。需要强调的是,代码注释应当的问题呈现方式。

    转载地址:http://dgesz.baihongyu.com/

    你可能感兴趣的文章
    nodejs 运行CMD命令
    查看>>
    nodejs-mime类型
    查看>>
    NodeJS、NPM安装配置步骤(windows版本)
    查看>>
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    nodejs包管理工具对比:npm、Yarn、cnpm、npx
    查看>>
    NodeJs单元测试之 API性能测试
    查看>>
    nodejs图片转换字节保存
    查看>>
    nodejs字符与字节之间的转换
    查看>>
    NodeJs学习笔记001--npm换源
    查看>>
    NodeJs学习笔记002--npm常用命令详解
    查看>>
    nodejs封装http请求
    查看>>
    nodejs开发公众号报错 40164,白名单配置找不到,竟然是这个原因
    查看>>
    Nodejs异步回调的处理方法总结
    查看>>
    Nodejs教程09:实现一个带接口请求的简单服务器
    查看>>
    nodejs服务端实现post请求
    查看>>
    nodejs端口被占用原因及解决方案
    查看>>
    Nodejs简介以及Windows上安装Nodejs
    查看>>
    nodejs系列之express
    查看>>
    nodejs系列之Koa2
    查看>>
    Nodejs连接mysql
    查看>>