Android ndk Android NDK JNI Rot13算法不工作;与gcc相同的算法非常有效-好主意?
我正在尝试使用NDK实现Rot13算法,但对于所有操作字符串缓冲区的不同方法,我无法实现 似乎是让原始字符串缓冲区在算法进行时接受新值。每次使用gcc时,相同的代码都会在 linux。我认为可能是优化器,但添加APP_OPTIM:=debug 我的Android.mk也不起作用。任何想法或帮助都将是伟大的Android ndk Android NDK JNI Rot13算法不工作;与gcc相同的算法非常有效-好主意?,android-ndk,java-native-interface,Android Ndk,Java Native Interface,我正在尝试使用NDK实现Rot13算法,但对于所有操作字符串缓冲区的不同方法,我无法实现 似乎是让原始字符串缓冲区在算法进行时接受新值。每次使用gcc时,相同的代码都会在 linux。我认为可能是优化器,但添加APP_OPTIM:=debug 我的Android.mk也不起作用。任何想法或帮助都将是伟大的 #define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO, "FOO", __VA_ARGS__)) jbyteArray
#define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO, "FOO", __VA_ARGS__))
jbyteArray Java_NativeUtils_foo(JNIEnv* env, jobject obj, jstring item)
{
int upper, i, a, c;
char p[9];
const char *d;
//char *p = item;
const char *s = (*env)->GetStringUTFChars(env, item, 0);
//len = (*env)->GetStringUTFLength(env, item);
//** make a copy
strncpy(p, s, 8);
p[8] = '\0';
(*env)->ReleaseStringUTFChars(env, item, s);
LOGI("GG1");
LOGI(p);
for (i=0; p[i] != 0; i++) {
LOGI("GG2");
a =~ (int)p[i];
c = ~a-1 / ( ~(a|32) / 13*2-11 ) * 13;
p[i] = (char)c;
//** for log output
d = (const char *)&c;
LOGI(d);
}
LOGI("GG3");
LOGI(p);
//** convert back to a Java type
jbyteArray out = (*env)->NewByteArray(env, 8);
(*env)->SetByteArrayRegion(env, out, 0, 8, (jbyte *)p);
LOGI("GG4");
LOGI(out);
return out;
}
输出:
( 3521): GG1
( 3521): 12345693
( 3521): GG2
( 3521): 1
( 3521): GG2
( 3521): 2
( 3521): GG2
( 3521): 3
( 3521): GG2
( 3521): 4
( 3521): GG2
( 3521): 5
( 3521): GG2
( 3521): 6
( 3521): GG2
( 3521): 9
( 3521): GG2
( 3521): 3
( 3521): GG3
( 3521): 12345693
( 3521): GG4
( 3521): ??
-( 3521): Rot13 in:12345693... out:12345693...
在ROT13算法中,唯一改变的字符是字母,数字保持不变。
ROT13('12345693')
等于'12345693'
在ROT13算法中,唯一更改的字符是字母,数字保持不变。
ROT13('12345693')
等于'12345693'
抓得好!谢谢你解释了很多。。。谢谢,接得好!谢谢你解释了很多。。。谢谢
the input is the same as the output and not shifted by 13 !
===============
GCC version
#include <stdio.h>
#include <string.h>
main(int argc, char** argv) {
int upper, i, a, c;
char p[9];
char *in;
in = argv[1];
strncpy(p, in, 8);
p[8] = '\0';
printf("in ...%s... p ...%s...", in, p);
for (i=0; p[i] != 0; i++) {
a =~ (int)p[i];
c = (~a-1 / ( ~(a|32) / 13*2-11 ) * 13);
p[i] = (char)c;
}
printf("out ...%s...", p);
//while(a=~getchar())putchar(~a-1/(~(a|32)/13*2-11)*13);}
}
$./a.out Serqql
in ...Serqql... p ...Serqql...out ...Freddy...