1

我们正在尝试运行此处提供的 Tess4J 测试:http: //tess4j.sourceforge.net/

测试适用于英语,但是当我将语言偏好更改为土耳其语时,它们会崩溃。我正在更改的代码是:

public void testTessBaseAPIRect() throws Exception {
        System.out.println("TessBaseAPIRect");
        String expResult = expOCRResult;
        String lang = "tur"; //this line is changed from "eng" to "tur"
        File tiff = new File("testTur.png");
        BufferedImage image = ImageIO.read(tiff); // require jai-imageio lib to read TIFF
        ByteBuffer buf = ImageIOHelper.convertImageData(image);
        int bpp = image.getColorModel().getPixelSize();
        int bytespp = bpp / 8;
        int bytespl = (int) Math.ceil(image.getWidth() * bpp / 8.0);
        TessAPI1.TessBaseAPIInit3(handle, "tessdata", lang);
        TessAPI1.TessBaseAPISetPageSegMode(handle, TessAPI1.TessPageSegMode.PSM_AUTO);
        Pointer utf8Text = TessAPI1.TessBaseAPIRect(handle, buf, bytespp, bytespl, 0, 0, 1024, 800);
        String result = utf8Text.getString(0);
        TessAPI1.TessDeleteText(utf8Text);
        System.out.println(result);
        assertEquals(expResult, result.substring(0, expResult.length()));
    }

错误的堆栈跟踪是:

