当前位置:首页 » 文件管理 » c缓存类

c缓存类

发布时间: 2022-07-16 04:46:34

A. C语言缓存问题:

scanf会跳过空白符,除非是%c。所以你getchar遗留下来的换行被scanf跳过

B. 电脑上网,有哪些缓存类型比如IE浏览器的

缓存指的是临时文件,你在环境变量里能看到的,4个TEMP的文件夹,都是缓存跟临时文件夹,处理不当的话会影响系统性能的!

我这个是优化过的,没在C盘了

C. C语言缓冲区的问题:下面是代码

具体来说是这样的,scanf的输入后面必然会有一个回车的.以字符串输入为例,字符被存进对应的地址里,这个回车就会留在缓冲区(其他格式按系统规定的字长读入,但无论怎样,缓冲区都会有一个回车字符),如果我们继续用scanf的话是没问题的,因为scanf读入得内容是重第一个非空字符开始的.当时,如果我们用gets或fgets时,就会将将这个回车读入,而无法读入我们 想要的字符.因为gets和fgets是读到回车就结束读入的,所以这种情况就要在scanf后面加多一条getchar或fflush语句, 你的理解大致上是正确的,关键是要理解这个回车

D. C语言缓冲区在哪里

缓冲区具体在哪里是与操作系统、编译器相关的
以VC++为例。察看getchar的源代码(src\fgetchar.c),有:
int __cdecl _fgetchar (void){
return(getc(stdin));
}
#undef getchar
int __cdecl getchar (void){
return _fgetchar();
}
可见getchar()相当于getc(stdin)

继续察看getc(src\fgetc.c),有一段(为便于阅读,有删减):
int __cdecl getc (FILE *stream){
int retval;
_ASSERTE(stream != NULL);
_lock_str(stream);
__try {
retval = _getc_lk(stream);
}
__finally {
_unlock_str(stream);
}
return(retval);
}

这段代码里_lock_str其实是通过Win32 API提供的临街区来锁住文件
接收用户输入发生在_getc_lk,_getc_lk宏调用_filbuf。_filbuf在_filbuf.c中可以查看,这段代码比较长,就不贴出来了
_filbuf主要是调用了_read(_fileno(stream), stream->_base, stream->_bufsiz)

而_read最终则是调用了Win32API ReadFile,以下是用WinDbg输出的getchar的调用栈:
# ChildEBP RetAddr
00 0012fe6c 0040a4e7 kernel32!ReadFile
01 0012fea8 0040a3b9 TestStruct!_read_lk+0x107 [read.c @ 146]
02 0012fec0 00403140 TestStruct!_read+0x69 [read.c @ 75]
03 0012fee8 00401290 TestStruct!_filbuf+0xd0 [_filbuf.c @ 127]
04 0012ff08 004012cc TestStruct!fgetc+0x80 [fgetc.c @ 44]
05 0012ff14 0040103d TestStruct!getc+0xc [fgetc.c @ 56]
06 0012ff20 00401058 TestStruct!_fgetchar+0xd [fgetchar.c @ 37]
07 0012ff28 0040101e TestStruct!getchar+0x8 [fgetchar.c @ 47]
08 0012ff80 0040115c TestStruct!main+0xe [d:\my programs\teststruct\ts.cpp @ 4]
09 0012ffc0 7c816fe7 TestStruct!mainCRTStartup+0xfc [crt0.c @ 206]
0a 0012fff0 00000000 kernel32!BaseProcessStart+0x23

可见,getchar最终调用了ReadFile。关于ReadFile的原理以及缓冲区在哪里,请你再提一个问我再回答

E. C语言中buffer到底是什么意思是数组缓冲区为什么一般C程序中都不定义他直接拿来用呢

C语言中buffer是缓冲区的意思。

不定义是不能拿过来直接用的,因为它肯定是在别的地方定义的,比如头文件,或者是个全局变量等。一般是在编译器里面,右键这个变量,选gotodifination就可以看到它在哪定义的了。

