vim编辑C++代码寻找标准库中结构的的定义

简介:

 编写代码时,有时候需要找到某个结构的定义,例如类型,成员变量名.首先使用gcc -E file.cpp -o file.ii进行预编译,然后使用more命令打开file.ii,可以看到所有预编译的头文件所在的全路径.

打开相应的头文件,找到相应的结构成员.不过标准库中的有些结构使用宏,不是那么直观,这很讨厌,下面以bind函数使用的socketaddr这个结构为例.下面是代码(部分):
#include <stdlib.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <netinet/in.h>
#include <unistd.h>
int main()
{
        printf("this is test server\r\n");
        int serversockd = socket(AF_UNIX,SOCK_STREAM,0);
 
        struct sockaddr serveraddr;
        serveraddr.sa_family = AF_UNIX;
        strcpy(serveraddr.sa_data,"10.1.1.26");
        int ret = bind(serversockd, &serveraddr, sizeof(serveraddr));
        if (0 != ret )
                printf("Error \r\n");
        ...
}
使用gcc -E file.cpp -o file.ii命令,然后打开file.ii,应该能够看到很多头文件的全路径路径,下面是几个例子:
...
# 1 "/usr/include/stdlib.h" 1 3 4
# 25 "/usr/include/stdlib.h" 3 4
# 1 "/usr/include/features.h" 1 3 4
# 323 "/usr/include/features.h" 3 4
# 1 "/usr/include/bits/predefs.h" 1 3 4
# 324 "/usr/include/features.h" 2 3 4
# 356 "/usr/include/features.h" 3 4
...
可以看到这段代码引用的头文件都在/usr/include及其子目录中,如果不做说明,只说打开文件就指在/usr/include/或其子目录中打开.
 
先看一下socketaddr的定义,<sys/socket.h>中有这么一句,#include <bits/socket.h>,打开bits/socket.h,这个文件中有这么一段:
/* Structure describing a generic socket address.  */
struct sockaddr
  {
    __SOCKADDR_COMMON (sa_);    /* Common data: address family and length.  */
    char sa_data[14];           /* Address data.  */
  };
__SOCKADDR_COMMON是一个宏,这个宏的定义在<bits/sockaddr.h>中,打开该文件,可以看到这么一句:
#define __SOCKADDR_COMMON(sa_prefix) \
  sa_family_t sa_prefix##family
宏替换__SOCKADDR_COMMON (sa_);后的结果就是:sa_family_t sa_family,也就是说struct sockaddr的定义其实是这样的:
struct sockaddr
  {
    sa_family_t sa_family    /* Common data: address family and length.  */
    char sa_data[14];           /* Address data.  */
  };
 
还可以在<sys/un.h>看到sockaddr_un的定义,下面是它的结构:
struct sockaddr_un
  {
    __SOCKADDR_COMMON (sun_);
    char sun_path[108];         /* Path name.  */
  };
它也使用了__SOCKADDR_COMMON.
 
可以在<netinet/in.h>看到sockaddr_in的定义,下面是它的结构:
struct sockaddr_in
  {
    __SOCKADDR_COMMON (sin_);
    in_port_t sin_port;                 /* Port number.  */
    struct in_addr sin_addr;            /* Internet address.  */
 
    /* Pad to size of `struct sockaddr'.  */
    unsigned char sin_zero[sizeof (struct sockaddr) -
                           __SOCKADDR_COMMON_SIZE -
                           sizeof (in_port_t) -
                           sizeof (struct in_addr)];
  };
它也使用了__SOCKADDR_COMMON.











本文转自jetyi51CTO博客,原文链接: http://blog.51cto.com/jetyi/823316 ,如需转载请自行联系原作者



相关文章
|
28天前
|
C++
C++ 语言异常处理实战:在编程潮流中坚守稳定,开启代码可靠之旅
【8月更文挑战第22天】C++的异常处理机制是确保程序稳定的关键特性。它允许程序在遇到错误时优雅地响应而非直接崩溃。通过`throw`抛出异常,并用`catch`捕获处理,可使程序控制流跳转至错误处理代码。例如,在进行除法运算或文件读取时,若发生除数为零或文件无法打开等错误,则可通过抛出异常并在调用处捕获来妥善处理这些情况。恰当使用异常处理能显著提升程序的健壮性和维护性。
42 2
|
21天前
|
算法框架/工具 C++ Python
根据相机旋转矩阵求解三个轴的旋转角/欧拉角/姿态角 或 旋转矩阵与欧拉角(Euler Angles)之间的相互转换,以及python和C++代码实现
根据相机旋转矩阵求解三个轴的旋转角/欧拉角/姿态角 或 旋转矩阵与欧拉角(Euler Angles)之间的相互转换,以及python和C++代码实现
90 0
|
28天前
|
程序员 C++ 开发者
C++命名空间揭秘:一招解决全局冲突,让你的代码模块化战斗值飙升!
【8月更文挑战第22天】在C++中,命名空间是解决命名冲突的关键机制,它帮助开发者组织代码并提升可维护性。本文通过一个图形库开发案例,展示了如何利用命名空间避免圆形和矩形类间的命名冲突。通过定义和实现这些类,并在主函数中使用命名空间创建对象及调用方法,我们不仅解决了冲突问题,还提高了代码的模块化程度和组织结构。这为实际项目开发提供了宝贵的参考经验。
42 2
|
28天前
|
C++
拥抱C++面向对象编程,解锁软件开发新境界!从混乱到有序,你的代码也能成为高效能战士!
【8月更文挑战第22天】C++凭借其强大的面向对象编程(OOP)能力,在构建复杂软件系统时不可或缺。OOP通过封装数据和操作这些数据的方法于对象中,提升了代码的模块化、重用性和可扩展性。非OOP方式(过程化编程)下,数据与处理逻辑分离,导致维护困难。而OOP将学生信息及其操作整合到`Student`类中,增强代码的可读性和可维护性。通过示例对比,可以看出OOP使C++代码结构更清晰,特别是在大型项目中,能有效提高开发效率和软件质量。
20 1
|
22天前
|
C++
C++代码来计算一个点围绕另一个点旋转45度后的坐标
C++代码来计算一个点围绕另一个点旋转45度后的坐标
42 0
|
22天前
|
C++
Resharper c++ 使用Enter自动补全代码
Resharper c++ 使用Enter自动补全代码
28 0
|
29天前
|
编译器 C++
【C/C++学习笔记】C++声明与定义以及头文件与源文件的用途
【C/C++学习笔记】C++声明与定义以及头文件与源文件的用途
28 0
|
29天前
|
监控 编译器 C++
【代码讲解】【C/C++】获取文件最后修改的时间(系统时间)
【代码讲解】【C/C++】获取文件最后修改的时间(系统时间)
33 0
|
27天前
|
Unix Linux 开发工具
在Linux中,有哪些基本的 Vim 命令?
在Linux中,有哪些基本的 Vim 命令?
|
8天前
|
存储 Linux 编译器
linux中vim介绍以及常用命令大全
linux中vim介绍以及常用命令大全
30 8