- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
拜托,我需要帮助来释放分配给一个非常长的字符串的内存。我试图将代码缩减为包含我遇到的问题的这个小片段:
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include <stdio.h>
#include <limits.h>
#define N 6
#define E 1024
int M[N][N][N], R[N*N][N], C[N*N][N], F[N*N][N];
void init_rcf() {
int i, j, k, p;
p = 0;
for(j=0; j<N; j++) {
for(k=0; k<N; k++) {
for(i=0; i<N; i++)
R[p][i] = M[i][j][k];
p++;
}
}
p = 0;
for(i=0; i<N; i++) {
for(k=0; k<N; k++) {
for(j=0; j<N; j++)
C[p][j] = M[i][j][k];
p++;
}
}
p = 0;
for(i=0; i<N; i++) {
for(j=0; j<N; j++) {
for(k=0; k<N; k++)
F[p][k] = M[i][j][k];
p++;
}
}
}
char *bin(int n, int p) {
int c, d, count;
char *pointer;
count = 0;
pointer = (char*)malloc(p+1);
for (c = p-1;c >= 0;c--) {
d = n >> c;
if (d & 1)
*(pointer+count) = 1 + '0';
else
*(pointer+count) = 0 + '0';
count++;
}
*(pointer+count) = '\0';
return pointer;
}
int f0(int n) {
return ceil(log2(n+1));
}
int f1() {
int sum, max = 0;
for(int k=0;k<N;k++) {
for(int j=0;j<N;j++) {
for(int i=0;i<N-1;i++) {
sum = M[i][j][k] + M[i+1][j][k];
if (sum > max)
max = sum;
}
}
}
return max;
}
int f2() {
int sum, max = 0;
for(int k=0;k<N;k++) {
for(int i=0;i<N;i++) {
for(int j=0;j<N-1;j++) {
sum = M[i][j][k] + M[i][j+1][k];
if (sum > max)
max = sum;
}
}
}
return max;
}
int f3() {
int sum, max = 0;
for(int j=0;j<N;j++) {
for(int i=0;i<N;i++) {
for(int k=0;k<N-1;k++) {
sum = M[i][j][k] + M[i][j][k+1];
if (sum > max)
max = sum;
}
}
}
return max;
}
int f4() {
int m1 = f1(), m2 = f2(), m3 = f3();
if ((m1 >= m2) && (m1 >= m3)) return m1;
if ((m1 <= m2) && (m2 >= m3)) return m2;
if ((m1 <= m3) && (m2 <= m3)) return m3;
}
char *g_fxn() {
char *g = (char *) malloc(1 + (N*N*N)*3);
int k = f0(f4());
init_rcf();
strcpy(g,"");
for(int i=0; i<N*N; i++)
for(int j=0; j<N; j++)
strcat(g,bin(R[i][j],k));
for(int i=0; i<N*N; i++)
for(int j=0; j<N; j++)
strcat(g,bin(C[i][j],k));
for(int i=0; i<N*N; i++)
for(int j=0; j<N; j++)
strcat(g,bin(F[i][j],k));
return g;
}
void convert2bin(char *file_in) {
const char *FILENAME_IN = file_in;
const char FILENAME_OUT[] = "temp.txt";
char c, d;
int k=0;
FILE *infile;
FILE *outfile;
infile = fopen(FILENAME_IN, "rb");
outfile = fopen(FILENAME_OUT, "w");
if(infile == NULL){
fprintf(stderr, "Error: Source file not found.\n");
exit(EXIT_FAILURE);
}
while((c = fgetc(infile)) != EOF){
k++;
unsigned n = (sizeof(c) * CHAR_BIT) - 1;
for (int i=0; i<=n; i++) {
int m = (c >> (n-i)) & 1;
d = '0'+m;
fwrite(&d, 1, sizeof(d), outfile);
}
}
if (k < E) {
d = '1';
fwrite(&d, 1, sizeof(d), outfile);
for (int i=k; i<=E; i++) {
d = '0';
fwrite(&d, 1, sizeof(d), outfile);
}
}
fclose(infile);
fclose(outfile);
}
void digest() {
const char *FILENAME_IN = "temp.txt";
const char FILENAME_OUT[] = "digest.txt";
int size = N*N*N; // size of message to construct N*N*N matrix
char c, msg0[size], *msgf;
FILE *infile;
FILE *outfile;
infile = fopen(FILENAME_IN, "r");
outfile = fopen(FILENAME_OUT, "wb");
if(infile == NULL){
fprintf(stderr, "Error: Source file \"temp.txt\" not found.\n");
exit(EXIT_FAILURE);
}
int quit = 0;
while (quit == 0) {
msgf = (char *) malloc(1 + (size)*3);
strcpy(msgf, "");
strcpy(msg0, "");
int p = 0;
while(((c = fgetc(infile)) != EOF) && (p < size)) {
msg0[p++] = c;
}
if(c == EOF) quit = 1;
if (p > 0) {
if (p < size) {
msg0[p] = '1';
for(int i=p+1; i<size; i++)
msg0[i] = '0';
}
for (int k=0; k<N; k++)
for (int j=0; j<N; j++)
for (int i=0; i<N; i++) {
c = msg0[i + N * (j + N * k)];
if (c == '0')
M[i][j][k] = 0;
else
M[i][j][k] = 1;
}
strcpy(msgf, g_fxn());
int q = 0;
while (q<strlen(msgf)) {
int d;
char b = 0;
for (int r=0; r<8; r++) {
if (msgf[q++] == '0')
d = 0;
else
d = 1;
b = ((b<<1) | d);
}
fwrite(&b, 1, 1, outfile);
b = 0;
}
}
}
free(msgf);
fclose(infile);
fclose(outfile);
}
int main(int argc, char *argv[]){
if (argc!=2) {
fprintf(stderr, "Error: Provide name of one source file.\n");
exit(EXIT_FAILURE);
}
char *clear_file = argv[1];
convert2bin(clear_file);
digest();
printf("File successfully digested!\n");
return(0);
}
此代码适用于最多 27 个字节的输入文件,但超过 27 个字节时每次都会崩溃。
尝试调试后,我发现问题出在 strcpy(msgf, g_fxn());
对函数 g_fxn 的调用上,我的猜测是问题出现了来自为消息分配的大块内存,但之后似乎没有被释放。我猜这是因为当对 g_fxn 的调用较少但调用较多时代码会崩溃。
有人知道我该如何解决这个问题吗?
最佳答案
msgf 多次在函数 digest() 的 while 循环中分配:
msgf = (char *) malloc(1 + (size)*3);
但是 free() 只在循环后被调用一次:
free(msgf);
这至少是我发现的一个内存泄漏。
关于c - 释放为 C 中的一个很长的字符串 (char*) 分配的内存?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31272416/
这个问题在这里已经有了答案: Isn't an Int64 equal to a long in C#? (2 个答案) 关闭 9 年前。 它不应该是一个整数类型吗? 这样,一些使用 int 的函数
当我遇到一些我想知道的事情时,我正忙着解析一个二进制文件。 Stream.Position属性的类型为Int64或long。为什么是这样?因为流中的位置不能为负,所以使用 UInt64 不是更有意义吗
所以第一部分是我从用户那里获得输入,在本例中,输入是“1”作为从另一个函数接收的字符值。 printf ("\nPlease enter 1, 2, 3 or q: "); option =
我正在尝试使用以下代码从 REST 服务返回 JSON: $categories = $categoriesController->listAll(); if($categories){ hea
我阅读了文档,它说 long 是 %li,但打印输出返回为 -2147024891。是什么赋予了? 最佳答案 您甚至没有提供要打印的号码,但我猜您已经无意中发现了签名打印和未签名打印之间的区别。 使用
我正在创建自定义购物车,我正在构建一个查询,该查询从检索我刚刚保存到购物车表中的 session_id 开始。我知道这个值被保存了,我在 mysql 命令行运行这个查询,它返回我需要的但我没有将值放入
我有一个包含 textView 的 scrollView。如果文本很长并且不适合屏幕,我想增加 textView 高度(我想我可以通过添加 NSLayoutConstraint outlet 并修改它
我有一个基本的数据库处理程序类,其中有一个使用 PDO::FETCH_ASSOC 参数返回结果集的公共(public)方法: public function resultSet() { $th
在后台线程中,我调用 PublishSubject.onNext(); 并在主线程中通过 subscribe(PublishSubject.filter(message -> message.getI
我想知道为什么 Amazon Web Services 控制台登录页面有这么长的 url?为什么不只发布数据而不显示其中包含大量数据的冗长 url。以这种方式实现有什么充分的理由吗? 最佳答案 我认为
这个问题在这里已经有了答案: Can I mix MySQL APIs in PHP? (4 个答案) 关闭 6 年前。 希望我犯了一个快速而明显的错误,我浏览了 previous question
我得到了答案:如果我禁用了cookie,那么使用URL重定向我可以传递JSESSIONID,但我的URL已经很长,因为我使用它有约束的GET方法。那怎么办我应该使用我的 session 吗?我希望我的
目前,当我使用 DOMDocument 对象并调用 saveHTML() 时,它会自动添加一些我不需要的 html 标签。我尝试了此处建议的解决方案 ( https://stackoverflow.c
我是一名优秀的程序员,十分优秀!