缓冲区它是内存空间的一部分。也就是说,在内存空间中预留了一定的存储空间,这些存储空间用来缓冲输入或输出的数据,这部分预留的空间就叫做缓冲区。

(5)c缓存类扩展阅读

C语言循环buffer的实现

#ifdefined(__CIRCLE_BUFFER__)

//"circle_buffer.h"

#ifndef__CIRCLE_BUFFER_H__

#define__CIRCLE_BUFFER_H__

#ifdefined(__CIRCLE_BUFFER__)

#include<stdio.h>

#include<string.h>

#include<stdlib.h>

#include<assert.h>

typedefunsignedcharcb_u8;

typedefunsignedshortintcb_u16;

typedefunsignedintcb_u32;

typedefsignedcharcb_s8;

typedefsignedshortintcb_s16;

typedefsignedintcb_s32;

typedefcharcb_char;

typedefenum{cb_false,cb_true}cb_bool;

typedefstruct{

cb_u8*bufptr;

cb_u32buflen;

cb_u32datalen;

cb_u32readpos;

cb_u32writepos;

}CircleBufferMngr;

typedefstruct{

void(*cb_init)(CircleBufferMngr**,cb_u32);

void(*cb_deinit)(CircleBufferMngr**);

void(*cb_info)(CircleBufferMngr*,cb_char*,cb_u32);

cb_u32(*cb_read)(CircleBufferMngr*,cb_u8*,cb_u32);

cb_u32(*cb_write)(CircleBufferMngr*,cb_u8*,cb_u32);

cb_u32(*cb_datalen)(CircleBufferMngr*);

cb_bool(*cb_full)(CircleBufferMngr*);

cb_bool(*cb_empty)(CircleBufferMngr*);

}CircleBufferApi;

#defineCB_MEMCPYmemcpy

#defineCB_MEMSETmemset

#defineCB_SPRINTsprintf

#defineCB_MALLOCmalloc

#defineCB_MFREEfree

#defineCB_ASSERTassert

#defineCB_SNPRINTsnprintf

#defineCB_TRACEprintf

//锁定,禁止中断和任务调度

#defineCB_GLOBAL_LOCK

#defineCB_GLOBAL_UNLOCK

;

#defineCBMA_INITcircleBufApi.cb_init

#defineCBMA_DEINITcircleBufApi.cb_deinit

#defineCBMA_INFOcircleBufApi.cb_info

#defineCBMA_READcircleBufApi.cb_read

#defineCBMA_WRITEcircleBufApi.cb_write

#defineCBMA_DATALENcircleBufApi.cb_datalen

#defineCBMA_FULLcircleBufApi.cb_full

#defineCBMA_EMPTYcircleBufApi.cb_empty

#endif/*__CIRCLE_BUFFER__*/

#endif/*__CIRCLE_BUFFER_H__*/

F. 怎么在C/C++程序中运用双缓存,双线程的大规模数据处理方法

无语了,又是你。。。

缓存在程序里就是依据程序需要申请的一段程序空间,可以用数组,可以用队列,也可以用链表。你说的queue<>是STL提供的已经搭好框架的队列。
具体需要怎样的缓存要看你的程序需要。
我举个例子,假如我是HTTP服务器程序,每秒收到多个HTTP请求,我会用多进程(多进程比多线程稳定)或者多线程来处理各个请求,主进程等待HTTP服务端口来数据,每来一个请求就起一个线程去处理它。来的数据我就可以放在一个 queue<char*>的数据结构里,这个就是缓存了。每个线程我都传个指针给他,让线程自己去访问其中一个缓存,取出HTTP请求做分析。而队列中的其他缓存可以继续接受数据。

创建线程的方法对操作系统有一定的依赖,在windows上一般是用CreateThread以及其相关函数,你可以查MSDN得到更详细的信息,或者直接网络。在linux或者unix上,一般用folk来起进程,pthread线程库(例如pthread_create)来操作线程。不过也有不用线程技术,用select epoll等技术的。这些你可以自己查到相应的例子。

希望这些对你有帮助。

