• struct和union分析实例


    1.#include <stdio.h>
    #include <malloc.h>

    typedef struct _soft_array
    {
        int len;
        int array[];
    }SoftArray;

    int main()
    {  
        int i = 0;
        SoftArray* sa = (SoftArray*)malloc(sizeof(SoftArray) + sizeof(int) * 10);
        
        sa->len = 10;
        
        for(i=0; i<sa->len; i++)
        {
            sa->array[i] = i + 1;
        }
        
        for(i=0; i<sa->len; i++)
        {
            printf("%d ", sa->array[i]);   
        }
        
        free(sa);
        
        return 0;
    }

    2.#include <stdio.h>
    #include <malloc.h>

    typedef struct _soft_array
    {
        int len;
        int array[];
    }SoftArray;

    SoftArray* create_soft_array(int size)
    {
        SoftArray* ret = NULL;
        
        if( size > 0 )
        {
            ret = (SoftArray*)malloc(sizeof(*ret) + sizeof(*(ret->array)) * size);
            
            ret->len = size;
        }
        
        return ret;
    }

    void fac(SoftArray* sa)
    {
        int i = 0;
        
        if( NULL != sa )
        {
            if( 1 == sa->len )
            {
               sa->array[0] = 1;
            }
            else
            {
                sa->array[0] = 1;
                sa->array[1] = 1;
                
                for(i=2; i<sa->len; i++)
                {
                    sa->array[i] = sa->array[i-1] + sa->array[i-2];
                }
            }
        }
    }

    void delete_soft_array(SoftArray* sa)
    {
        free(sa);
    }

    int main()
    {
        int i = 0;
        SoftArray* sa = create_soft_array(10);
        
        fac(sa);
        
        for(i=0; i<sa->len; i++)
        {
            printf("%d ", sa->array[i]);
        }
        
        delete_soft_array(sa);
        
        return 0;
    }

  • 相关阅读:
    SpringBoot 项目瘦身
    对比两个文本的异同
    Spring 事务不起作用的场景
    Controller 层数据校验实现思路
    Notify 类的实现思路
    backup: 使用 vim 时一定会用到的设置 --for-myself
    exercise: 反射获取指定的属性值 --CSharp
    exercise: 序列化和反序列化Xml --CSharp
    前缀
    华罗庚的数学思想
  • 原文地址:https://www.cnblogs.com/wxb20/p/6145881.html
Copyright © 2020-2023  润新知