问题的原因是,在对地址进行map的时候,发现封到函数中,不能改变地址的值,
void BaseVirtMap(unsigned int *map_base,unsigned int *virt_addr)
{
int dev_mem_fd;
if( ( dev_mem_fd = open( "/dev/mem", O_RDWR | O_SYNC ) ) == -1 ) FATAL;
printf("begin map\r\n");
map_base = (unsigned int *)mmap( 0, MAP_SIZE, PROT_READ | PROT_WRITE, MAP_SHARED, dev_mem_fd, RX_BUFFER_BASE & ~MAP_MASK ); //Ê×µØÖ·ÊÇÈ¡½ÓÊÕ»º³åÇø»ùµØÖ·µÄÇ°20bit+12bitµÄ0
virt_addr = map_base + ( RX_BUFFER_BASE & MAP_MASK ); //DMAµÄµØÖ·
close(dev_mem_fd);
printf("map finished\r\n");
}
函数
unsigned int map_base=NULL,virt_addr=NULL;
BaseVirtMap(map_base,virt_addr);
If(virt_addr==NULL)
Printf(“virt fault\r\n”);
这种情况,不能改变virt_addr的值,而需要,声明
void BaseVirtMap(unsigned int *&map_base,unsigned int *&virt_addr){..}
就可以了
为什么需要使用它们
当我们把一个指针做为参数传一个方法时,其实是把指针的复本传递给了方法,也可以说传递指针是指针的值传递。
如果我们在方法内部修改指针会出现问题,在方法里做修改只是修改的指针的copy而不是指针本身,原来的指针还保留着原来
的值。我们用下边的代码说明一下问题:
int m_value = 1;
void func(int *p)
{
p = &m_value;
}
int main(int argc, char *argv[])
{
int n = 2;
int *pn = &n;
cout << *pn << endl;
func(pn);
cout << *pn <<endl;
return 0;
}
输出的是两个2
另一种解决方法是使用指针的指针
展示一下使用指针的指针做为参数
void func(int **p)
{
*p = &m_value;
// 也可以根据你的需求分配内存
*p = new int;
**p = 5;
}
int main(int argc, char *argv[])
{
int n = 2;
int *pn = &n;
cout << *pn << endl;
func(&pn);
cout << *pn <<endl;
return 0;
}
我们看一下 func(int **p)这个方法
- p: 是一个指针的指针,在这里我们不会去对它做修改,否则会丢失这个指针指向的指针地址
- *p: 是被指向的指针,是一个地址。如果我们修改它,修改的是被指向的指针的内容。换句话说,我们修改的是main()方法里 *pn指针
- **p: 两次解引用是指向main()方法里*pn的内容
再看一下指针的引用的方式
int m_value = 1;
void func(int *&p)
{
p = &m_value;
// 也可以根据你的需求分配内存
p = new int;
*p = 5;
}
int main(int argc, char *argv[])
{
int n = 2;
int *pn = &n;
cout << *pn << endl;
func(pn);
cout << *pn <<endl;
return 0;
}
看一下func(int *&p)方法
- p: 是指针的引用,main()方法里的 *pn
- *p:是main()方法里的pn指向的内容
Linux下C++编写的参数问题
Main里面两个参数,一个argc是输入参数的个数,argv数组是各个参数,从1开始访问第一个参数,详细可百度
Argc 默认是1,argc[0],当前路径
Argv是字符串的指针(指针的指针)
这样访问到字符串参数的内容,此处c是字符,这个程序参数只输入一个字符,仅表示访问字符的方法。