C++杂记

1,C++在文件读取的时候,路径中的斜杠是右斜杠,matlab中的斜杠是左斜杠。

2,读取信号:

FILE *pFile;
long lSize;
char *buffer;
size_t result;   //这是一种数据类型,提供足够大的空间,将数据存在内存中


fopen_s(&pFile,"G:/youcali/youcalilvbo/originaldatas/BC825F6DF2E88B83E169E117906B12EBB.DAT", "rb");   //C ++中的路径的地址是右斜杠
if (pFile == NULL)
{
fputs("File error", stderr);
exit(1);
}
fseek(pFile, 0, SEEK_END);  //将指针指向文件的结尾,
lSize = ftell(pFile);  //获得文件的大小
rewind(pFile);     //将指针指向文件的开头


  //申请空间获得整个文件的内容
buffer = (char*)malloc(sizeof(char)*lSize);
if (buffer == NULL)
{
fputs("Memory error", stderr);
exit(2);
}
//将获得的数据读到缓存中
result = fread(buffer, 1, lSize, pFile);
if (result != lSize)
{
fputs("Reading error", stderr);
exit(3);
}

fclose(pFile);

free(buffer);



2,vector的使用:相关的使用说明有很多,这里只说;在使用vector之前,先进行申请一下空间,避免二次分配;就是在使用vector的时候,原来的vector的大小不能子啊存储数据了,但是你还需要在分配空间,这是时候,vector就会重新分配空间,这时候,就会增大计算量,时间就会延长。

 reserve是容器预留空间,但并不真正创建元素对象,在创建对象之前,不能引用容器内的元素,因此当加入新的元素时,需要用push_back()/insert()函数。

resize是改变容器的大小,并且创建对象,因此,调用这个函数之后,就可以引用容器内的对象了,因此当加入新的元素时,用operator[]操作符,或者用迭代器来引用元素对象

 再者,两个函数的形式是有区别的,reserve函数之后一个参数,即需要预留的容器的空间;resize函数可以有两个参数,第一个参数是容器新的大小,第二个参数是要加入容器中的新元素,如果这个参数被省略,那么就调用元素对象的默认构造函数。

   reserve只是保证vector的空间大小(capacity)最少达到它的参数所指定的大小n。在区间[0, n)范围内,如果下标是index,vector[index]这种访问有可能是合法的,也有可能是非法的,视具体情况而定。
     resize和reserve接口的共同点是它们都保证了vector的空间大小(capacity)最少达到它的参数所指定的大小。


3,引用和指针

 1)指针是一个变量,存储的是一个地址,指针指向内存中的一个存储单元;引用和原来的变量实质上是一个东西,只不过是原来变量的一个别名而已。

   指针 int a = 1;int *p = &a;      引用  int a = 1;int &b = a;

  2)可以有const指针,但是没有const引用;‘

  3)指针可以有多级,但是引用只能是一级;

  4)指针的值可以为空,但是引用的值不能为NULL;并且引用在定义的时候必须初始化

 5)指针的值在初始化后可以改变,即指向其他的存储单元,而引用在进行初始化后就不会再改变了。

 6)"sizeof()引用"得到的指向变量(对象)的大小,但是“”sizeof指针“得到的是指针本身的大小。

  7)指针和引用的自增(++)运算不一样,

  8)指针和引用作为函数参数进行传递时的区别;用指针传递参数,可以实现对实参进行改变的目的,是因为传递过来的是实参的地址,因此使用*a实际上是去存储实参的内存单元里的数据,即是对实参进行改变,因此可以达到目的;

         将引用作为函数的参数进行传递:将引用作为参数进行传递是,实质上传递的是实参本身,即传递进来的不是实参的一个拷贝,因此对形参的修改,其实是对是实参的修改,在用引用进行参数传递时,不仅节约时间,而且可以节约空间。

4,引用的赋值:在参数的传递过程中,引用是不能重新赋值的。引用初始化时,它的引用对象只能是变量,并且,一旦它指定为某一个对象的引用后了,就不能更改了。


5,int* src_sig[] = { src_v5_sig ,src_v1_sig };  将两个一维数组合并为二维数组。


6,memset的作用;

1)所属的头文件<memory.h>和<string.h>

2)作用:在一块内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快的办法。memset可以方便的清空一个结构体类型的变量或者数组。

表达式:memset(str,0,sizeof(str)):参数str可以是数组,指针(已附内存),对象,结构体等。

7,memcpy:头文件:<memory.h>(C)或者<memory>(C++)

1)void *-cdecl memcpy(void *_Dst,const void *_Src,size_t_Size);

c和C++使用的内存拷贝函数,memcpy函数的功能就是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置。

strcpy:头文件是<string.h>

char *strcpy(char* strDest,const char*strSrc)

把str地址开始且含有‘\0’结束符的字符串复制到以dest开始的地址空间。

strcpy和memcpy的区别:

1、复制的内容不同。strcpy只能复制字符串,而memcpy可以复制任意内容,例如字符数组、整型、结构体、类

2、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。

3、用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时则一般用memcpy。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

野狼位位

给点辛苦费0.1元

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值