JNI学习之C语言第5天

#define _CRT_SECURE_NO_WARNINGS


#include <stdlib.h>
#include <stdio.h>

#include <string.h>


//联合体(共用体)
// 不同类型的变量共占用一段内存(相互覆盖),联合变量任何时刻只有一个成员存在
//目的节省内存
//大小:联合体变量的大小=最大的成员所占的字节数
/*
union MyValue{
int x;
int y;
double z;
};
void main(){
union MyValue d1;
d1.x = 5;
d1.y = 6;
d1.z = 1.2;
//输出结果为只有d1.z有值,最后一次赋值的有效。
printf("%d,%d,%lf\n",d1.x,d1.y,d1.z);
getchar();
}
*/


//枚举(用来列举所有的情况)
//限定值,保证取值的安全性
//固定的数据
/*
enum Day{
MonDay,
TuesDay,
WednesDay,
ThursDay,
FriDay,
SaturDay,
SunDay
};
void main(){
//枚举的值,必须是括号中的值
enum Day d = ThursDay;
//输出 3.就是从0开始
printf("%#x,%d\n",&d,d);
getchar();
}
*/

//IO  在c中读取文本文件
/*
void main(){
char path[] = "D:\\s.txt";

FILE *fp = fopen(path,"r");


if (fp == NULL){
printf("读取失败");
return;
}
char buff[50];//缓存
while (fgets(buff,50,fp)){
printf("%s",buff);
}
fclose(fp);
system("pause");
getchar();


}
*/


//写入文本文件 ,换行\n
/*
void main(){
char *path = "D:\\s.txt";
FILE *fp = fopen(path, "w");
char *text = "hhhhhhhhh";
fputs(text,fp);


fclose(fp);
getchar();


}
*/


//计算机的文件存储在物理上都是二进制
// 文件文本和二进制之分,其实是一个逻辑之分
//c读写文本文件与二进制文件的差别仅仅体现在回车换行符
//写文本时,每遇到一个'\n',会将其转换成'\r\n'
//读文本时,'\r\n',转换'\\n'
//文件复制
/*
void main(){
char *path = "";
//读的文件,加入b字符表示操作二进制文件binary
FILE *read_fp = fopen(path,"rb");
//写的二进制文件,在后面加一个b
FILE* write_fp = fopen(path,"wb");

int buff[50];//缓冲区域
int len = 0; //每次读取到的数据长度
while ((len = fread(buff,sizeof(int),50,read_fp)) != 0){
//將读到的内容写入新的文件
fwrite(buff,sizeof(int),len,write_fp);
}





//关闭流
gclose(write_fp);
gclose(read_fp);
getchar();



}
*/


//获取文件的大小
/*
void main(){
char *read_path = "";
FILE *fp = fopen(read_path,"r");
//类似java中的RandAccessFile,游标,指向文件的指定位置
//重新定位文件指针,seek_end,定位到文件末尾,
fseek(fp,0,SEEK_END);
//返回当前的文件指针,相对于文件开头的位移量
long file_size = ftell(fp);
printf("%ld\n",file_size);
getchar();
}
*/


//练习,文本文件加密,解密
//异或运算规则。1^0 = 1, 0^1=1, 1^1=0, 0^0=0 相同为0,不同为1
//列子 8^9 = 
//1000
//1001
//0001;结果为1.
//在异或一次
//结果为9
//加密
/*
void crpypt(char *path,char* crypt_path){
//打开文件
FILE *normal_fp = fopen(path,"r");
FILE* crypt_fp = fopen(crypt_path,"w");
//文本文件加解密是一次读取一个字节
int ch;
while ((ch = fgetc(normal_fp))!= EOF){//End of File
//加密(异或运算)
fputc(ch^9,crypt_fp);
}
fclose(normal_fp);
fclose(crypt_fp);
}


//解密
void decrpypt(char* crypt_path,char* decrypt_path){
FILE *crypt_path = fopen(crypt_path,"r");
FILE* decrypt_path = fopen(decrypt_path,"w");
int ch;
while ((ch = fgetc(crypt_path))!= EOF){
fputc(ch^9,decrypt_path);
}
fclose(crypt_path);
fclose(decrypt_path);
}


void main(){

getchar();
}
*/


//二进制文件加解密
//读取二进制文件的数据时,一个一个字符读取,
//密码:fourlm 用于循环异或
void crpypt(char *path, char* crypt_path,char * password){
//打开文件
FILE *normal_fp = fopen(path, "rb");
FILE* crypt_fp = fopen(crypt_path, "wb");
//文本文件加解密是一次读取一个字节
int i = 0;//循环使用密码中的字母进行异或运算
int pwd_len = strlen(password);//密码的长度
int ch;
while ((ch = fgetc(normal_fp)) != EOF){//End of File
//加密(异或运算)
fputc(ch ^ password[i % pwd_len], crypt_fp);
i++;
}
fclose(normal_fp);
fclose(crypt_fp);
}


//解密
void decrpypt(char* crypt_path, char* decrypt_path,char * password){
FILE *crypt_path = fopen(crypt_path, "rb");
FILE* decrypt_path = fopen(decrypt_path, "wb");
int psw_len = strlen(password);
int i = 0;
int ch;
while ((ch = fgetc(crypt_path)) != EOF){
fputc(ch ^ password[i % psw_len], decrypt_path);
i++;
}
fclose(crypt_path);
fclose(decrypt_path);
}


void main(){


getchar();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值