• 编程拾穗


    • 在使用scanf()函数的时候,在如下使用方法时
    int tmp;
    scanf("%d",&tmp);//scanf读取正确返回1,错误返回0

    如果在标准输入中输入的是字符(串)而非数字,标准输入中就会有字符缓存,这个时候就会出现问题,一些情况下会出现死循环(你再次调用scanf函数时,就不会执行),那就需要清空标准输入缓存,C标准规定fflush()函数是用来刷新输出(stdout)缓存的。对于输入(stdin),它是没有定义的。但是有些编译器也定义了fflush( stdin )的实现,比如微软的VC,但GCC中并没有定义,在GCC中可以使用函数setbuf(stdin,NULL)。还有一个方法就是用fgets() 或者getchar()函数读取缓冲区的字符。


    不要对申请的内存或者还要使用原地址的指针进行 自加 或者 自减 行为

    在<深入理解指针>中就有提到,一些情况下对指针进行 ++ 或者 -- 行为会造成不可预测的结果。结果用的时候还是犯了此错误,记一下:

    vector<int> arID;
    arID.push_back(
    12); arID.push_back(12); int* pInt = new int[arID.size()]; cout << pInt << endl; //Address : 0x2591c20 std::vector<int>::iterator it = arID.begin(); for ( ;it != arID.end();it++) { *(pInt++) = *it; } cout << pInt << endl; //Address : 0x2591c34 delete[]pIntCtrolLsh; //Segmentation fault (core dumped)
    vector<int> arID;
    arID.push_back(12); 
    arID.push_back(12); 
    int* pInt = new int[arID.size()];
    int* p_mInt = pInt;
    cout << pInt << endl;   //Address : 0x2591c20 
    std::vector<int>::iterator it = arID.begin();
    for ( ;it != arID.end();it++)
    {
       *(p_mInt++) = *it;
    }
    cout << pInt << endl; //Address : 0x2591c20
    delete[]pIntCtrolLsh; //Correct delete the  pointer

    这就是问题所在,new出来的堆内存是要进行释放的,从申请出来开始,就尽可能的不要修改这个指针的值,若对其内存区域进行读写,可设置一个临时指针,从而避免了后续对new出的指针进行操作造成的错误。问题很小,但真的考验细节啊,要细心


     初始化结构体问题:

    有用的连接: C语言基础及指针⑦结构体与指针  关于结构体成员变量初始化的一些资料

    在写代码时,定义了一个结构体,并进行了初始化:

    typedef struct{
        char md5[32];
        int flag;
    } Tinner;
    
    Tinner *St_A; //结构体指针的正确用法如下
    Tinner St;
    strcpy(St.md5,"aaaaa");
    St.flag = 1;
    St_A = St;

    结构体传参数:

    在写对接模块的时候,上级模块传来一结构体指针,为了能够避免许多隐藏问题,我直接对这个结构体指针进行内存拷贝(memcpy),也严格按照memcpy的用法使用了,但程序还是莫名的崩掉,后排查得知,对其中一个传来的结构体为NULL的参数进行了内存拷贝,这直接导致线程崩溃。故,在对地址进行操作之前,要进行地址判空,之后再进行地址操作,要养成这个习惯。

  • 相关阅读:
    数据库之小问题
    网络基础
    react-fiber 解析
    【like-react】手写一个类似 react 的框架
    istat menus 序列号
    Git学习
    JavaScript设计模式与开发实践【第一部分】
    javascript 原生bind方法实现
    requirejs 学习
    mac 安装maven+eclipse
  • 原文地址:https://www.cnblogs.com/gardenofhu/p/7041351.html
Copyright © 2020-2023  润新知