duanniedang3946 2017-07-18 08:23
浏览 122
已采纳

PHP:Hashtable优化

I have two static hashtables in my program:

public static $labels = [
    'id' => 'ID',
    'name' => 'Name',
    'email' => 'E-mail',
    'password' => 'Password',
];

public static $columnTypes = [
    'id' => 'number',
    'name' => 'text',
    'email' => 'text',
    'password' => 'text',
];

First is for the labels of the database columns and the second for each type (necessary for filtering).

My problem is that I often need to get the type of a column by its label what leads to speed issues (hashtables are pretty slow in this direction right?).

My approaches would be the following:

  1. Type a hashtable label => type which is bad because I have to repeat myself and there is no support for other languages
  2. Create the label => type hashtable in a static content on runtime (is this possible in php?)

Are there better approaches or best practices for this issue and is the second approach possible in php? (maybe with a small example ;)

  • 写回答

2条回答 默认 最新

  • donglisi8644 2017-07-18 08:38
    关注

    Call array_flip in the class constructor. To avoid repeating it, check whether the flipped array is already set.

    class YourClass {
        public static $labels = [
            'id' => 'ID',
            'name' => 'Name',
            'email' => 'E-mail',
            'password' => 'Password',
        ];
        public static $labels_flipped = null;
    
        public function __construct() {
            if (!$labels_flipped) {
                $labels_flipped = array_flip($labels);
            }
            ...
        }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