RNAMatrix

Coffee in, Code out

  C++博客 :: 首页 :: 联系 :: 聚合  :: 管理
  3 Posts :: 0 Stories :: 0 Comments :: 0 Trackbacks

公告

一个没研究方向的计算机研究生。 喜爱C++。

常用链接

留言簿

我参与的团队

搜索

  •  

最新评论

阅读排行榜

评论排行榜

2010年8月5日 #

     摘要: 今天在使用limits中的numeric_limits类模板函数max和min时,编译出现了一个错误:view plaincopy to clipboardprint?error C2589: '(' : illegal token on right side of '::'  ...  阅读全文
posted @ 2010-08-05 17:12 matrix 阅读(4175) | 评论 (0)编辑 收藏

2010年7月8日 #

我们都知道C和C++中在传递一维数组时,,都将被编译器视为指针类型。如:

  1. // 三个等价的putValues()声明   
  2. void func( int* );   
  3. void func( int[] );  
  4. void func( int[ 10 ] );   

所以传递一个指针实参给一维数组参数是可行的。

而且,当编译器对实参类型进行参数类型检查时并不检查一维数组的长度,也就是说数组的长度与参数声明无关。

那么上升为多维数组的情况,多维数组参数也将会被编译器视为指针的指针(或者说指针数组)吗?

当然不是,当函数参数是多维数组时,这样的参数必须指明第一维以外的所有维的长度。例如:

  1. void func( int matrix[][10], ...);   
  2. //等价声明  
  3. void func( int (*matrix)[10] );   

我们可以看到,二维数组的将会被编译器视为数组指针,而非指针的指针或者指针数组。

这也就是为什么我们经常需要传递一个二维数组参数时误传了一个指针的指针或使得编译器报错的原因。

最后来总结一下:

****************************************************************************************************                                                      
                             实参                           所匹配的形式参数
数组的数组        char c[m][n]             char(*)[n]    -> 数组指针
指针数组           char *c[n]                char **c    -> 指针的指针
数组指针           char (*c)[n]             char (*c)[n]    -> 不改变
指针的指针        char **c;                 char **c   ->  不改变

*************************************************************************************************** */
posted @ 2010-07-08 17:30 matrix 阅读(724) | 评论 (0)编辑 收藏

2010年7月7日 #

在C中 malloc和memset是2个常用的对内存操作的函数。首先还是来看一下这2个函数的函数原型。
1.malloc函数
malloc函数用于从堆上分配指定字节的内存空间。

void * malloc(size_t n);


其中,形参n为要求分配的内存字节数。如果执行成功,函数范围获得的内存空间的首地址;执行失败,返回值为NULL。由于函数返回值值的类型为void的指针,因此,可以将void指针类型转换后赋值给任意类型指针,这样就可以通过操作该类型指针来操作从堆上获得的内存空间。
需要注意的是malloc函数分配得到的内存空间是未初始化的。有时候,在使用前需要对该内存空间进行初始化,memset就派上用场了。

2.memset函数

    
void * memset (void * p,int c,size_t n);

其中,指针p为所操作的内存空间的首地址,c为每个字节所赋的值,n为所操作内存空间的字节长度,也就是内存被赋值为c的字节数。
在使用memset时经常要注意的它是以字节为单位进行赋值的,所赋值的范围是0x00~0xFF。若想要对一个double或int型的数组赋值时,就特别需要注意这一点:

example1:
char a[4];
memset(a, '\0', 4);

example2:
int a[4];
memset(a, 1, 4);//这里改成memset(a,1,5*sizeof(int))也是不可以的

第一个例子是正确的,memset对字符数组里的每个char类型元素赋值为NULL。第二个例子显然得到的结果不是把int型数组里的每个元素赋值为了1。因为memset函数以字节为单位进行赋值,那么数组中一个int型元素的4个字节都将被赋值为1(或者说ASCII码1所对应的字符),实际上它所表示的整数是0x01010101。
另外,在使用malloc为一个二维数组分配内存空间时,要特别注意使用memset进行初始化可能会出错。

    
int m = 2;
int n = 3;
int i;

//二位数组a[m][n]
int **a;

= (int **) malloc(m * sizeof(int *));

for(i=0; i<m; ++i)
{
    a[i] 
= (int *) malloc(n * sizeof(int));
}

memset(a, 
0sizeof(int* m * n);

对所有二维以上的数组使用memset时,若此多维数组是通过多次调用malloc函数搭积木分配得到的,那么该数组的内存空间可能不连续。使用memset函数进行连续的统一赋值就毫无意义了。直接声明的多维数组如a[2][3]的内存空间显然是连续的,此时使用memset函数初始化就没有问题。
posted @ 2010-07-07 07:44 matrix 阅读(8524) | 评论 (0)编辑 收藏