[cocos2d-x]File文件的IO读写处理

本文介绍如何在Cocos2d-x中进行文件的读取与保存操作,包括通过CCFileUtils获取可读写路径及使用标准C库函数如fopen、fread和fputs等实现文件内容的读取和写入。

为了保存自定义数据文件,需要保存文件和读取文件,也就是File的IO处理;

针对cocos2d-x我们可以通过CCFileUtils::sharedFileUtils()->getWriteablePath()获取到可读写的文件目录,其实是Caches目录。


关于file的操作,我们要明白几个概念:

File :文件对象,用于创建文件,操作文件

fopen:打开操作一个具体文件(文件路径,模式)模式有"w"\"r"读写等

fseek:移动文件指针

ftell:得到文件指针的位置,距离开头

rewind:文件指针重置

malloc:分配内存空间

fread:读一个文件的内容,需要输入buf储存空间,单位大小,长度,文件指针

fputs:写内容进去一个文件


摘录读取模式

    r 以只读方式打开文件,该文件必须存在。   
    r+ 以可读写方式打开文件,该文件必须存在。   
    rb+ 读写打开一个二进制文件,允许读数据。   
    rt+ 读写打开一个文本文件,允许读和写。   
    w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。   
    w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。   
    a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保    留。(EOF符保留)   
    a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。 (原来的EOF符不保留)   
    wb 只写打开或新建一个二进制文件;只允许写数据。   
    wb+ 读写打开或建立一个二进制文件,允许读和写。   
    wt+ 读写打开或着建立一个文本文件;允许读写。   
    at+ 读写打开一个文本文件,允许读或在文本末追加数据。   
    ab+ 读写打开一个二进制文件,允许读或在文件末追加数据。


以下是代码,2个静态方法,保存和读取:TDInvFileUtils.h

  1. // 
  2. //  TDInvFileUtils.h 
  3. //  MyCocoa2DTest 
  4. // 
  5. //  Created by 韦 柱全 on 13-2-27. 
  6. // 
  7. // 
  8.  
  9. #ifndef __MyCocoa2DTest__TDInvFileUtils__ 
  10. #define __MyCocoa2DTest__TDInvFileUtils__ 
  11.  
  12. #include <iostream> 
  13. #include "cocos2d.h" 
  14. using namespace cocos2d; 
  15. using namespace std; 
  16.  
  17. /** 负责操作文件储存和读取
  18. */ 
  19.  
  20. class TDInvFileUtils { 
  21. public
  22.     /** 读取本地文件,返回数据 */ 
  23.     static string getFileByName(string pFileName); 
  24.      
  25.     /** 储存内容到文件 */ 
  26.     static bool saveFile(char* pContent,string pFileName); 
  27.      
  28. }; 
  29.  
  30. #endif /* defined(__MyCocoa2DTest__TDInvFileUtils__) */ 
//
//  TDInvFileUtils.h
//  MyCocoa2DTest
//
//  Created by 韦 柱全 on 13-2-27.
//
//

#ifndef __MyCocoa2DTest__TDInvFileUtils__
#define __MyCocoa2DTest__TDInvFileUtils__

#include <iostream>
#include "cocos2d.h"
using namespace cocos2d;
using namespace std;

/** 负责操作文件储存和读取
 */

class TDInvFileUtils {
public:
    /** 读取本地文件,返回数据 */
    static string getFileByName(string pFileName);
    
    /** 储存内容到文件 */
    static bool saveFile(char* pContent,string pFileName);
    
};

#endif /* defined(__MyCocoa2DTest__TDInvFileUtils__) */

其实现文件 TDInvFileUtils.cpp

  1. // 
  2. //  TDInvFileUtils.cpp 
  3. //  MyCocoa2DTest 
  4. // 
  5. //  Created by 韦 柱全 on 13-2-27. 
  6. // 
  7. // 
  8.  
  9. #include "TDInvFileUtils.h" 
  10.  
  11. string TDInvFileUtils::getFileByName(string pFileName){ 
  12.     //第一先获取文件的路径 
  13.     string path = CCFileUtils::sharedFileUtils()->getWriteablePath() + pFileName; 
  14.     CCLOG("path = %s",path.c_str()); 
  15.      
  16.     //创建一个文件指针 
  17.     FILE* file = fopen(path.c_str(), "r"); 
  18.      
  19.     if (file) { 
  20.         char* buf;  //要获取的字符串 
  21.         int len;    //获取的长度 
  22.         /*获取长度*/ 
  23.         fseek(file, 0, SEEK_END);   //移到尾部 
  24.         len = ftell(file);          //提取长度 
  25.         rewind(file);               //回归原位 
  26.         CCLOG("count the file content len = %d",len); 
  27.         //分配buf空间 
  28.         buf = (char*)malloc(sizeof(char) * len + 1); 
  29.         if (!buf) { 
  30.             CCLOG("malloc space is not enough."); 
  31.             return NULL; 
  32.         } 
  33.          
  34.         //读取文件 
  35.         //读取进的buf,单位大小,长度,文件指针 
  36.         int rLen = fread(buf, sizeof(char), len, file); 
  37.         buf[rLen] = '\0'
  38.         CCLOG("has read Length = %d",rLen); 
  39.         CCLOG("has read content = %s",buf); 
  40.          
  41.         string result = buf; 
  42.         fclose(file); 
  43.         free(buf); 
  44.         return result; 
  45.     } 
  46.     else 
  47.         CCLOG("open file error."); 
  48.      
  49.     return NULL; 
  50.  
  51. bool TDInvFileUtils::saveFile(char *pContent, string pFileName){ 
  52.     //第一获取储存的文件路径 
  53.     string path = CCFileUtils::sharedFileUtils()->getWriteablePath() + pFileName; 
  54.     CCLOG("wanna save file path = %s",path.c_str()); 
  55.      
  56.     //创建一个文件指针 
  57.     //路径、模式 
  58.     FILE* file = fopen(path.c_str(), "w"); 
  59.     if (file) { 
  60.         fputs(pContent, file); 
  61.         fclose(file); 
  62.     } 
  63.     else 
  64.         CCLOG("save file error."); 
  65.      
  66.     return false
基于数据驱动的 Koopman 算子的递归神经网络模型线性化,用于纳米定位系统的预测控制研究(Matlab代码实现)内容概要:本文围绕“基于数据驱动的 Koopman 算子的递归神经网络模型线性化,用于纳米定位系统的预测控制研究”展开,提出了一种结合数据驱动方法与Koopman算子理论的递归神经网络(RNN)模型线性化方法,旨在提升纳米定位系统的预测控制精度与动态响应能力。研究通过构建数据驱动的线性化模型,克服了传统非线性系统建模复杂、计算开销大的问题,并在Matlab平台上实现了完整的算法仿真与验证,展示了该方法在高精度定位控制中的有效性与实用性。; 适合人群:具备一定自动化、控制理论或机器学习背景的科研人员与工程技术人员,尤其是从事精密定位、智能控制、非线性系统建模与预测控制相关领域的研究生与研究人员。; 使用场景及目标:①应用于纳米级精密定位系统(如原子力显微镜、半导体制造设备)中的高性能预测控制;②为复杂非线性系统的数据驱动建模与线性化提供新思路;③结合深度学习与经典控制理论,推动智能控制算法的实际落地。; 阅读建议:建议读者结合Matlab代码实现部分,深入理解Koopman算子与RNN结合的建模范式,重点关注数据预处理、模型训练与控制系统集成等关键环节,并可通过替换实际系统数据进行迁移验证,以掌握该方法的核心思想与工程应用技巧。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值