复制空指针到另一个空指针?

时间:2019-05-09 12:44:45

标签: c pointers malloc heap-memory void-pointers

我正在尝试将void指针复制到另一个指针数组的不同索引,对于字符来说一切正常,但是对于整数和双精度出现问题

这是我的结构:

typedef struct vector_struct {
 size_t e_sz;
 char e_type;

 #define V_INT 1 
 #define V_DOUBLE 2
 #define V_CHAR 3

 unsigned no_e;
 unsigned cur_cap;
 void* e_array;

}* vector_type;
 //for typecasting
  #define vector_int_at(v,i) (*((int*)v_at(v,i)))
  #define vector_double_at(v,i) (*((double*)v_at(v,i)))
  #define vector_char_at(v,i) (*((char*)v_at(v,i)))

  void* v_at(vector_type v, iterator i) {
    if ( v == NULL )
     fail("v_at() Error: no such vector");
    if ( i == iterator_end )
     i = v->no_e -1;
    if ( i < 0 || i >= v->no_e )
     fail("v_at() Error: no such element in this vector");
    return (v->e_array+i); //return element
   }

我想将值复制到void* e_array中,它可以是整数,字符或双精度数。

void v_push_back(vector_type v, void* new_val){
 if ( v->no_e >= v->cur_cap ) {
    /*** need to expand the array ***/
    v->cur_cap += (v->cur_cap)? v->cur_cap : 2;

    v->e_array = check_a(realloc(v->e_array, sizeof(void*) * v->cur_cap));
    //allocate memory

   }
/*** copy new_val into the array at end position (v->no_e) ***/
   printf("%d  %d %p\n",v->e_sz,v->no_e,v->e_array+(v->no_e *v->e_sz));
    memcpy(
          v->e_array +(v->no_e)*v->e_sz,
          new_val,
          v->e_sz
          );

 (v->no_e)++;
}

我这样调用此函数:

c1 = 'o'; v_push_back(vc1,(void*)&c1); //for character
for ( i1 = 0 ; i1 < 10 ; i1++ ){ //for integer
    v_push_back(vi1,(void*)&i1);
}

//I call these like
  for ( i1 = 0 ; i1 < vector_size(vi1) ; i1++ )
   printf(" %ld",vector_int_at(vi1,i1));
  printf("\n");

但是似乎事情对于整数不起作用,但对于字符却很好,但是对于整数,垃圾值被复制,如下所示: enter image description here

请帮帮我。谢谢

这是完整的项目: https://s3.amazonaws.com/assignment.pointers.vectorc.implementation/C-VectorImplementation1.zip

1 个答案:

答案 0 :(得分:1)

我看到的几个问题

  1. 为了获取当前向量类型的第i个位置,您需要将iv->e_sz相乘。

    void* v_at(vector_type v, iterator i)
    {
        .....
        return ((char*)v->e_array+i*v->e_sz); //return element    
    }
    
  2. 您正在分配sizeof(void *)您想要的是

     v->e_array = check_a(realloc(v->e_array, v->e_sz * v->cur_cap));
    
  3. 到目前为止,您还将地址存储为int,但需要存储其值。

    void v_push_back(vector_type v, void* new_val){
         if(v->e_type==V_INT){
            //  (v->e_array+(v->no_e))=new_val;
            ((int*)v->e_array)[v->no_e]=*(int*)new_val;
                                        ^------storing its content
         }
    }
    

    没有任何类型检查,简单的memcpy应该可以工作。

    void v_push_back(vector_type v, void* new_val){
        ....
        memcpy(
              v->e_array +(v->no_e)*v->e_sz,
              new_val,
              v->e_sz
              );
           //   *(char*)(v->e_array+v->no_e)=*(char*)new_val;
    
         (v->no_e)++;
     }