Java frames: (J=compiled Java code, j=interpreted, Vv=VM code)
j  net.sourceforge.tess4j.TessAPI1.TessBaseAPIRect(Lnet/sourceforge/tess4j/TessAPI1$TessBaseAPI;Ljava/nio/ByteBuffer;IIIIII)Lcom/sun/jna/Pointer;+0
j  net.sourceforge.tess4j.TessAPI1Test.testTessBaseAPIRect()V+112
v  ~StubRoutines::call_stub
j  sun.reflect.NativeMethodAccessorImpl.invoke0(Ljava/lang/reflect/Method;Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+0
j  sun.reflect.NativeMethodAccessorImpl.invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+87
j  sun.reflect.DelegatingMethodAccessorImpl.invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+6
j  java.lang.reflect.Method.invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+57
j  org.junit.runners.model.FrameworkMethod$1.runReflectiveCall()Ljava/lang/Object;+15
j  org.junit.internal.runners.model.ReflectiveCallable.run()Ljava/lang/Object;+1
j  org.junit.runners.model.FrameworkMethod.invokeExplosively(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+10
j  org.junit.internal.runners.statements.InvokeMethod.evaluate()V+12
j  org.junit.internal.runners.statements.RunBefores.evaluate()V+49
j  org.junit.internal.runners.statements.RunAfters.evaluate()V+12
j  org.junit.runners.ParentRunner.runLeaf(Lorg/junit/runners/model/Statement;Lorg/junit/runner/Description;Lorg/junit/runner/notification/RunNotifier;)V+17
j  org.junit.runners.BlockJUnit4ClassRunner.runChild(Lorg/junit/runners/model/FrameworkMethod;Lorg/junit/runner/notification/RunNotifier;)V+32
j  org.junit.runners.BlockJUnit4ClassRunner.runChild(Ljava/lang/Object;Lorg/junit/runner/notification/RunNotifier;)V+6
j  org.junit.runners.ParentRunner$3.run()V+12
j  org.junit.runners.ParentRunner$1.schedule(Ljava/lang/Runnable;)V+1
j  org.junit.runners.ParentRunner.runChildren(Lorg/junit/runner/notification/RunNotifier;)V+40
j  org.junit.runners.ParentRunner.access$000(Lorg/junit/runners/ParentRunner;Lorg/junit/runner/notification/RunNotifier;)V+2
j  org.junit.runners.ParentRunner$2.evaluate()V+8
j  org.junit.internal.runners.statements.RunBefores.evaluate()V+49
j  org.junit.internal.runners.statements.RunAfters.evaluate()V+12
j  org.junit.runners.ParentRunner.run(Lorg/junit/runner/notification/RunNotifier;)V+20
j  junit.framework.JUnit4TestAdapter.run(Ljunit/framework/TestResult;)V+13
j  org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.run()V+707
j  org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.launch(Lorg/apache/tools/ant/taskdefs/optional/junit/JUnitTest;[Ljava/lang/String;ZZZZZZ)I+41
j  org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.main([Ljava/lang/String;)V+918
v  ~StubRoutines::call_stub

我将 tur.traineddata 移到了 Tess4J 的 tesseract 文件夹下。当我从命令行运行 tesseract 时,它也适用于 tesseract。提前致谢。

编辑:我添加了我正在尝试测试土耳其语的文件。

在此处输入图像描述

编辑 2:完整的堆栈跟踪:

#
# A fatal error has been detected by the Java Runtime Environment:
#
#  EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x646a2e00, pid=3256, tid=5948
#
# JRE version: 7.0_25-b17
# Java VM: Java HotSpot(TM) Client VM (23.25-b01 mixed mode, sharing windows-x86 )
# Problematic frame:
# C  [libtesseract302.dll+0xf2e00]  STRING::split+0x27cf0
#
# Failed to write core dump. Minidumps are not enabled by default on client versions of Windows
#
# If you would like to submit a bug report, please visit:
#   http://bugreport.sun.com/bugreport/crash.jsp
# The crash happened outside the Java Virtual Machine in native code.
# See problematic frame for where to report the bug.
#

---------------  T H R E A D  ---------------

Current thread (0x0115c000):  JavaThread "main" [_thread_in_native, id=5948, stack(0x00930000,0x00980000)]

siginfo: ExceptionCode=0xc0000005, reading address 0x05e1d000

Registers:
EAX=0x05e1d002, EBX=0x0680a020, ECX=0x00000280, EDX=0x00000400
ESP=0x0097e03c, EBP=0x00000000, ESI=0x06030de0, EDI=0x05e1c600
EIP=0x646a2e00, EFLAGS=0x00010283

Top of Stack: (sp=0x0097e03c)
0x0097e03c:   cf9c9600 056b73d0 06030de0 64c06870
0x0097e04c:   056b73d0 00001000 0097e08c 02673ab9
0x0097e05c:   00000000 29d140e0 29ce9ad8 00000000
0x0097e06c:   0097e06c 386f7e82 0097e0a8 390fa4f0
0x0097e07c:   65626100 61616562 00000000 0097e0a0
0x0097e08c:   cedf1e2c 0097e0d0 674c744a 0097e0b0
0x0097e09c:   64a628f8 00000000 0097e8f0 64a628f8
0x0097e0ac:   0097e8fc 0097e114 0097e8ac 646c89f0 

Instructions: (pc=0x646a2e00)
0x646a2de0:   88 00 00 00 00 00 00 00 7e 5d 8b 56 30 03 c0 03
0x646a2df0:   c0 89 44 24 14 33 c9 85 d2 7e 31 8d 47 02 8b ff
0x646a2e00:   0f b6 50 fe 0f b6 68 ff c1 e2 08 0b d5 0f b6 28
0x646a2e10:   c1 e2 08 0b d5 0f b6 68 01 c1 e2 08 0b d5 89 14 


Register to memory mapping:

EAX=0x05e1d002 is an unknown value
EBX=0x0680a020 is an unknown value
ECX=0x00000280 is an unknown value
EDX=0x00000400 is an unknown value
ESP=0x0097e03c is pointing into the stack for thread: 0x0115c000
EBP=0x00000000 is an unknown value
ESI=0x06030de0 is an unknown value
EDI=0x05e1c600 is an unknown value


Stack: [0x00930000,0x00980000],  sp=0x0097e03c,  free space=312k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
C  [libtesseract302.dll+0xf2e00]  STRING::split+0x27cf0

[error occurred during error reporting (printing native stack), id 0xc0000005]

Java frames: (J=compiled Java code, j=interpreted, Vv=VM code)
j  net.sourceforge.tess4j.TessAPI1.TessBaseAPIGetUTF8Text(Lnet/sourceforge/tess4j/TessAPI1$TessBaseAPI;)Lcom/sun/jna/Pointer;+0
j  net.sourceforge.tess4j.TessAPI1Test.testTessBaseAPIGetUTF8Text()V+143
v  ~StubRoutines::call_stub
j  sun.reflect.NativeMethodAccessorImpl.invoke0(Ljava/lang/reflect/Method;Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+0
j  sun.reflect.NativeMethodAccessorImpl.invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+87
j  sun.reflect.DelegatingMethodAccessorImpl.invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+6
j  java.lang.reflect.Method.invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+57
j  org.junit.runners.model.FrameworkMethod$1.runReflectiveCall()Ljava/lang/Object;+15
j  org.junit.internal.runners.model.ReflectiveCallable.run()Ljava/lang/Object;+1
j  org.junit.runners.model.FrameworkMethod.invokeExplosively(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+10
j  org.junit.internal.runners.statements.InvokeMethod.evaluate()V+12
j  org.junit.internal.runners.statements.RunBefores.evaluate()V+49
j  org.junit.internal.runners.statements.RunAfters.evaluate()V+12
j  org.junit.runners.ParentRunner.runLeaf(Lorg/junit/runners/model/Statement;Lorg/junit/runner/Description;Lorg/junit/runner/notification/RunNotifier;)V+17
j  org.junit.runners.BlockJUnit4ClassRunner.runChild(Lorg/junit/runners/model/FrameworkMethod;Lorg/junit/runner/notification/RunNotifier;)V+32
j  org.junit.runners.BlockJUnit4ClassRunner.runChild(Ljava/lang/Object;Lorg/junit/runner/notification/RunNotifier;)V+6
j  org.junit.runners.ParentRunner$3.run()V+12
j  org.junit.runners.ParentRunner$1.schedule(Ljava/lang/Runnable;)V+1
j  org.junit.runners.ParentRunner.runChildren(Lorg/junit/runner/notification/RunNotifier;)V+40
j  org.junit.runners.ParentRunner.access$000(Lorg/junit/runners/ParentRunner;Lorg/junit/runner/notification/RunNotifier;)V+2
j  org.junit.runners.ParentRunner$2.evaluate()V+8
j  org.junit.internal.runners.statements.RunBefores.evaluate()V+49
j  org.junit.internal.runners.statements.RunAfters.evaluate()V+12
j  org.junit.runners.ParentRunner.run(Lorg/junit/runner/notification/RunNotifier;)V+20
j  junit.framework.JUnit4TestAdapter.run(Ljunit/framework/TestResult;)V+13
j  org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.run()V+707
j  org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.launch(Lorg/apache/tools/ant/taskdefs/optional/junit/JUnitTest;[Ljava/lang/String;ZZZZZZ)I+41
j  org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.main([Ljava/lang/String;)V+918
v  ~StubRoutines::call_stub

---------------  P R O C E S S  ---------------

Java Threads: ( => current thread )
  0x04ec0000 JavaThread "Java2D Disposer" daemon [_thread_blocked, id=784, stack(0x051b0000,0x05200000)]
  0x01069c00 JavaThread "Service Thread" daemon [_thread_blocked, id=4172, stack(0x04c90000,0x04ce0000)]
  0x01060800 JavaThread "C1 CompilerThread0" daemon [_thread_blocked, id=3552, stack(0x04bf0000,0x04c40000)]
  0x0105f400 JavaThread "Attach Listener" daemon [_thread_blocked, id=4164, stack(0x010e0000,0x01130000)]
  0x0105c400 JavaThread "Signal Dispatcher" daemon [_thread_blocked, id=4124, stack(0x049e0000,0x04a30000)]
  0x01045800 JavaThread "Finalizer" daemon [_thread_blocked, id=3604, stack(0x048e0000,0x04930000)]
  0x01044000 JavaThread "Reference Handler" daemon [_thread_blocked, id=5824, stack(0x04850000,0x048a0000)]
=>0x0115c000 JavaThread "main" [_thread_in_native, id=5948, stack(0x00930000,0x00980000)]

Other Threads:
  0x01042400 VMThread [stack: 0x046e0000,0x04730000] [id=2280]
  0x0108d800 WatcherThread [stack: 0x04a40000,0x04a90000] [id=5332]

VM state:not at safepoint (normal execution)

VM Mutex/Monitor currently owned by a thread: None

Heap
 def new generation   total 4928K, used 485K [0x246f0000, 0x24c40000, 0x29c40000)
  eden space 4416K,   3% used [0x246f0000, 0x24719c48, 0x24b40000)
  from space 512K,  62% used [0x24bc0000, 0x24c0f7e0, 0x24c40000)
  to   space 512K,   0% used [0x24b40000, 0x24b40000, 0x24bc0000)
 tenured generation   total 10944K, used 3308K [0x29c40000, 0x2a6f0000, 0x346f0000)
   the space 10944K,  30% used [0x29c40000, 0x29f7b1b0, 0x29f7b200, 0x2a6f0000)
 compacting perm gen  total 12288K, used 2764K [0x346f0000, 0x352f0000, 0x386f0000)
   the space 12288K,  22% used [0x346f0000, 0x349a33e0, 0x349a3400, 0x352f0000)
    ro space 10240K,  45% used [0x386f0000, 0x38b79b28, 0x38b79c00, 0x390f0000)
    rw space 12288K,  54% used [0x390f0000, 0x3977d0e8, 0x3977d200, 0x39cf0000)

Card table byte_map: [0x00ac0000,0x00b70000] byte_map_base: 0x0099c880

Polling page: 0x00210000

Code Cache  [0x02670000, 0x02750000, 0x04670000)
 total_blobs=357 nmethods=176 adapters=116 free_code_cache=31891Kb largest_free_block=32657280

Compilation events (10 events):
Event: 3.683 Thread 0x01060800  172             java.util.zip.Inflater::ensureOpen (47 bytes)
Event: 3.683 Thread 0x01060800 nmethod 172 0x02748ac8 code [0x02748bd0, 0x02748cdc]
Event: 3.691 Thread 0x01060800  173   !         java.util.zip.InflaterInputStream::read (138 bytes)
Event: 3.692 Thread 0x01060800 nmethod 173 0x02749048 code [0x027491f0, 0x02749a54]
Event: 3.692 Thread 0x01060800  174   !         java.util.zip.Inflater::inflate (74 bytes)
Event: 3.692 Thread 0x01060800 nmethod 174 0x0274a148 code [0x0274a280, 0x0274a5f0]
Event: 3.692 Thread 0x01060800  176             java.util.zip.InflaterInputStream::ensureOpen (18 bytes)
Event: 3.692 Thread 0x01060800 nmethod 176 0x0274a848 code [0x0274a950, 0x0274aa4c]
Event: 3.695 Thread 0x01060800  177             java.io.DataInputStream::readFully (63 bytes)
Event: 3.695 Thread 0x01060800 nmethod 177 0x0274aac8 code [0x0274abf0, 0x0274add4]

GC Heap History (6 events):
Event: 0.590 GC heap before
{Heap before GC invocations=0 (full 0):
 def new generation   total 4928K, used 4416K [0x246f0000, 0x24c40000, 0x29c40000)
  eden space 4416K, 100% used [0x246f0000, 0x24b40000, 0x24b40000)
  from space 512K,   0% used [0x24b40000, 0x24b40000, 0x24bc0000)
  to   space 512K,   0% used [0x24bc0000, 0x24bc0000, 0x24c40000)
 tenured generation   total 10944K, used 0K [0x29c40000, 0x2a6f0000, 0x346f0000)
   the space 10944K,   0% used [0x29c40000, 0x29c40000, 0x29c40200, 0x2a6f0000)
 compacting perm gen  total 12288K, used 1564K [0x346f0000, 0x352f0000, 0x386f0000)
   the space 12288K,  12% used [0x346f0000, 0x34877068, 0x34877200, 0x352f0000)
    ro space 10240K,  45% used [0x386f0000, 0x38b79b28, 0x38b79c00, 0x390f0000)
    rw space 12288K,  54% used [0x390f0000, 0x3977d0e8, 0x3977d200, 0x39cf0000)
Event: 0.593 GC heap after
Heap after GC invocations=1 (full 0):
 def new generation   total 4928K, used 512K [0x246f0000, 0x24c40000, 0x29c40000)
  eden space 4416K,   0% used [0x246f0000, 0x246f0000, 0x24b40000)
  from space 512K, 100% used [0x24bc0000, 0x24c40000, 0x24c40000)
  to   space 512K,   0% used [0x24b40000, 0x24b40000, 0x24bc0000)
 tenured generation   total 10944K, used 676K [0x29c40000, 0x2a6f0000, 0x346f0000)
   the space 10944K,   6% used [0x29c40000, 0x29ce9128, 0x29ce9200, 0x2a6f0000)
 compacting perm gen  total 12288K, used 1564K [0x346f0000, 0x352f0000, 0x386f0000)
   the space 12288K,  12% used [0x346f0000, 0x34877068, 0x34877200, 0x352f0000)
    ro space 10240K,  45% used [0x386f0000, 0x38b79b28, 0x38b79c00, 0x390f0000)
    rw space 12288K,  54% used [0x390f0000, 0x3977d0e8, 0x3977d200, 0x39cf0000)
}
Event: 3.279 GC heap before
{Heap before GC invocations=1 (full 0):
 def new generation   total 4928K, used 4928K [0x246f0000, 0x24c40000, 0x29c40000)
  eden space 4416K, 100% used [0x246f0000, 0x24b40000, 0x24b40000)
  from space 512K, 100% used [0x24bc0000, 0x24c40000, 0x24c40000)
  to   space 512K,   0% used [0x24b40000, 0x24b40000, 0x24bc0000)
 tenured generation   total 10944K, used 676K [0x29c40000, 0x2a6f0000, 0x346f0000)
   the space 10944K,   6% used [0x29c40000, 0x29ce9128, 0x29ce9200, 0x2a6f0000)
 compacting perm gen  total 12288K, used 2370K [0x346f0000, 0x352f0000, 0x386f0000)
   the space 12288K,  19% used [0x346f0000, 0x34940a48, 0x34940c00, 0x352f0000)
    ro space 10240K,  45% used [0x386f0000, 0x38b79b28, 0x38b79c00, 0x390f0000)
    rw space 12288K,  54% used [0x390f0000, 0x3977d0e8, 0x3977d200, 0x39cf0000)
Event: 3.283 GC heap after
Heap after GC invocations=2 (full 0):
 def new generation   total 4928K, used 511K [0x246f0000, 0x24c40000, 0x29c40000)
  eden space 4416K,   0% used [0x246f0000, 0x246f0000, 0x24b40000)
  from space 512K,  99% used [0x24b40000, 0x24bbfff8, 0x24bc0000)
  to   space 512K,   0% used [0x24bc0000, 0x24bc0000, 0x24c40000)
 tenured generation   total 10944K, used 1391K [0x29c40000, 0x2a6f0000, 0x346f0000)
   the space 10944K,  12% used [0x29c40000, 0x29d9bef0, 0x29d9c000, 0x2a6f0000)
 compacting perm gen  total 12288K, used 2370K [0x346f0000, 0x352f0000, 0x386f0000)
   the space 12288K,  19% used [0x346f0000, 0x34940a48, 0x34940c00, 0x352f0000)
    ro space 10240K,  45% used [0x386f0000, 0x38b79b28, 0x38b79c00, 0x390f0000)
    rw space 12288K,  54% used [0x390f0000, 0x3977d0e8, 0x3977d200, 0x39cf0000)
}
Event: 3.695 GC heap before
{Heap before GC invocations=2 (full 0):
 def new generation   total 4928K, used 4927K [0x246f0000, 0x24c40000, 0x29c40000)
  eden space 4416K,  99% used [0x246f0000, 0x24b3fc18, 0x24b40000)
  from space 512K,  99% used [0x24b40000, 0x24bbfff8, 0x24bc0000)
  to   space 512K,   0% used [0x24bc0000, 0x24bc0000, 0x24c40000)
 tenured generation   total 10944K, used 1391K [0x29c40000, 0x2a6f0000, 0x346f0000)
   the space 10944K,  12% used [0x29c40000, 0x29d9bef0, 0x29d9c000, 0x2a6f0000)
 compacting perm gen  total 12288K, used 2745K [0x346f0000, 0x352f0000, 0x386f0000)
   the space 12288K,  22% used [0x346f0000, 0x3499e548, 0x3499e600, 0x352f0000)
    ro space 10240K,  45% used [0x386f0000, 0x38b79b28, 0x38b79c00, 0x390f0000)
    rw space 12288K,  54% used [0x390f0000, 0x3977d0e8, 0x3977d200, 0x39cf0000)
Event: 3.699 GC heap after
Heap after GC invocations=3 (full 0):
 def new generation   total 4928K, used 317K [0x246f0000, 0x24c40000, 0x29c40000)
  eden space 4416K,   0% used [0x246f0000, 0x246f0000, 0x24b40000)
  from space 512K,  62% used [0x24bc0000, 0x24c0f7e0, 0x24c40000)
  to   space 512K,   0% used [0x24b40000, 0x24b40000, 0x24bc0000)
 tenured generation   total 10944K, used 3308K [0x29c40000, 0x2a6f0000, 0x346f0000)
   the space 10944K,  30% used [0x29c40000, 0x29f7b1b0, 0x29f7b200, 0x2a6f0000)
 compacting perm gen  total 12288K, used 2745K [0x346f0000, 0x352f0000, 0x386f0000)
   the space 12288K,  22% used [0x346f0000, 0x3499e548, 0x3499e600, 0x352f0000)
    ro space 10240K,  45% used [0x386f0000, 0x38b79b28, 0x38b79c00, 0x390f0000)
    rw space 12288K,  54% used [0x390f0000, 0x3977d0e8, 0x3977d200, 0x39cf0000)
}

Deoptimization events (0 events):
No events

Internal exceptions (10 events):
Event: 3.331 Thread 0x0115c000 Threw 0x24773480 at C:\jdk7u2_32P\jdk7u25\hotspot\src\share\vm\prims\jvm.cpp:1235
Event: 3.332 Thread 0x0115c000 Threw 0x247818c0 at C:\jdk7u2_32P\jdk7u25\hotspot\src\share\vm\prims\jvm.cpp:1235
Event: 3.333 Thread 0x0115c000 Threw 0x2478aba0 at C:\jdk7u2_32P\jdk7u25\hotspot\src\share\vm\prims\jvm.cpp:1235
Event: 3.365 Thread 0x0115c000 Threw 0x247969c0 at C:\jdk7u2_32P\jdk7u25\hotspot\src\share\vm\prims\jvm.cpp:1235
Event: 3.366 Thread 0x0115c000 Threw 0x2479a270 at C:\jdk7u2_32P\jdk7u25\hotspot\src\share\vm\prims\jvm.cpp:1235
Event: 3.367 Thread 0x0115c000 Threw 0x247a6eb0 at C:\jdk7u2_32P\jdk7u25\hotspot\src\share\vm\prims\jvm.cpp:1235
Event: 3.368 Thread 0x0115c000 Threw 0x247aad48 at C:\jdk7u2_32P\jdk7u25\hotspot\src\share\vm\prims\jvm.cpp:1235
Event: 3.428 Thread 0x0115c000 Threw 0x247e0b28 at C:\jdk7u2_32P\jdk7u25\hotspot\src\share\vm\prims\jvm.cpp:1235
Event: 3.701 Thread 0x0115c000 Threw 0x2470a000 at C:\jdk7u2_32P\jdk7u25\hotspot\src\share\vm\prims\jvm.cpp:1235
Event: 3.782 Thread 0x0115c000 Threw 0x24711a70 at C:\jdk7u2_32P\jdk7u25\hotspot\src\share\vm\prims\jvm.cpp:1235

Events (10 events):
Event: 3.675 loading class 0x04ea54f0
Event: 3.675 loading class 0x04ea54f0 done
Event: 3.695 Executing VM operation: GenCollectForAllocation
Event: 3.699 Executing VM operation: GenCollectForAllocation done
Event: 3.701 loading class 0x04d821b0
Event: 3.701 loading class 0x04d821b0 done
Event: 3.782 loading class 0x04e8de40
Event: 3.782 loading class 0x04e8de40 done
Event: 3.782 loading class 0x04eb9db8
Event: 3.782 loading class 0x04eb9db8 done


Dynamic libraries:
0x01240000 - 0x0126f000     C:\Program Files (x86)\Java\jdk1.7.0_25\bin\java.exe
0x77960000 - 0x77ae0000     C:\Windows\SysWOW64\ntdll.dll
0x705f0000 - 0x7062f000     C:\Program Files\AVAST Software\Avast Business\snxhk.dll
0x773a0000 - 0x774b0000     C:\Windows\syswow64\KERNEL32.dll
0x77350000 - 0x77397000     C:\Windows\syswow64\KERNELBASE.dll
0x772b0000 - 0x77350000     C:\Windows\syswow64\ADVAPI32.dll
0x774b0000 - 0x7755c000     C:\Windows\syswow64\msvcrt.dll
0x75e80000 - 0x75e99000     C:\Windows\SysWOW64\sechost.dll
0x75ee0000 - 0x75fd0000     C:\Windows\syswow64\RPCRT4.dll
0x753b0000 - 0x75410000     C:\Windows\syswow64\SspiCli.dll
0x753a0000 - 0x753ac000     C:\Windows\syswow64\CRYPTBASE.dll
0x75720000 - 0x75820000     C:\Windows\syswow64\USER32.dll
0x75490000 - 0x75520000     C:\Windows\syswow64\GDI32.dll
0x75fe0000 - 0x75fea000     C:\Windows\syswow64\LPK.dll
0x75670000 - 0x7570d000     C:\Windows\syswow64\USP10.dll
0x73340000 - 0x734de000     C:\Windows\WinSxS\x86_microsoft.windows.common-controls_6595b64144ccf1df_6.0.7601.17514_none_41e6975e2bd6f2b2\COMCTL32.dll
0x75430000 - 0x75487000     C:\Windows\syswow64\SHLWAPI.dll
0x75e20000 - 0x75e80000     C:\Windows\system32\IMM32.DLL
0x75520000 - 0x755ec000     C:\Windows\syswow64\MSCTF.dll
0x742d0000 - 0x74305000     c:\windows\syswow64\nvinit.dll
0x67460000 - 0x6751e000     C:\Program Files (x86)\Java\jdk1.7.0_25\jre\bin\msvcr100.dll
0x647d0000 - 0x64b12000     C:\Program Files (x86)\Java\jdk1.7.0_25\jre\bin\client\jvm.dll
0x73f60000 - 0x73f67000     C:\Windows\system32\WSOCK32.dll
0x75ea0000 - 0x75ed5000     C:\Windows\syswow64\WS2_32.dll
0x76260000 - 0x76266000     C:\Windows\syswow64\NSI.dll
0x73ef0000 - 0x73f22000     C:\Windows\system32\WINMM.dll
0x75710000 - 0x75715000     C:\Windows\syswow64\PSAPI.DLL
0x71570000 - 0x7157c000     C:\Program Files (x86)\Java\jdk1.7.0_25\jre\bin\verify.dll
0x6b4f0000 - 0x6b510000     C:\Program Files (x86)\Java\jdk1.7.0_25\jre\bin\java.dll
0x6b4d0000 - 0x6b4e3000     C:\Program Files (x86)\Java\jdk1.7.0_25\jre\bin\zip.dll
0x6b4b0000 - 0x6b4c4000     C:\Program Files (x86)\Java\jdk1.7.0_25\jre\bin\net.dll
0x73bf0000 - 0x73c2c000     C:\Windows\system32\mswsock.dll
0x70af0000 - 0x70af6000     C:\Windows\System32\wship6.dll
0x71580000 - 0x7158f000     C:\Program Files (x86)\Java\jdk1.7.0_25\jre\bin\nio.dll
0x70a80000 - 0x70a90000     C:\Windows\system32\NLAapi.dll
0x70a70000 - 0x70a80000     C:\Windows\system32\napinsp.dll
0x70a50000 - 0x70a62000     C:\Windows\system32\pnrpnsp.dll
0x70a00000 - 0x70a44000     C:\Windows\system32\DNSAPI.dll
0x709f0000 - 0x709f8000     C:\Windows\System32\winrnr.dll
0x709e0000 - 0x709ed000     C:\Windows\system32\wshbth.dll
0x709b0000 - 0x709d7000     C:\Program Files (x86)\Common Files\Microsoft Shared\Windows Live\WLIDNSP.DLL
0x73be0000 - 0x73be5000     C:\Windows\System32\wshtcpip.dll
0x737b0000 - 0x737cc000     C:\Windows\system32\IPHLPAPI.DLL
0x73690000 - 0x73697000     C:\Windows\system32\WINNSI.DLL
0x70960000 - 0x70966000     C:\Windows\system32\rasadhlp.dll
0x70970000 - 0x709a8000     C:\Windows\System32\fwpuclnt.dll
0x64d20000 - 0x64e64000     C:\Program Files (x86)\Java\jdk1.7.0_25\jre\bin\awt.dll
0x770c0000 - 0x7714f000     C:\Windows\syswow64\OLEAUT32.dll
0x75aa0000 - 0x75bfc000     C:\Windows\syswow64\ole32.dll
0x728b0000 - 0x728c6000     C:\Windows\system32\CRYPTSP.dll
0x72870000 - 0x728ab000     C:\Windows\system32\rsaenh.dll
0x74320000 - 0x74337000     C:\Windows\system32\USERENV.dll
0x74310000 - 0x7431b000     C:\Windows\system32\profapi.dll
0x10000000 - 0x1003d000     C:\Users\deniz\AppData\Local\Temp\jna-deniz\jna2263007016168316943.dll
0x645b0000 - 0x647ca000     C:\Users\deniz\Documents\NetBeansProjects\Tess4J-1.1-src\Tess4J\libtesseract302.dll
0x64b80000 - 0x64d1c000     C:\Users\deniz\Documents\NetBeansProjects\Tess4J-1.1-src\Tess4J\liblept168.dll
0x741f0000 - 0x74293000     C:\Windows\WinSxS\x86_microsoft.vc90.crt_1fc8b3b9a1e18e3b_9.0.30729.6161_none_50934f2ebcb7eb57\MSVCR90.dll
0x72f60000 - 0x72fee000     C:\Windows\WinSxS\x86_microsoft.vc90.crt_1fc8b3b9a1e18e3b_9.0.30729.6161_none_50934f2ebcb7eb57\MSVCP90.dll
0x72c70000 - 0x72d5b000     C:\Windows\system32\dbghelp.dll

编辑 3:这是 testTessBaseAPIRect 的最终版本:

@Test
    public void testTessBaseAPIRect() throws Exception {
        System.out.println("TessBaseAPIRect");
        String expResult = expOCRResult;
        String lang = "tur";
        File tiff = new File("testTur.tif");
        BufferedImage image = ImageIO.read(tiff); // require jai-imageio lib to read TIFF
        ByteBuffer buf = ImageIOHelper.convertImageData(image);
        int bpp = image.getColorModel().getPixelSize();
        int bytespp = bpp / 8;
        int bytespl = (int) Math.ceil(image.getWidth() * bpp / 8.0);
        TessAPI1.TessBaseAPIInit3(handle, "tessdata", lang);
        TessAPI1.TessBaseAPISetPageSegMode(handle, TessAPI1.TessPageSegMode.PSM_AUTO);
        Pointer utf8Text = TessAPI1.TessBaseAPIRect(handle, buf, bytespp, bytespl, 0, 0, 2048, 1600);
        String result = utf8Text.getString(0);
        TessAPI1.TessDeleteText(utf8Text);
        System.out.println(result);
//        assertEquals(expResult, result.substring(0, expResult.length()));
    }
4

1 回答 1

1

TessBaseAPIRect指定图像上的区域。如果区域大于图像,则会抛出异常。指定一个较小的区域或TessBaseAPIGetUTF8Text用于整个图像。

于 2013-08-07T23:01:28.293 回答