arm6410,linux,c语言,read函数返回-1,错误:bad address
采用串口通信,部分代码如下:intnread,i=0;while(i<10){char*myBuff2="#000000#000000#000000#000000T000...
采用串口通信,部分代码如下:
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++;
} 展开
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++;
} 展开
展开全部
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
2、read()函数是文件操作函数,在c语言中很重要。
函数的返回值如下:
(1)如果成功,返回读取的字节数;
(2)如果出错,返回-1并设置errno;
(3)如果在调read函数之前已是文件末尾,则返回0
威孚半导体技术
2024-08-19 广告
2024-08-19 广告
威孚(苏州)半导体技术有限公司是一家专注生产、研发、销售晶圆传输设备整机模块(EFEM/SORTER)及核心零部件的高科技半导体公司。公司核心团队均拥有多年半导体行业从业经验,其中技术团队成员博士、硕士学历占比80%以上,依托丰富的软件底层...
点击进入详情页
本回答由威孚半导体技术提供
展开全部
可以事先检查一下传递给 read()() 函数的 fd 是否合法, 即在 'if ((nread = read(fd,myBuff2,strlen(myBuff2)))>0)' 之前判断 if ( fd == NULL ) printf("出错啦!\n");
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
应该先调用 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 <stdio.h>
#include <fcntl.h>
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;
}
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 <stdio.h>
#include <fcntl.h>
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;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
上步连接出错了,感觉该是没连上,你就去读写了,描述符不对
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询