采用串口通信,部分代码如下:
int nread,i=0 ;
while(i<10)
{
char *myBuff2="#000000#000000#000000#000000T000\r\n";
char myBuff4[]="#222222#222222#222222#222222T222\r\n";
if ((nread = read(fd,myBuff2,strlen(myBuff2)))>0)
{
printf("nLen %d\n",nread);
memcpy(myBuff4, myBuff2, strlen(myBuff2));
printf("hello\n");
printf("%s\n",myBuff4);
printf("hi\n");
}
else
{
printf("出错啦!\n");
perror("read:");
}
i++;
}
arm6410,linux,c语言,read函数返回-1,错误:bad address
答案:4 悬赏:20 手机版
解决时间 2021-02-26 04:32
- 提问者网友:不要迷恋哥
- 2021-02-25 08:25
最佳答案
- 五星知识达人网友:佘樂
- 2021-02-25 09:01
可以事先检查一下传递给 read() 函数的 fd 是否合法, 即在 'if ((nread = read(fd,myBuff2,strlen(myBuff2)))>0)' 之前判断 if ( fd == NULL ) printf("出错啦!\n");
全部回答
- 1楼网友:等灯
- 2021-02-25 11:28
上步连接出错了,感觉该是没连上,你就去读写了,描述符不对
- 2楼网友:野慌
- 2021-02-25 09:57
应该先调用 open 函数
if( fd = open(“路径名”,O_WRONLY) == -1)
{
perror("open failed");
}
这样保证你的fd 参数才是有效的;
然后 char *myBuff2="#000000#000000#000000#000000T000\r\n"; 是有问题的,
myBuff2 指针指向的是只读的数据段,不可以修改, 你把它变成数组
char myBuff2[]="#000000#000000#000000#000000T000\r\n"; 就没问题了
示例:
#include
#include
int main(int argc, char *argv[])
{
int nread,i=0 ;
int fd;
if( fd = open("./hello.c",O_WRONLY) == -1)
{
perror("open failed");
return -1;
}
printf("open success \n");
while(i<10)
{
char *myBuff2="#000000#000000#000000#000000T000\r\n";
char myBuff4[]="#222222#222222#222222#222222T222\r\n";
if ((nread = read(fd,myBuff4,strlen(myBuff2)))>0)
{
printf("nLen %d\n",nread);
memcpy(myBuff4, myBuff2, strlen(myBuff2));
printf("hello\n");
printf("%s\n",myBuff4);
printf("hi\n");
}
else
{
printf("出错啦 !\n");
perror("read:");
}
i++;
}
return nread;
}
- 3楼网友:纵马山川剑自提
- 2021-02-25 09:47
1、可以事先检查一下传递给 read() 函数的 fd 是否合法,即在 'if ((nread = read(fd,myBuff2,strlen(myBuff2)))>0)' 之前判断 if ( fd == NULL ) printf("出错啦!\n");
2、read()函数是文件操作函数,在c语言中很重要。
函数的返回值如下:
(1)如果成功,返回读取的字节数;
(2)如果出错,返回-1并设置errno;
(3)如果在调read函数之前已是文件末尾,则返回0
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