• c++ 陷阱


    .c89 c90 gnu90 c99 c11 c++98( default ) c++03 c++11 gnu++11


    bool
    C 标准 does not support the boolean data type. include it with this include: #include <stdbool.h>
    c++ 标准都支持



    extern
        可以置于变量或者函数前,以标示变量或者函数的定义在别的文件中,提示编译器遇到此变量和函数时在其他模块中寻找其定义。此外extern也可用来进行链接指定。
        extern有两个作用,第一个,当它与"C"一起连用时,如: extern "C" void fun(int a, int b);则告诉编译器在编译fun这个函数名时按着C的规则去翻译相应的函数名而不是C++的,C++的规则在翻译这个函数名时会把fun这个名字变得面目全非,可能是fun@aBc_int_int#%$也可能是别的,这要看编译器的"脾气"了(不同的编译器采用的方法不一样),为什么这么做呢,因为C++支持函数的重载。
        第二,当extern不与"C"在一起修饰变量或函数时,如在头文件中: extern int g_Int; 它的作用就是声明函数或全局变量的作用范围的关键字,其声明的函数和变量可以在本模块活其他模块中使用,记住它是一个声明不是定义!也就是说B模块(编译单元)要是引用模块(编译单元)A中定义的全局变量或函数时,它只要包含A模块的头文件即可,在编译阶段,模块B虽然找不到该函数或变量,但它不会报错,它会在连接时从模块A生成的目标代码中找到此函数。



    for(int i=0;;)
    ‘for’ loop initial declarations aren't only allowed in C89 c90 gnu90 mode
    c++ 标准都支持



    数组元素大小是否是 const
    c 和 c++ 所有常见标准均支持用变量来初始化数组的大小。



    Segmentation fault (core dumped)
    段错误
    1、出现段错误时,首先应该想到段错误的定义,从它出发考虑引发错误的原因。
    2、在使用指针时,定义了指针后记得初始化指针,在使用的时候记得判断是否为NULL。
    3、在使用数组时,注意数组是否被初始化,数组下标是否越界,数组元素是否存在等。
    4、在访问变量时,注意变量所占地址空间是否已经被程序释放掉。
    5、在处理变量时,注意变量的格式控制是否合理等。
    http://www.cnblogs.com/panfeng412/archive/2011/11/06/segmentation-fault-in-linux.html
    scanf("%d",&a); 不是 scanf("%d",a);



    char str[2]="hello world!";            字符数超出数组大小,默认会截取数组大小的字符,并且 str[1] 中存放的不是 '' 而是 'e', 这样定义的数组在操作时结果是未定义的,将字符串赋值给数组时结尾必须是 ''

    数组越界访问不会报错,结果是为定义的。



    stray ‘342’ in program
    标点符号错误



    incompatible implicit declaration of built-in function ‘printf’
    没有引用相应的头文件
    printf            stdio
    exit            stdlib
    _exit            unistd



    implicit declaration of function ‘getline’ [-Wimplicit-function-declaration]
    使用的函数要申明
    extern ssize_t getline(char **lineptr, size_t *n, FILE *stream);



    initialization makes pointer from integer without a cast
    int *p = 2;
    给指针直接赋具体值会出错,应该让指针指向一个变量。



    函数返回值为 char* ,不能将数组作为左值,因为数组名相当于常量字符指针。



    不能直接将字符串赋值给字符数组,但是可以用 read 和 write 函数来向字符数组中写入值;输出数组时只输出有值的部分。
    char arr[10] = "hel";
    arr = "exit";            //this is wrong!



    不能将字符指针重新指向新的字符指针。
    char *buf_1 = "hell";
    buf_1 = "hel";            //this is wrong!



    用 read/write 从终端读入文件时,如果输入的字符串在缓冲区中没有被读取完,程序结束后缓冲区剩下的内容会作为命令在 shell 中自动执行此命令。



    dereferencing pointer to incomplete type
    使用结构体指针是用符号 ->


    使用动态库时,生成可执行文件,但执行时出错:
    原因是程序找不到动态库,将动态库路径添加到环境变量 LD_LIBRARY_PATH 中即可。


    字符串结束符不要使用 ,而需要使用自定义的 EOF。


    整形不能直接转换为字符型,如果需要遍历整形的每一位,可用除运算和模运算结合的方法。
    除法去掉低位,模 10 得到个位数。

  • 相关阅读:
    java web分页查询初试
    SQL注入原理深度解析
    JS 清除IE缓存
    Android 代码混淆及第三方jar包不被混淆
    [leetcode]Unique Paths II
    ffmpeg API录制rtsp视频流
    HDU 2045 不容易系列之(3)—— LELE的RPG难题
    Ffmpeg和SDL创建线程(转)
    “富豪相亲大会”究竟迷失了什么?
    Ffmpeg和SDL如何同步视频(转)
  • 原文地址:https://www.cnblogs.com/little-snake/p/4925697.html
Copyright © 2020-2023  润新知