mysql - gtk2 和线程中的段错误

标签 mysql multithreading perl user-interface

我遇到了这个问题,这个小示例代码将检查用户名是否存在于 MySQL 服务器上。

#!/usr/bin/perl
use Gtk2 '-init';
use Glib qw/TRUE FALSE/;
use threads;
use threads::shared;
use DBI;
use DBD::mysql;

our $type="mysql";
our $database="store";
our $host="localhost";
our $port="3306";
our $tablename="topic";
our $user="root";
our $pwd="killme32";

our $dsn="dbi:$type:$database:$host:$port";
our $query;
our $queryhandle;
my $str:shared=0;

my $window=Gtk2::Window->new;
$window->signal_connect('delete_event',sub{Gtk2->main_quit;});
$window->set_title("Perl Gtk2 Tutorial");

my $vbox=Gtk2::VBox->new;
my $label=Gtk2::Label->new("Username: ");
my $button=Gtk2::Button->new("Login");
my $entry=Gtk2::Entry->new();
$button->signal_connect(clicked=>sub{
    $str=$entry->get_text;
    my $thr=threads->create(\&continue_checking);
});
$vbox->add($label);
$vbox->add($entry);
$vbox->add($button);
$window->add($vbox);
$window->show_all;
Gtk2->main;
sub continue_checking{
    our $connect=DBI->connect($dsn,$user,$pwd)or die &mysql_Err;
    $query="SELECT username FROM login WHERE username=\"$str\"";
    $queryhandle=$connect->prepare($query);
    $queryhandle->execute;
    $queryhandle->bind_columns(undef, \my $user_name);
    while ($queryhandle->fetch()) {
        if("$str" eq "$user_name"){
            &main;
        }
    }   
}
sub main{
    my $mw=Gtk2::Window->new;
    $mw->set_default_size(250, 250);
    my $label=Gtk2::Label->new("username $str is already exist");
    $mw->add($label);
    $mw->show_all;
    $mw->show;
}

ERROR Result: GLib-GObject-WARNING **: cannot register existing type `GConnectFlags' at /usr/lib/perl/5.14/DynaLoader.pm line 207. Pango-WARNING **: shaping failure, expect ugly output. shape-engine='BasicEngineFc', font='DejaVu Sans 9.9990234375', text='' at server.pl line 40. Segmentation fault

最佳答案

尝试添加

use Gtk2 qw/-init -threads-init/;
Glib::Object->set_threadsafe (1);

关于mysql - gtk2 和线程中的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27830523/

相关文章:

安卓本地服务: are they that useful?

perl - 使用运行 perl s/("|' )//命令的 Windows 批处理文件/命令行,如何防止在运算符(operator)预期错误处发现裸字?

perl - 什么是对非 Perl 开发人员的有效 Perl 培训?

perl - 如何将一个以破折号开头的值发送到 Getopt::Long?

PHP解析sql结果集

mysql - 改进我的 MYSQL 查询

python - GUI 卡住了其余的 python 代码

Java:如何区分wait()中的虚假唤醒和超时

mysql - 选择多对多关系

mysql - 将值以 x 开头的行排序在包含 x 的行之前