opencv的imread函数相对路径问题和 main 参数问题

参考:

https://blog.csdn.net/u013404374/article/details/80178822

https://blog.csdn.net/fujilove/article/details/19402561

https://blog.csdn.net/hopeneversleep/article/details/55798722

imread函数中,一个点代表省略当前文件夹路径,两个点则代表回到上一个文件夹路径。

1

cv::Mat img11 = cv::imread("./res/panda.bmp");

比如这个是,Visual Studio 2015ProjectsOpencv_cuda_test1Opencv_cuda_test1,工程文件路径下的res文件夹。

 cv::Mat img12 = cv::imread("../res/panda.bmp");

而这个则是,Visual Studio 2015ProjectsOpencv_cuda_test1 es,这里面的res。

 这也就是两个相对路径设置的不同方式。

另外如果实在读不出来图片,可能是系统将一些存在版权信息的图片屏蔽掉,这种情况我一般将其他各种文件格式的图片转换为BMP格式,虽然bmp格式压缩性能很差,但在编写代码阶段可以这么实现,以后换电脑就可以了。

2

分析原因:imread加载完整路径的格式是双斜杠,这与库自己的定义有关,就像halcon的完整路径是单反斜杠,大家注意下就OK了。

同样可以将第五行代码改为:

cv::Mat imagesrc = cv::imread("D:\test123\lena.bmp");
3
程序运行命令行中,程序名字 后面的第一个参数(作为字符串) 就是argv[1]。
argv[0]  是 程序名字。 位置参数总个数 是 argc.
例:
abc.exe  123
argv[1]  是 "123"   ,argv[0]  是 "abc.exe",   argc=2

4.int main(int argc,char* argv[])详解,以及与int main()有什么区别

K&R C 上5.10 命令行参数 中介绍的int main(int argc,char* argv[ ])

在 d: 编写 程序,并命名为 c.c
 
#include
int main(int argc, char ** argv) {     int i;     for (i=0; i < argc; i++)         printf("Argument %d is %s. ", i, argv[i]);
    return 0; }
在附件中找到命令提示符  输入 (exe文件的路径)(当然不是在编译器输入了)
 
如图所示

argc是命令行总的参数个数 argv[]是argc个参数,其中第0个参数是程序的全名,以后的参数命令行后面跟的用户输入的参数, ------------------------ char *argv[]是一个字符数组,其大小是int argc,      主要用于命令行参数argv[]参数,数组里每个元素代表一个参数; ------------------------ 例如: int main(int argc, char* argv[]) {     int i;     for (i=0;i<argc;i++)         cout<<argv[i]<<endl;//输入数组到argv[i]中     cin>>i;                 //输出数组argv[i]     return   0; } 比如你输入: test   a.c   b.c   t.c 输出如下: test a.c b.c t.c
则 argc   =   4
argv[0]   =   "test" argv[1]   =   "a.c" argv[2]   =   "b.c" argv[3]   =   "t.c" ------------------------------------------------------------------------------ 下面这段话感觉讲得比较清楚

main函数的参数
  前面介绍的main函数都是不带参数的。因此main 后的括号都是空括号。实际上,main函数可以带参数,这个参数可以认为是 main函数的形式参数。C语言规定main函数的参数只能有两个, 习惯上这两个参数写为argc和argv。因此,main函数的函数头可写为: main (argc,argv)C语言还规定argc(第一个形参)必须是整型变量,argv( 第二个形参)必须是指向字符串的指针数组。加上形参说明后,main函数的函数头应写为:  main (argc,argv) int argv; char *argv[];或写成: main (int argc,char *argv[])   由于main函数不能被其它函数调用, 因此不可能在程序内部取得实际值。那么,在何处把实参值赋予main函数的形参呢? 实际上,main函数的参数值是从操作系统命令行上获得的。当我们要运行一个可执行文件时,在DOS提示符下键入文件名,再输入实际参数即可把这些实参传送到main的形参中去。
  DOS提示符下命令行的一般形式为: C:>可执行文件名 参数 参数……; 但是应该特别注意的是,main 的两个形参和命令行中的参数在 位置上不是一一对应的。因为,main的形参只有二个,而命令行中的参数个数原则上未加限制。argc参数表示了命令行中参数的个数(注意:文件名本身也算一个参数),argc的值是在输入命令行时由系统按实际参数的个数自动赋予的。例如有命令行为: C:>E6 24 BASIC dbase FORTRAN由于文件名E6 24本身也算一个参数,所以共有4个参数,因此argc取得的值为4。argv参数是字符串指针数组,其各元素值为命令行中各字符串(参数均按字符串处理)的首地址。 指针数组的长度即为参数个数。数组元素初值由系统自动赋予。其表示如图6.8所示: main(int argc,char *argv){ while(argc-->1) printf("%s ",*++argv); } 本例是显示命令行中输入的参数如果上例的可执行文件名为e24.exe,存放在A驱动器的盘内。 因此输入的命令行为: C:>a:e24 BASIC dBASE FORTRAN  则运行结果为: BASIC dBASE FORTRAN   该行共有4个参数,执行main时,argc的初值即为4。argv的4个元素分为4个字符串的首地址。执行while语句,每循环一次 argv值减1,当argv等于1时停止循环,共循环三次, 因此共可输出三个参数。在printf函数中,由于打印项*++argv是先加1再打印, 故第一次打印的是argv[1]所指的字符串BASIC。第二、 三次循环分别打印后二个字符串。而参数e24是文件名,不必输出。
  下例的命令行中有两个参数,第二个参数20即为输入的n值。在程序中*++argv的值为字符串“20”,然后用函数"atoi"把它换为整型作为while语句中的循环控制变量,输出20个偶数。 #include"stdlib.h" main(int argc,char*argv[]){ int a=0,n; n=atoi(*++argv); while(n--) printf("%d ",a++*2); }   本程序是从0开始输出n个偶数。指向指针的指针变量如果一个指针变量存放的又是另一个指针变量的地址, 则称这个指针变量为指向指针的指针变量。

原文地址:https://www.cnblogs.com/MCSFX/p/10754474.html