char * left(char *dst,char *src, long n)
{
char *p = src
char *q = dst
int len = strlen(src)
if(n>len) n = len
/*p += (len-n)*/ /*从右边第n个字符开始*/
while(n--) *(q++) = *(p++)
*(q++)='\0'/*有必要吗?很有必要*/
return dst
}
int substr(char *s1, char *s2)
{
char *s3 = strstr(s1,s2)
if(s3 == NULL)
return -1
return strlen(s1)-strlen(s3)
}
char* mysubstr(char* srcstr, int offset, int length) {
int total_length = strlen(srcstr)
int real_length = ((total_length - offset) >= length ? length : (total_length - offset)) + 1
char *tmp
if (NULL == (tmp=(char*) malloc(real_length * sizeof(char)))) {
printf("Memory overflow . \n")
exit(0)
}
strncpy(tmp, srcstr+offset, real_length - 1)
tmp[real_length - 1] = '\0'
return tmp
}
#define ENCODE 1
#define IN_PCM(a) strcat(a,"/file/input.pcm")
#define OUT_SPX(a) strcat(a,"/file/out.spx")
#define OUT_PCM(a) strcat(a,"/file/out.pcm")
int main(int argc, char **argv){
char* path
char* dist
path = argv[0]
char* index = strstr(path,PROJECT_PATH)
long diff = index-path
char *pathDir = mysubstr(path,0,substr(path,PROJECT_PATH)+9)
// 创建一个字符串数组
char arr1[64] = {0}
strcpy(arr1, pathDir)
char arr2[64] = {0}
strcpy(arr2, pathDir)
char* temp0=IN_PCM(pathDir)
char* temp=OUT_SPX(arr1)
char* tempOut=OUT_PCM(arr2)
// 创建一个字符串数组
char arr0[64] = {0}
strcpy(arr0, temp0)
printf("after arr0=%s\n,arr1=%s\n,arr2=%s\n",arr0,arr1,arr2)
return 0
}
http://hi.baidu.com/andywangcn/item/7633efda5517baf9ca0c39c6TCHAR _szPath[MAX_PATH + 1]={0}
GetModuleFileName(NULL, _szPath, MAX_PATH)
(_tcsrchr(_szPath, _T('\\')))[1] = 0//删除文件名,只获得路径 字串
CString strPath
for (int n=0_szPath[n]n++)
{
if (_szPath[n]!=_T('\\'))
{
strPath +=_szPath[n]
}
else
{
strPath += _T("\\\\")
}
}
MessageBox(strPath)//输出==e:\\program\\Debug\\
//头文件用到 windows.h
如果是通过open方式打开的,那么第一个参数就是文件路径信息:#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int open(const char *path, int oflag, /* mode_t mode */...)
如果是通过fopen方式打开的,那么第一个参数就是文件路径信息:
#include <stdio.h>
FILE *fopen(const char *filename, const char *mode)
无论通过open还是fopen打开文件,都必须先知道文件路径信息,尽管可能是相对路径。
如果知道了filename的内容,我们就可以定位它的绝对路径,也就是你说的完全路径。
1. filename本身就是绝对路径,ok。
2. filename是相对路径,那么先通过getcwd获取进程的执行路径,然后再获取绝对路径即可。
#include <unistd.h>
extern char *getcwd(char *buf, size_t size)
但是,如果进程在打开文件后又执行了chdir、fchdir之类函数的话,估计就不能够再获取文件路径信息了。
#include <unistd.h>
int chdir(const char *path)
int fchdir(int fildes)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)