G. 怎么清理c盘的缓存如何快速清理C盘中的的

1.打开“我的电脑”-“工具”-“文件夹选项”-“查看”-在“显示所有文件和文件夹”选项前打勾-再按“确定”

2.删除以下文件夹中的内容:

C:\Documents and Settings\用户名\Cookies\下的所有文件(保留index文件)

C:\Documents and Settings\用户名\Local Settings\Temp\下的所有文件(用户临时文件)

C:\Documents and Settings\用户名\LocalSettings\TemporaryInternet Files\下的所有文件(页面文件)

C:\Documents and Settings\用户名\Local Settings\History\下的所有文件(历史纪录)

C:\Documents and Settings\用户名\Recent\下的所有文件(最近浏览文件的快捷方式)

C:\WINDOWS\Temp\下的所有文件(临时文件)

C:\WINDOWS\ServicePackFiles(升级sp1或sp2后的备份文件)

C:\WINDOWS\Driver Cache\i386下的压缩文件(驱动程序的备份文件)

C:\WINDOWS\SoftwareDistribution\download下的所有文件

3.如果对系统进行过windoes updade升级,则删除以下文件:

C:\windows\下以 $u... 开头的隐藏文件

4.然后对磁盘进行碎片整理,整理过程中请退出一切正在运行的程序

5.碎片整理后打开“开始”-“程序”-“附件”-“系统工具”-“系统还原”-“创建一个还原点”(最好以当时的日期作为还原点的名字)

6.打开“我的电脑”-右键点系统盘-“属性”-“磁盘清理”-“其他选项”-单击系统还原一栏里的“清理”-选择“是”-ok了

7、在各种软硬件安装妥当之后,其实XP需要更新文件的时候就很少了。删除系统备份文件吧:开始→运行→sfc.exe /purgecache近3xxM。(该命令的作用是立即清除"Windows 文件保护"文件高速缓存,释放出其所占据的空间)

8、删掉\windows\system32\dllcache下dll档(减去200——300mb),这是备用的dll档, 只要你已拷贝了安装文件,完全可以这样做。
9、删除不用的输入法:对很多网友来说,Windows XPt系统自带的输入法并不全部都合适自己的使用,比如IMJP8_1 日文输入法、IMKR6_1 韩文输入法这些输入法,如果用不着,我们可以将其删除。输入法位于\windows\ime\文件夹中,全部占用了88M的空间。
10、升级完成发现windows\多了许多类似$NtUninstallQ311889$这些目录,都干掉吧,1x-3xM

11、另外,保留着\windows\help目录下的东西对我来说是一种伤害,呵呵。。。都干掉!

12、关闭系统还原:系统还原功能使用的时间一长,就会占用大量的硬盘空间。因此有必要对其进行手工设置,以减少硬盘占用量。打开"系统属性"对话框,选择"系统还原"选项,选择"在所有驱动器上关闭系统还原"复选框以关闭系统还原。也可仅对系统所在的磁盘或分区设置还原。先选择系统所在的分区,单击"配置"按钮,在弹出的对话框中取消"关闭这个驱动器的系统还原"选项,并可设置用于系统还原的磁盘空间大小。

13、休眠功能会占用不少的硬盘空间,如果使用得少不妨将共关闭,关闭的方法是的:打开"控制面板",双击"电源选项",在弹出的"电源选项属性"对话框中选择"休眠"选项卡,取消"启用休眠"复选框。

14、卸载不常用组件:XP默认给操作系统安装了一些系统组件,而这些组件有很大一部分是你根本不可能用到的,可以在"添加/删除Windows组件"中将它们卸载。但其中有一些组件XP默认是隐藏的,在"添加/删除Windows 组件"中找不到它们,这时可以这样操作:用记事本打开\windows\inf\sysoc.inf这个文件,用查找/替换功能把文件中的"hide"字符全部替换为空。这样,就把所有组件的隐藏属性都去掉了,存盘退出后再运行"添加-删除程序",就会看见多出不少你原来看不见的选项,把其中那些你用不到的组件删掉(记住存盘的时候要保存为sysoc.inf,而不是默认的sysoc.txt),如Internat信使服务、传真服务、Windows messenger,码表等,大约可腾出近50MB的空间。

