douhu7807 2011-03-23 20:18
浏览 20
已采纳

我应该多久创建一个类的新实例?

I'm not a "die hard" coder and I need some advice.

I'm developing a website where users may search for a store or a brand.

I've created a class called Search and Store.

There are two ways search is executed: "jQuery Live Search" and "normal search".

Live search is triggered for each character entered above 2 characters. So if you enter 5 characters, a search is performed 3 times. If the store you are looking for is in the dropdown list, you can click the store and the store page will be loaded.

The other search is when you click the search button after entering 3 or more characters.

Every time a search is performed, the following code is executed

$search = new Search();
$result = $search->search($_GET);

Each time a store page is loaded a $store = new Store() is executed.

My question is this:

Let's assume I get a very successful website and I have aroun 100 users per hour. Each user searches at least 3 times and looks at least 5 stores.

That means between 300 and 900 search objects are created every hour and 500 store objects.

Is it bad or good to create so many new objects?

I've read a bit about Singleton, but many advices against this.

How should I do this to achieve best performance? Any specific design pattern I should use?

  • 写回答

3条回答 默认 最新

  • douchan6512 2011-03-23 20:26
    关注

    I don't think that creating the classes will become a bottleneck for your site. Look at an MVC Framework like Zend Framework, and examine how many instances of classes are generated for every call. The overhead of creating an instance of a class is almost nothing, the search will put heat on your db(assuming you are using a db like mysql).

    I suggest using a timer for your jQuery Live search to do the search after the user stopped entering more characters. Like refreshing everytime the timer when a character has been entered and when the timer fires you can actually search.

    I think one of the bigger problems will be your database. If you have many reading requests a good caching layer like memcache may take a good heap of load from you DB.

    Optimizing your db for searches should be a good measure to hold performance high. There are many tweaks and best practices to follow to get the most out of the db you are using.

    As a comment of prodigitalson suggested diving into full text search with Lucene could even be more efficient than tuning the db.

    If Lucene is bit overhead for you, you may want to look at the Zend_Search_Lucene component, which does the same job and is written in php.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 BP神经网络控制倒立摆
  • ¥20 要这个数学建模编程的代码 并且能完整允许出来结果 完整的过程和数据的结果
  • ¥15 html5+css和javascript有人可以帮吗?图片要怎么插入代码里面啊
  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算