你用UTF8试试,这个包含的符号比较全,不要用默认字符,这并不能保证一定会一致
比如2个字节可以转化成1个空字符,1个字节也可以转化成1个空字符,这种情况,2个字节变成字符再转成字节,就会变成1个字节。
//从流中还原图片Image image = Image.FromStream(你获取的图片流)
//显示图片
PictureBox pic = new PictureBox()
pic.Image = image
//保存图片
image.Save(@"c:\pic.jpg")
使用read()函数以下为百度百科的介绍函数名:read
功 能:从文件中读
函数原型 :int read(int handle, void *buf, int nbyte)
表头文件:#include <unistd.h>
函数说明:read()会把参数handle所指的文件传送nbyte个字节到buf指针所指的内存中。若参数nbyte为0,则read()不会有作用并返回0。返回值为实际读取到的字节数,如果返回0,表示已到达文件尾或无可读取的数据。
程序例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#include <stdio.h>
#include <io.h>
#include <alloc.h>
#include <fcntl.h>
#include <process.h>
#include <sys\stat.h>
int main(void)
{
void *buf
int handle, bytes
buf = malloc(10)
/*
Looks for a file in the current directory named TEST.$$$ and attempts
to read 10 bytes from it. To use this example you should create the
file TEST.$$$
*/
if ((handle =
open("TEST.$$$", O_RDONLY | O_BINARY, S_IWRITE | S_IREAD)) == -1)
{
printf("Error Opening File\n")
exit(1)
}
if ((bytes = read(handle, buf, 10)) == -1) {
printf("Read Failed.\n")
exit(1)
}
else {
printf("Read: %d bytes read.\n", bytes)
}
return 0
}
2Linux C
编辑
定义函数
ssize_t read(int fd, void *buf, size_t count)
返回值
成功返回读取的字节数,出错返回-1并设置errno,如果在调read之前已到达文件末尾,则这次read返回0。
参数
参数count是请求读取的字节数,读上来的数据保存在缓冲区buf中,同时文件的当前读写位置向后移。注意这个读写位置和使用C标准I/O库时的读写位置有可能不同,这个读写位置是记在内核中的,而使用C标准I/O库时的读写位置是用户空间I/O缓冲区中的位置。比如用fgetc读一个字节,fgetc有可能从内核中预读1024个字节到I/O缓冲区中,再返回第一个字节,这时该文件在内核中记录的读写位置是1024,而在FILE结构体中记录的读写位置是1。注意返回值类型是ssize_t,表示有符号的size_t,这样既可以返回正的字节数、0(表示到达文件末尾)也可以返回负值-1(表示出错)。
read函数返回时,返回值说明了buf中前多少个字节是刚读上来的。有些情况下,实际读到的字节数(返回值)会小于请求读的字节数count,例如:读常规文件时,在读到count个字节之前已到达文件末尾。例如,距文件末尾还有30个字节而请求读100个字节,则read返回30,下次read将返回0。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)