15、清除系统临时文件:系统的临时文件一般存放在两个位置中:一个Windows安装目录下的Temp文件夹;另一个是C:\Documents and Settings"用户名"\Local Settings\Temp文件夹(Y:是系统所在的分区)。这两个位置的文件均可以直接删除。

16、清除Internet临时文件:定期删除上网时产生的大量Internet临时文件,将节省大量的硬盘空间。打开IE浏览器,从"工具"菜单中选择"Internet选项",在弹出的对话框中选择"常规"选项卡,在"Internet临时文件"栏中单击"删除文件"按钮,并在弹出"删除文件"对话框,选中"删除所有脱机内容"复选框,单击"确定"按钮。

17、清除预读文件:Windows XP的预读设置虽然可以提高系统速度,但是使用一段时间后,预读文件夹里的文件数量会变得相当庞大,导致系统搜索花费的时间变长。而且有些应用程序会产生死链接文件,更加重了系统搜索的负担。所以,应该定期删除这些预读文件。预计文件存放在Windows XP系统文件夹的Prefetch文件夹中,该文件夹下的所有文件均可删除。

18、压缩NTFS驱动器、文件或文件夹:如果你的硬盘采用的是NTFS文件系统,空间实在紧张,还可以考虑启用NTFS的压缩功能。右击要压缩的驱动器-"属性"-"常规"-"压缩磁盘以节省磁盘空间",然后单击"确定", 在"确认属性更改"中选择需要的选项。这样可以节省约20% 的硬盘空间。在压缩C盘的时候,最好在安全模式下压缩,这样效果要好一些。

19、关闭华医生Dr.Watson:要关闭Dr.Watson可打开注册表编辑器,找到"HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsNT\CurrentVersion\AeDebug"分支,双击其下的Auto键值名称,将其"数值数据"改为0,最后按F5刷新使设置生效,这样就取消它的运行了。也在"开始"->"运行"中输入"drwtsn32"命令,或者"开始"->"程序"->"附件"->"系统工具"->"系统信息"->"工具"->"Dr Watson",调出系统里的华医生Dr.Watson ,只保留"转储全部线程上下文"选项,否则一旦程序出错,硬盘会读很久,并占用大量空间。如以前有此情况,请查找user.dmp文件,删除后可节省几十MB空间。

20、关闭远程桌面:"我的电脑"->"属性"->"远程","远程桌面"里的"允许用户远程连接到这台计算机"勾去掉。

21、取消XP对ZIP支持:Windows XP在默认情况下打开了对zip文件支持,这要占用一定的系统资源,可选择"开始→运行",在"运行"对话框中键入"regsvr32 /u zipfldr.dll",回车确认即可取消XP对ZIP解压缩的支持,从而节省系统资源。

22、关闭错误报告:当应用程序出错时,会弹出发送错误报告的窗口,其实这样的错误报告对普通用户而言几乎没有任何意义,关闭它是明智的选择。在"系统属性"对话框中选择"高级"选项卡,单击"错误报告"按钮,在弹出的"错误汇报"对话框中,选择"禁用错误汇报"单选项,最后单击"确定"即可。另外我们也可以从组策略中关闭错误报告:从"运行"中键入"gpedit.msc",运行"组策略编辑器",展开"计算机配置→管理模板→系统→错误报告功能",双击右边设置栏中的"报告错误",在弹出的"属性"对话框中选择"已禁用"单选框即可将"报告错误"禁用。

23、关掉不用的设备:Windows XP总是尽可能为电脑的所有设备安装驱动程序并进行管理,这不仅会减慢系统启动的速度,同时也造成了系统资源的大量占用。针对这一情况,你可在 设备管理器中,将PCMCIA卡、调制解调器、红外线设备、打印机端口(LPT1)或者串口(COM1)等不常用的设备停用,方法是双击要停用的设备,在其属性对话框中 的"常规"选项卡中选择"不要使用这个设备(停用)"。在重新启动设置即可生效,当需要使用这些设备时再从设备管理器中启用它们。

