原:开辟内存时,可以以结构体为单位,这样测试,是对的吧?
原創(chuàng)一個,也不是太確定,有問題希望大家指正了。
#include <stdio.h>
typedef struct complex_float
{
?? ?float real;
?? ?float imag;
}complex_float;
struct ComplexMatrix
{
?? ?int?? num_rows;
??? int?? num_columns;
?? ?complex_float? *data;? // 向量類型,是容器來的,改為普通指針,存取的是地址,指向數(shù)據(jù),對其取值即得到數(shù)據(jù)
??? complex_float? **elements;? // 改為普通指針,指向行向量的指針,存取的是地址,指向地址,對其取值得到地址,再取值,才得到數(shù)據(jù)
??? // float? (*elements)[];
?? ? // Stores temporary copies of |data_| and |elements_| for in-place operations
??? // where referring to original data is necessary.
??? complex_float *scratch_data;? // 改為普通指針
??? complex_float **scratch_elements;? // 改為普通指針,指向行向量的指針
?? ?//float (*scratch_elements)[];? // 改為普通指針,指向行向量的指針
};
// 直接改成成全局函數(shù),通過行和列參數(shù),構(gòu)造一個二維復(fù)數(shù)矩陣,構(gòu)造方式是動態(tài)申請內(nèi)存,后面需要定義內(nèi)存釋放函數(shù)
void Create_ComplexMatrix_row_num(struct ComplexMatrix *p, int num_rows, int num_columns)? // 構(gòu)造函數(shù),二維復(fù)數(shù)矩陣 ?
{
?? ?complex_float *p_temp;
?? ?if ((p_temp = (complex_float *)malloc(num_rows * num_columns * sizeof(complex_float))) == NULL)
?? ?{
?? ??? ?printf("malloc error\n");
?? ??? ?return p_temp;
?? ?}
?? ?p->num_rows = num_rows;
?? ?p->num_columns = num_columns;
?? ?memset(p_temp, 0, num_rows * num_columns * sizeof(complex_float));
?? ?p->data = p_temp;
}
int main()
{
?? ?struct ComplexMatrix p;
?? ?Create_ComplexMatrix_row_num(&p, 2, 3);
?? ?printf("p.data[5] = %f+i*%f\n",p.data[0].real,p.data[0].imag);
?? ?return 0;
}
?
?
?
與50位技術(shù)專家面對面20年技術(shù)見證,附贈技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的原:开辟内存时,可以以结构体为单位,这样测试,是对的吧?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 这个转录组比对工具很快,十几分钟一个样品
- 下一篇: 机器学习算法 随机森林学习 之决策树