24、定期清理系统还原点:打开磁盘清理,选择其他选项->清理系统还原点,点击清理。

25、卸载不需要的程序,这个就不用我多说了

26、其它优化:

a 将应用软件装在其它硬盘(不要安装在系统盘下,这对重装系统也有好处);

b 将"我的文档"文件夹都转到其他分区:在桌面的"我的文档"图标上是右击鼠标,选择"属性"->"移动" ;

c 将IE临时文件夹都转到其他分区:打开IE浏览器,选择"工具"->"internet选项"->"常规"->"设置"->"移动文件夹";

d 把虚拟内存也转到其它硬盘;

虚拟内存设置技巧

一般windows XP默认情况下是利用C盘的剩余空间来做虚拟内存的,因此,C盘的剩余空间越大,对系统运行就越好,虚拟内存是随着你的使用而动态地变化的,这样C盘就容易产生磁盘碎片,影响系统运行速度,所以,最好将虚拟内存设置在其它分区,如D盘中。查看虚拟内存设置情况如下:

右键点“我的电脑”,左键点“属性”,点选“高级”选项卡,点“性能”里的“设置”按钮,再选“高级”选项卡,点下面的“更改”按钮,所弹出的窗口就是虚拟内存设置窗口,一般默认的虚拟内存是从小到大的一段取值范围,这就是虚拟内存变化大小的范围,最好给它一个固定值,这样就不容易产生磁盘碎片了,具体数值根据你的物理内存大小来定,一般为物理内存的1.5到2倍,如内存为256M,那么应该设置256*1.5=384M,或者干脆512M,设置方法如下:

假设内存为256M,虚拟内存放在D盘,先要将默认的清除,保持C盘为选中状态,单选“无分页文件(N)”再按“设置”按钮,此时C盘旁的虚拟内存就消失了,然后选中D盘,单选“自定义大小”,在下面的“初始大小”和“最大值”两个方框里都添上512,再点一下“设置”按钮,会看到D盘的旁边出现了“512-512”的字样,这样就说明设置好了,再一路确定,最终,系统会要重新启动,重启一下,便完成了设置。

注意:虚拟内存只能有一个,只放在一个盘中。

H. C语言中如何将结构体中的值赋给BYTE类型的缓存

C语言中将结构体给BYTE缓存赋值时,直接进行拷贝即可。

结构体在内存中是一段连续的内存空间,BYTE缓存(即BYTE数组)也是一段连续的内存空间,直接进行内存拷贝就可以完成赋值操作。

例如:

structA{
inta;
shortb;
}dataStruct;
BYTEdataBuffer[20];
memcpy(dataBuffer,dataStruct,sizeof(structA));//对Byte缓存赋值
memcpy(dataStruct,dataBuffer,sizeof(structA));//对结构体赋值

I. C语言中结构体与BYTE类型缓存之间的赋值问题

memcpy(&test1, &(TTTT.STUDENT[51]), sizeof(TTTT)-sizeof(STU)*50)
我好像记得你。

热点内容
sql数据库的端口 发布:2025-01-22 12:20:02 浏览:362
安卓最终幻想8怎么设置中文 发布:2025-01-22 12:19:23 浏览:651
怎么查电脑配置和网络 发布:2025-01-22 12:19:16 浏览:586
linuxsnmp查看 发布:2025-01-22 12:17:49 浏览:37
安卓数据线怎么接蓝牙 发布:2025-01-22 12:07:29 浏览:229
扣扣账号多少次密码不正确会被封 发布:2025-01-22 12:07:19 浏览:400
python是32位还是64位 发布:2025-01-22 11:51:41 浏览:894
铃声多多缓存文件夹 发布:2025-01-22 11:51:39 浏览:724
java按键精灵 发布:2025-01-22 11:49:31 浏览:81
python配色 发布:2025-01-22 11:46:40 浏览:613