這些Java8官方挖過的坑,你踩過幾個?_網頁設計公司

南投搬家公司費用,距離,噸數怎麼算?達人教你簡易估價知識!

搬家費用:依消費者運送距離、搬運樓層、有無電梯、步行距離、特殊地形、超重物品等計價因素後,評估每車次單

導讀:系統啟動異常日誌竟然被JDK吞噬無法定位?同樣的加密方法,竟然出現部分數據解密失敗?往List裏面添加數據竟然提示不支持?日期明明間隔1年卻輸出1天,難不成這是天上人間?1582年神秘消失的10天JDK能否識別?Stream很高大上,List轉Map卻全失敗……這些JDK8官方挖的坑,你踩過幾個? 關注公眾號【碼大叔】,實戰踩坑硬核分享,一起交流!

@

目錄

  • 一、Base64:你是我解不開的迷
  • 二、被吞噬的異常:我不敢說出你的名字
  • 三、日期計算:我想留住時間,讓1天像1年那麼長
  • 四、List:一如你我初見,不增不減
  • 五、Stream處理:給你,獨一無二
  • 六、結尾:紙上得來終覺淺,絕知此事要躬行!
  • 推薦閱讀

一、Base64:你是我解不開的迷

出於用戶隱私信息保護的目的,系統上需將姓名、身份證、手機號等敏感信息進行加密存儲,很自然選擇了AES算法,外面又套了一層Base64,之前用的是sun.misc.BASE64Decoder/BASE64Encoder,網上的資料基本也都是這種寫法,運行得很完美。但這種寫法在idea或者maven編譯時就會有一些黃色告警提示。到了Java 8后,Base64編碼已經成為Java類庫的標準,內置了 Base64 編碼的編碼器和解碼器。於是乎,我手賤地修改了代碼,改用了jdk8自帶的Base64方法

import java.util.Base64;

public class Base64Utils {

    public static final Base64.Decoder DECODER = Base64.getDecoder();
    public static final Base64.Encoder ENCODER = Base64.getDecoder();

    public static String encodeToString(byte[] textByte) {
        return ENCODER.encodeToString(textByte);
    }

    public static byte[] decode(String str) {
        return DECODER.decode(str);
    }

}

程序員的職業操守咱還是有的,構造新老數據、自測、通過,提交測試版本。信心滿滿,我要繼續延續我 0 Bug的神話!然後……然後版本就被打回了。

Caused by: java.lang.IllegalArgumentException: Illegal base64 character 3f
    at java.util.Base64$Decoder.decode0(Base64.java:714)
    at java.util.Base64$Decoder.decode(Base64.java:526)
    at java.util.Base64$Decoder.decode(Base64.java:549)

關鍵是這個錯還很詭異,部分數據是可以解密的,部分解不開

Base64依賴於簡單的編碼和解碼算法,使用65個字符的US-ASCII子集,其中前64個字符中的每一個都映射到等效的6位二進制序列,第65個字符(=)用於將Base64編碼的文本填充到整數大小。後來產生了3個變種:

  • RFC 4648:Basic
    此變體使用RFC 4648和RFC 2045的Base64字母表進行編碼和解碼。編碼器將編碼的輸出流視為一行; 沒有輸出行分隔符。解碼器拒絕包含Base64字母表之外的字符的編碼。​
  • RFC 2045:MIME
    此變體使用RFC 2045提供的Base64字母表進行編碼和解碼。編碼的輸出流被組織成不超過76個字符的行; 每行(最後一行除外)通過行分隔符與下一行分隔。解碼期間將忽略Base64字母表中未找到的所有行分隔符或其他字符。
  • RFC 4648:Url
    此變體使用RFC 4648中提供的Base64字母表進行編碼和解碼。字母表與前面显示的字母相同,只是-替換+和_替換/。不輸出行分隔符。解碼器拒絕包含Base64字母表之外的字符的編碼。
S.N. 方法名稱 & 描述
1 static Base64.Decoder getDecoder()
返回Base64.Decoder解碼使用基本型base64編碼方案。
2 static Base64.Encoder getEncoder()
返回Base64.Encoder編碼使用的基本型base64編碼方案。
3 static Base64.Decoder getMimeDecoder()
返回Base64.Decoder解碼使用MIME類型的base64解碼方案。
4 static Base64.Encoder getMimeEncoder()
返回Base64.Encoder編碼使用MIME類型base64編碼方案。
5 static Base64.Encoder getMimeEncoder(int lineLength, byte[] lineSeparator)
返回Base64.Encoder編碼使用指定的行長度和線分隔的MIME類型base64編碼方案。
6 static Base64.Decoder getUrlDecoder()
返回Base64.Decoder解碼使用URL和文件名安全型base64編碼方案。
7 static Base64.Encoder getUrlEncoder()
返回Base64.Decoder解碼使用URL和文件名安全型base64編碼方案。

關於base64用法的詳細說明,可參考:https://juejin.im/post/5c99b2976fb9a070e76376cc

對於上面的錯誤,網上有的說法是,建議使用Base64.getMimeDecoder()Base64.getMimeEncoder(),對此我只能建議:老的系統如果已經有數據了,就不要使用jdk自帶的Base64了。JDK官方的Base64和sun的base64是不兼容的!不要替換!不要替換!不要替換!

二、被吞噬的異常:我不敢說出你的名字

這個問題理解起來還是蠻費腦子的,所以我把這個系統異常發生的過程提煉成了一個美好的故事,放鬆一下,吟詩一首!

最怕相思濃
一切皆是你
唯獨
不敢說出你的名字
— 碼大叔

這個問題是在使用springboot的註解時遇到的問題,發現JDK在解析註解時,若註解依賴的類定義在JVM加載時不存在,也就是NoClassDefFoundError時,實際拿到的異常將會是ArrayStoreException,而不是NoClassDefFoundError,涉及到的JDK里的類是AnnotationParser.java, 具體代碼如下:

private static Object parseClassArray(int paramInt, ByteBuffer paramByteBuffer, ConstantPool paramConstantPool, Class<?> paramClass) {
    Class[] arrayOfClass = new Class[paramInt];
    int i = 0;
    int j = 0;
    for (int k = 0; k < paramInt; k++){
        j = paramByteBuffer.get();
        if (j == 99) {
            // 注意這個方法
        	arrayOfClass[k] = parseClassValue(paramByteBuffer, paramConstantPool, paramClass);
        } else {
        	skipMemberValue(j, paramByteBuffer);
        	i = 1;
        }
    }
    return i != 0 ? exceptionProxy(j) : arrayOfClass;
}
private static Object parseClassValue(ByteBuffer paramByteBuffer, ConstantPool paramConstantPool, Class<?> paramClass) {
    int i = paramByteBuffer.getShort() & 0xFFFF;
    try
    {
        String str = paramConstantPool.getUTF8At(i);
        return parseSig(str, paramClass);
    } catch (IllegalArgumentException localIllegalArgumentException) {
        return paramConstantPool.getClassAt(i);
    } catch (NoClassDefFoundError localNoClassDefFoundError) {
         // 注意這裏,異常發生了轉化
        return new TypeNotPresentExceptionProxy("[unknown]", localNoClassDefFoundError);
    } catch (TypeNotPresentException localTypeNotPresentException) {
        return new TypeNotPresentExceptionProxy(localTypeNotPresentException.typeName(), localTypeNotPresentException.getCause());
    }
}

parseClassArray這個方法中,預期parseClassValue返回Class對象,但看實際parseClassValue的邏輯,在遇到NoClassDefFoundError時,返回的是TypeNotPresentExceptionProxy,由於類型強轉失敗,最終拋出的是java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy,此時只能通過debug到這行代碼,找到具體是缺少哪個類定義,才能解決這個問題。

筆者重現一下發現這個坑的場景,有三個module,module3依賴module2但未聲明依賴module1,module2依賴module1,但聲明的是optional類型,依賴關係圖如下:

上面每個module中有一個Class,我們命名為ClassInModuleX。ClassInModule3啟動時在註解中使用了ClassInModule2的類,而ClassInModule2這個類的繼承了ClassInModule1,這幾個類的依賴關係圖如下:

如此,其實很容易知道在module運行ClassInModule3時,會出現ClassInModule1的NoClassDefFoundError的,但實際運行時,你能看到的異常將不是NoClassDefFoundError,而是java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy,此時,若想要知道具體是何許異常,需通過debug在AnnotationParser中定位具體問題,以下展示兩個截圖,分別對應系統控制台實際拋出的異常和通過debug發現的異常信息。

控制台異常信息:

注意異常實際在紅色圈圈這裏,自動收縮了,需要展開才可以看到通過debug發現的異常信息:

如果你想體驗這個示例,可關注公眾號碼大叔和筆者交流。如果你下次遇到莫名的java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy,請記得用這個方法定位具體問題。

三、日期計算:我想留住時間,讓1天像1年那麼長

Java8之前日期時間操作相當地麻煩,無論是Calendar還是SimpleDateFormat都讓你覺得這個設計怎麼如此地反人類,甚至還會出現多線程安全的問題,阿里巴巴開發手冊中就曾禁用static修飾SimpleDateFormat。好在千呼萬喚之後,使出來了,Java8帶來了全新的日期和時間API,還帶來了Period和Duration用於時間日期計算的兩個API。

Duraction和Period,都表示一段時間的間隔,Duraction正常用來表示時、分、秒甚至納秒之間的時間間隔,Period正常用於年、月、日之間的時間間隔。

網上的大部分文章也是這麼描述的,於是計算兩個日期間隔可以寫成下面這樣的代碼:

// parseToDate方法作用是將String轉為LocalDate,略。
LocalDate date1 = parseToDate("2020-05-12");
LocalDate date2 = parseToDate("2021-05-13");
// 計算日期間隔
int period = Period.between(date1,date2).getDays();

一個是2020年,一個是2021年,你認為間隔是多少?1年?
恭喜你,和我一起跳進坑裡了(畫外音:裏面的都擠一擠,動一動,又來新人了)。
正確答案應該是:1天。

這個單詞的含義以及這個方法看起來確實是蠻誤導人的,一不注意就會掉進坑裡。Period其實只能計算同月的天數、同年的月數,不能計算跨月的天數以及跨年的月數。

正確寫法1

網頁設計公司推薦不同的風格,搶佔消費者視覺第一線

透過選單樣式的調整、圖片的縮放比例、文字的放大及段落的排版對應來給使用者最佳的瀏覽體驗,所以不用擔心有手機版網站兩個後台的問題,而視覺效果也是透過我們前端設計師優秀的空間比例設計,不會因為畫面變大變小而影響到整體視覺的美感。

 long period = date2.toEpochDay()-date1.toEpochDay();

toEpochDay():將日期轉換成Epoch 天,也就是相對於1970-01-01(ISO)開始的天數,和時間戳是一個道理,時間戳是秒數。顯然,該方法是有一定的局限性的

正確寫法2

long period = date1.until(date2,ChronoUnit.DAYS);

使用這個寫法,一定要注意一下date1和date2前後順序:date1 until date2。

正確做法3(推薦)

 long period = ChronoUnit.DAYS.between(date1, date2);

ChronoUnit:一組標準的日期時間單位。這組單元提供基於單元的訪問來操縱日期,時間或日期時間。 這些單元適用於多個日曆系統。這是一個最終的、不可變的和線程安全的枚舉。

看到”適用於多個日曆系統“這句話,我一下子想起來歷史上1582年神秘消失的10天,在JDK8上是什麼效果呢?1582-10-15和1582-10-04你覺得會相隔幾天呢?11天還是1天?有興趣的小夥伴自己去寫個代碼試試吧。

打開你的手機,跳轉到1582年10月,你就能看到這消失的10天了。

四、List:一如你我初見,不增不減

這個問題其實在JDK里存在很多年了,JDK8中依然存在,也是很多人最容易跳的一個坑!直接上代碼:

public List<String> allUser() {
    // 省略
    List<String> currentUserList = getUser();
    currentUserList.add("碼大叔");
    // 省略
}

就是上面這樣一段代碼,往一個list里添加一條數據,你覺得結果是什麼呢?“碼大叔”成功地添加到了List里?天真,不報個錯你怎麼能意識到JDK存在呢。

Exception in thread "main" java.lang.UnsupportedOperationException
    at java.util.AbstractList.add(AbstractList.java:148)

原因
因為在getUser方法里,返回的List使用的是Arrays.asList生成的,示例:

    private List<String> getUser(){
        return Arrays.asList("劍聖","小九九");
    }

我們來看看Arrays.asList的源碼

    @SafeVarargs
    @SuppressWarnings("varargs")
    public static <T> List<T> asList(T... a) {
        return new ArrayList<>(a);
    }
 private static class ArrayList<E> extends AbstractList<E>
        implements RandomAccess, java.io.Serializable
    {
   		private final E[] a;
        // 部分代碼略
        ArrayList(E[] array) {
            // 返回的是一個定長的數組
            a = Objects.requireNonNull(array);
        }
        // 部分代碼略
   }

很明顯,返回的實際是一個定長的數組,所以只能“一如你我初見”,初始化什麼樣子就什麼樣子,不能新增,不能減少。如果你理解了,那我們就再來一個栗子

   int[] intArr  = {1,2,3,4,5};
   Integer[] integerArr  = {1,2,3,4,5};
   String[] strArr = {"1", "2", "3", "4", "5"};
   List list1 = Arrays.asList(intArr);
   List list2 = Arrays.asList(integerArr);
   List list3 = Arrays.asList(strArr);
   System.out.println("list1中的數量是:" + list1.size());
   System.out.println("list2中的數量是:" + list2.size());
   System.out.println("list3中的數量是:" + list3.size());

你覺得答案是什麼?預想3秒鐘,揭曉答案,看跟你預想的是否一致呢?

list1中的數量是:1
list2中的數量是:5
list3中的數量是:5

是不是和你預想又不一樣了?還是回到Arrays.asList方法,該方法的輸入只能是一個泛型變長參數。基本類型是不能泛型化的,也就是說8個基本類型不能作為泛型參數,要想作為泛型參數就必須使用其所對應的包裝類型,那前面的例子傳遞了一個int類型的數組,為何程序沒有報編譯錯誤呢?在Java中,數組是一個對象,它是可以泛型化的,也就是說我們的例子是把一個int類型的數組作為了T的類型,所以在轉換后在List中就只有1個類型為int數組的元素了。除了int,其它7個基本類型的數組也存在相似的問題。

JDK里還為我們提供了一個便捷的集合操作工具類Collections,比如多個List合併時,可以使用Collections.addAll(list1,list2), 在使用時也同樣要時刻提醒自己:“請勿踩坑”!

五、Stream處理:給你,獨一無二

Java8中新增了Stream流 ,通過流我們能夠對集合中的每個元素進行一系列并行或串行的流水線操作。當使用一個流的時候,通常包括三個基本步驟:獲取一個數據源(source)→ 數據轉換→執行操作獲取想要的結 果,每次轉換原有 Stream 對象不改變,返回一個新的 Stream 對象(可以有多次轉換),這就允許對其操作可以 像鏈條一樣排列,變成一個管道。

項目上千萬不要使用Stream,因為一旦用起來你會覺得真屏蔽詞爽,根本停不下來。當然不可避免的,還是有一些小坑的。

假設我們分析用戶的訪問日誌,放到list里。

list.add(new User("碼大叔", "登錄公眾號"));
list.add(new User("碼大叔", "編寫文章"));

因為一些原因,我們要講list轉為map,Steam走起來,

private static void convert2MapByStream(List<User> list) {
    Map<String, String> map = list.stream().collect(Collectors.toMap(User::getName, User::getValue));
    System.out.println(map);
}

咣當,掉坑裡了,程序將拋出異常:

Exception in thread "main" java.lang.IllegalStateException: Duplicate key 碼大叔

使用Collectors.toMap() 方法中時,默認key值是不允許重複的。當然,該方法還提供了第三個參數:也就是出現 duplicate key的時候的處理方案

如果在開發的時候就考慮到了key可能重複,你需要在這樣定義convert2MapByStream方法,聲明在遇到重複key時是使用新值還是原有值:

    private static void convert2MapByStream(List<User> list) {
        Map<String, String> map = list.stream().collect(Collectors.toMap(User::getName, User::getValue, (oldVal, newVal) -> newVal));
        System.out.println(map);
    }

關於Stream的坑其實還是蠻多的,比如尋找list中的某個對象,可以使用findAny().get(),你以為是找到就返回找不到就就返回null?依然天真,找不到會拋出異常的,需要使用額外的orElse方法。

六、結尾:紙上得來終覺淺,絕知此事要躬行!

所謂JDK官方的坑,基本上都是因為我們對技術點了解的不夠深入,望文生義,以為是怎樣怎樣的,而實際上我們的自以為是讓我們掉進了一個又一個坑裡。面對着這些坑,我流下了學藝不精的眼淚!但也有些坑,確實發生的莫名其妙,比如吞噬異常,沒有理解JDK為什麼這麼設計。還有些坑,誤導性確實太強了,比如日期計算、list操作等。最後只能說一句:

紙上得來終覺淺,絕知此事要躬行!
編碼不易,且行且珍惜!

推薦閱讀

Try-Catch包裹的代碼異常后,竟然導致了產線事務回滾!
Redis 6.0 新特性-多線程連環13問!
報告老闆,微服務高可用神器已祭出,您花巨資營銷的高流量來了沒?
我成功攻擊了Tomcat服務器,大佬們的反應亮了

公眾號:碼大叔
資深程序員、架構師技術社區
微服務 | 大數據 | 架構設計 | 技術管理
個人微信:itmadashu

本站聲明:網站內容來源於博客園,如有侵權,請聯繫我們,我們將及時處理

※想知道購買電動車哪裡補助最多?台中電動車補助資訊懶人包彙整

節能減碳愛地球是景泰電動車的理念,是創立景泰電動車行的初衷,滿意態度更是服務客戶的最高品質,我們的成長來自於你的推薦。

年畫“圈粉”路在何方?_貨運

※評比南投搬家公司費用收費行情懶人包大公開

搬家價格與搬家費用透明合理,不亂收費。本公司提供下列三種搬家計費方案,由資深專業組長到府估價,替客戶量身規劃選擇最經濟節省的計費方式

“如果年畫進行創新,你會喜歡什麼樣的年畫?為什麼會喜歡它?”

“我覺得你一定不是年輕人。”“現在的年輕人多喜歡‘傳統文化’。”……

這是一次有意思的採訪。當記者對遠在廣東佛山的一位“90后”孫璐璐拋出這樣的問題時,就被“呼之欲出”的代溝感震得“花枝凌亂”。自認為通過工作接觸,已經潛入“00后”的審美世界,而又得以在眾“90后”同事的熏陶中了解了年輕人的審美趣味,但這次的採訪才讓記者發覺,過往一切認知都只是皮毛。

孫璐璐說:“現在的年輕人多喜歡‘傳統文化’,覺得李寧酷斃了,漢服超級美,大白兔奶糖的香水、六神花露水的雞尾酒就是流行元素符號……”

從一番激動的言辭中,記者依稀看到當下年輕人對傳統文化那份堅定的認同。這些年,漢服熱、懷舊復古風等潮流風行,讓越來越多的人重新感受到傳統的別樣韻味。傳統文化復蘇、文化自信增強,在這樣的大背景下,作為與傳統文化息息相關的非遺,應該抓住時機,重新綻放新顏。比如,曾在春節年俗中不可或缺的年畫,如何在保留美好文化內涵的前提下,另闢蹊徑,重振春節傳統年俗?

嫁接新平台興起來

在年畫的發展歷史中,也曾起起落落。年畫內容不斷更迭、不斷充盈,跟進時代的步伐。1949年後,年畫曾迎來小陽春。那時,許多專業畫家加入年畫的創作隊伍,打破了舊年畫的一些固定模式,大膽借鑒其他畫種的表現手法,使年畫的面貌煥然一新。

時代在變,人們的審美觀念在變。傳統文化雖好,卻不能囿於過去的框架止步不前,在萬象更新的時代進程中,傳統文化需要年輕化的表達。基於這樣的理念,清華大學等高校與傳承人結對子,走出了一條年畫與時代接軌的新路子。

2019年,在文化和旅遊部非物質文化遺產司的指導與支持下,由傳統工藝與材料研究文化和旅遊部重點實驗室(清華大學)主辦,清華大學美術學院視覺傳達設計系和繪畫系共同承辦的清華大學年畫日新創作營,精選了天津楊柳青、蘇州桃花塢、山東高密、山東楊家埠、陝西鳳翔、河北武強等11個代表性年畫產地的年畫人與設計師、美術創作者組成團隊,在10周的時間里創作出作品48件(套),後期成果將投入商業渠道。

創作營的成果首先在北京國際設計周上展示發布,經過3個月的不懈努力,最終落地京東年貨節。佛山、開封、楊柳青、武強、綿竹、灘頭、高密七大年畫項目帶着濃郁的地域特色,將祥和喜慶的產品帶進電商平台。除了藉助京東非遺頻道銷售年畫和年畫衍生品,“萌萌噠”的年神當起了京東數碼產品的“導購”,一些年畫項目還與戴爾、Kindle、華為等知名品牌深度合作,推出了富有中國風味的春節禮盒。

清華大學美術學院副教授、藝術史論系主任陳岸瑛說,這次嘗試的成功說明古老的年畫並非註定落伍於時代,而是具有強大的發展潛力,特別是在新媒體時代,只要把年畫中的美好寓意挖掘出來,與人民群眾對美好生活的嚮往結合起來,年畫就不愁沒有粉絲。

清華大學年畫日新創作營營員石彥敏創作的楊柳青年畫《連年有餘》

助力老手藝活起來

有一件事曾讓楊柳青木版年畫國家級代表性傳承人霍慶有很有感觸,2015年他在天津圖書館舉辦個人年畫藝術展,來看展覽的人不少,但普遍是中老年人,幾乎沒有年輕人,更別提小朋友了。“這給我一個提示,要想讓年畫藝術傳承發展下去,就應該思考如何把孩子們吸引過來。讓年畫走到孩子身邊,陪伴下一代成長。”霍慶有說。

年畫的遠離,帶來的是年味的變淡,不僅是孩子、年輕人對它越來越陌生,曾經充盈民間的紅火年味也不知所蹤。在過去,過年貼年畫,圖的是喜慶吉利,蘊含的是祈福祝願。在那個穿新衣戴新帽、鞭炮聲聲的年節里,我們用一張張年畫集結普天下的喜慶顏色,把一段叫作“年”的時光裝扮起來。如今,物質生活越來越豐富,傳統的年俗年味卻越來越淡了。

時代的車輪滾滾向前,現代印刷術的出現,令傳統印刷的木版年畫受到了衝擊,有的地區年畫一度失傳。2002年,還是一位生意人的張榮強,因緣際會接到了數十年來投身文化遺產搶救的文化學者馮驥才的電話。那時,馮驥才想去尋找四川夾江年畫,卻發現已經沒有可以製作年畫的師傅了。一直酷愛美術的他,決定將精力投入到拯救夾江年畫上。

2010年,他拜夾江年畫老字號作坊“董大興榮”傳人董貴中為師,希望盡最大努力讓這項傳統文化繼續傳承下去。但這條路走起來比想象中更難。起初,擺在張榮強面前的難題是幾乎沒有可利用的資源,沒有夾江年畫製作流程的文字記載,也沒有會實際操作的師傅,甚至連照片都寥寥無幾。此後,張榮強走訪了大量民間手藝人,並不斷尋找相關資料,經過反覆推敲、多次修改,終於成功恢復了夾江年畫的木版套色印刷技藝,並復刻出《鯉魚跳龍門》《福祿宮》《榮華富貴》《財源湧進》《陳姑趕潘》等近30張經典年畫作品。

※智慧手機時代的來臨,RWD網頁設計為架站首選

網動結合了許多網際網路業界的菁英共同研發簡單易操作的架站工具,及時性的更新,為客戶創造出更多的網路商機。

福美祥作坊創作的灘頭年畫《鼠慶豐年》

轉換新語境潮起來

中國人民大學美學與現代藝術研究所研究員張成源在研究東方美學與年畫的關聯時發現,年畫蘊含的東方美學內涵非常豐富,它包含祈禱、健康、豐收、忠孝等。而這些寓意是古今相通的,留存於每一代國人的思想中。因此,年畫重回春節、重回現代生活無需刻意,只要將這一內涵重新挖掘出來,轉換新的話語形式,年畫依然會受到人們的青睞。

在新一代年畫傳承人中,年畫女俠kk的網名似乎比她劉鍾萍的本名更具傳播效應。她當旅遊講解員時與佛山木版年畫結緣。原先的師兄師姐都各尋出路去了,給師父打下手的劉鍾萍卻留了下來。師父馮炳棠是佛山唯一一位掌握木版年畫全套工序的老藝術家,“唯一”二字讓劉鍾萍在不知不覺中對這份工作有了擔當。師父故去后,她挑起了傳承佛山木版年畫的重任。

年畫需要傳承,也需要創新。為了將傳統年畫與現代需求嫁接,她把傳統技藝與現代文化相結合,創作出“諸神復活”系列年畫,受到了市場的歡迎,而傳統年畫與新潮包裝的結合,也迅速俘獲了年輕人的心。起初有人來求購姻緣年畫,受到啟發,她將喜神和合二仙賦予“脫單神器”的新闡釋,頓時使傳統年畫穿越時空與現代接軌。之後,“一個億小目標的財神”“考神狀元及第逢考必過”“天姬送子兒女雙全的二胎神器”“新房入夥鎮宅神器紫薇大神”等系列相繼面世。

劉鍾萍說:“過去的傳統年畫很難吸引到年輕人,我就讓年畫跟他們的生活發生聯繫,他們帶着願望而來,我就負責把他們的願望通過年畫的寓意傳達出去。”

章昉創作的綿竹年畫《老鼠嫁女》

清華大學美術學院教授唐薇創作的佛山年畫《子開鴻蒙》

傳統文化並不缺市場,缺少的是我們重新打扮它的用心。一個鄉村女孩李子柒,將恬靜、本真的鄉村生活用鏡頭表現出來,在互聯網上贏得了國內外網友廣泛的共鳴。因此,承載着人們對美好未來憧憬和嚮往的年畫也可以迎來複興,只要更多力量聚集於此,並賦予年畫一些創新發展的思路和內容,年畫“圈粉”時機來了。

傳統文化並不缺市場,缺少的是我們重新打扮它的用心。一個鄉村女孩李子柒,將恬靜、本真的鄉村生活用鏡頭表現出來,在互聯網上贏得了國內外網友廣泛的共鳴。因此,承載着人們對美好未來憧憬和嚮往的年畫也可以迎來複興,只要更多力量聚集於此,並賦予年畫一些創新發展的思路和內容,年畫“圈粉”時機來了。

專家觀點

中國人民大學美學與現代藝術研究所研究員 張成源

科技的日新月異不會停下前進的腳步,傳統文化的熏陶也應注重其形式。我們要將其中的倫理道德、家風家訓、行為底線、人格境界提煉出來,用新的形式讓它重新被人們接受。在現代社會中,不能強求年畫的量化,因為傳統技藝無法規模生產,但是年畫衍生品可以。年畫也許是小眾文化,年畫衍生品卻可以是大眾文化。因此,當我們在極力調動眾多力量加入年畫的創新中時,欠缺的不僅是年畫衍生品的創作人才,更重要是的消費人群對它的認識。

中國傳媒大學文化產業管理學院副教授 楊 紅

自2019年開始,圍繞“年畫重回春節”這一主題,非遺傳承人與各類互聯網企業、文化創意團隊合作,開始藉助新媒體開發年畫拼圖微信小遊戲、年畫體驗類H5、年畫賀歲動漫、年畫音頻故事課、年畫微信表情包等多種形態的年畫主題創新應用,傳統年畫成為了春節里熱門的網絡傳播內容。

這些嘗試說明,儘管不少與節日相關的非物質文化遺產在當代的應用場景逐漸消失,但它們卻可以藉助網絡與創意,與我們再次相遇,攜帶着不可或缺的文化意義重回節日場景。在這個過程中,給傳統文化適當“減負”,為文化普及適當“減壓”,讓年畫等越來越多傳統IP在當代實現全民認知與共享,是新時代弘揚中華優秀傳統文化的重要路徑。(杜潔芳 王學思)

本站聲明:網站內容來http://www.societynews.cn/html/wh/fq/,如有侵權,請聯繫我們,我們將及時處理

※回頭車貨運收費標準

宇安交通關係企業,自成立迄今,即秉持著「以誠待人」、「以實處事」的企業信念

月銷量過萬的自主品牌家轎 外觀時尚配置實用車主們滿意嗎_貨運

※回頭車貨運收費標準

宇安交通關係企業,自成立迄今,即秉持著「以誠待人」、「以實處事」的企業信念

1萬最值得表揚的地方:外觀絕對算是最滿意的,很漂亮時尚,大氣穩重,改款后增加的配置也很多,內飾也上檔次了,空間也能滿足家庭日常使用,給人很寬敞的感覺,動力完全夠用,性價比非常高。尚有不足:整車做工方面還有待提高,一擋換二擋有點不順暢,低扭有點不足,後排座椅不能比例放倒。

長安汽車-逸動

指導價:8.09-24.99萬

基本資料

長*寬*高(mm) 4620*1820*1490

軸距(mm) 2660

動力系統

1.6L+5擋手動/4擋手自一體

車主一

購買車型:2016款 1.6L 手動風尚型

裸車價格:7.1萬

最值得表揚的地方:外觀絕對算是最滿意的,很漂亮時尚,大氣穩重,改款后增加的配置也很多,內飾也上檔次了,空間也能滿足家庭日常使用,給人很寬敞的感覺,

※智慧手機時代的來臨,RWD網頁設計為架站首選

網動結合了許多網際網路業界的菁英共同研發簡單易操作的架站工具,及時性的更新,為客戶創造出更多的網路商機。

動力完全夠用,性價比非常高。

尚有不足:整車做工方面還有待提高,一擋換二擋有點不順暢,低扭有點不足,後排座椅不能比例放倒。

車主二

購買車型:2016款 1.6L 自動風尚型

裸車價格:7.5萬

最值得表揚的地方:外觀時尚動感,線條流暢,給人十分耐看而大氣的感覺,小改款后的內飾中控台材質有改良過,質感比較好,主被動安全配置明顯提高了,乘坐空間和舒適性都令人滿意,綜合實力強。

尚有不足:後排座椅沒有中間頭枕,油耗稍微高點,液壓助力方向盤有點重,4AT變速箱有點落後,開起來感覺比較肉。

編輯點評:逸動在自主品牌當中做工算是比較出色的,但細節上還和合資品牌有一定差距,配置上已經跟得上主流,但是發動機、變速箱等技術還有待進一步提升。本站聲明:網站內容來源於http://www.auto6s.com/,如有侵權,請聯繫我們,我們將及時處理

※評比南投搬家公司費用收費行情懶人包大公開

搬家價格與搬家費用透明合理,不亂收費。本公司提供下列三種搬家計費方案,由資深專業組長到府估價,替客戶量身規劃選擇最經濟節省的計費方式

各督察組組長深入一線推進中央生態環境保護督察工作_貨運

※智慧手機時代的來臨,RWD網頁設計為架站首選

網動結合了許多網際網路業界的菁英共同研發簡單易操作的架站工具,及時性的更新,為客戶創造出更多的網路商機。

2020-09-20

2020-09-20
分享到:
[打印]
字號:[大] [中] [小]

  第二輪第二批中央生態環境保護督察進駐以來,各督察組組長身體力行,率先垂範,深入學習貫徹習近平生態文明思想,堅決扛起政治責任,把握督察方向,狠抓隊伍建設,帶領督察組紮實開展工作。

  張寶順組長要求對標對錶習近平生態文明思想和習近平總書記對北京市一系列重要講話精神,深刻領會習近平總書記給建設和守護密雲水庫鄉親們的重要回信精神,堅持高標準、嚴要求,堅持以人民為中心的發展理念,聚焦突出生態環境問題,精準、科學、依法開展督察。督察進駐以來,他先後帶隊赴北京石景山、昌平、門頭溝、房山、通州等區開展實地督察調研,深入宣貫習近平生態文明思想,深入了解基層生態環境保護工作情況,特別是第一輪中央環保督察整改情況,督促地方高度重視生態環境整治工作。

  焦煥成組長要求將全面從嚴治黨貫穿於督察工作始終,充分發揮督察組臨時黨支部戰鬥堡壘作用和全體黨員先鋒模範作用,堅決貫徹落實習近平生態文明思想,堅決扛起政治責任。他先後帶隊赴天津津南、薊州、武清等7個區現場督察調研七裏海濕地修復治理、獨流減河污染整治等20多個問題點位,在調研獨流減河北堤水產養殖尾水治理、農業面源整治、濕地修復等情況和咸陽路污水處理廠、靜海區楊成庄鄉東寨村污水處理站等點位后,他強調,生態修復治理要因地制宜、分類施策,不能搞“一刀切”。

  耿惠昌組長帶頭學習習近平總書記關於中央生態環境保護督察工作、浙江省生態環境保護方面的重要指示批示精神,先後赴杭州、紹興、嘉興等地現場督察調研,現場察看紹興市賀家池區域環境綜合整治情況,詳細詢問整治工作面臨的困難和具體做法,了解督察整改落實、群眾信訪投訴舉報調查處理和服務“六穩”“六保”大局等情況,要求地方要深入貫徹落實習近平生態文明思想,對標對錶習近平總書記賦予浙江的新目標、新定位,進一步扛起生態文明建設先行示範的使命擔當。

※回頭車貨運收費標準

宇安交通關係企業,自成立迄今,即秉持著「以誠待人」、「以實處事」的企業信念

  李家祥組長要求督察組全體黨員幹部要深入學習貫徹習近平生態文明思想和習近平總書記關於生態環境保護的重要指示批示精神,嚴格按照部門督察規範組織開展工作,主動加強與國家能源局的交流溝通。他還帶隊赴河北張家口、山西大同下沉走訪,實地了解我國新能源建設和煤炭行業清潔生產情況。在現場調研時指出,要堅決貫徹落實習近平總書記關於能源發展的重要指示精神和黨中央、國務院決策部署,推動能源供給側結構性改革,堅持生態優先,积極化解過剩煤炭產能,推動能源綠色發展,助力打贏污染防治攻堅戰。

  於廣洲組長在對國家林草局的督察工作中,反覆強調要深入學習貫徹習近平生態文明思想,並用習近平生態文明思想指導推進督察工作。在大興安嶺督察調研期間,面對地處偏遠,交通不便的大興安嶺林區總部,他表示,來林草局督察,大興安嶺的情況不掌握不行。在察看大興安嶺林木種苗基地和南瓮河濕地國家級自然保護區等地后,他指出,大興安嶺的森林和濕地是東北地區的生態屏障,是保護黑土地的重要依託,廣大林草工作者要深入領會習近平總書記重要指示批示精神,統一思想、提高認識、加強研究、強化保護。

  黃龍雲組長帶頭學習貫徹習近平生態文明思想,在工作中始終堅持問題導向,把握督察重點方向,身體力行深入一線督察調研生態環境問題。督察進駐以來,先後帶隊赴中國鋁業集團公司所屬8家重點企業開展現場督察調研。每到一處,都詳細了解企業生產經營和生態環境保護情況,直奔產污節點和環境風險點,查看台賬記錄、在線監測數據等,對生態環保做得好的企業給予充分肯定,對發現的問題嚴肅指出,並督促企業邊督邊改、立行立改,有效傳導壓力,推進突出生態環境問題解決。

  蔣巨峰組長先後深入中國建材集團所屬7家企業,聚焦重點,直奔問題開展現場督察調研,並以座談會形式與企業有關人員開展深入交流,對發現的共性問題,要求集團公司有關部門及企業上一級公司要認真研究、舉一反三,深入學習領會貫徹落實習近平生態文明思想,將新發展理念貫穿到企業發展戰略布局和生產經營中。下沉督察期間,他始終走在隊伍最前面,在浩源水泥所屬金鑫礦山,他不顧道路崎嶇,現場檢查了3個礦坑的生態修復情況,他邊走邊問,邊看邊督,切實推動環境保護主體責任落到實處。

  在各位督察組組長的帶領下,第二輪第二批中央生態環境保護督察順利進駐,各項督察工作有序開展,並取得較好的督察效果,特別是推動解決一批群眾身邊的生態環境問題,獲得人民群眾的認可和稱讚。

※評比南投搬家公司費用收費行情懶人包大公開

搬家價格與搬家費用透明合理,不亂收費。本公司提供下列三種搬家計費方案,由資深專業組長到府估價,替客戶量身規劃選擇最經濟節省的計費方式

知名虐機頻道評選 2020 年智慧型手機耐用獎,誰是最堅固的贏家?_貨運

※智慧手機時代的來臨,RWD網頁設計為架站首選

網動結合了許多網際網路業界的菁英共同研發簡單易操作的架站工具,及時性的更新,為客戶創造出更多的網路商機。

虐機,大概是所有消費者最感興趣的話題,哪一款手機最耐用、哪一款手機耐用性最差,還有更深奧的那些手機最容易被修復等。知名虐機頻道 JerryRigEverything 更是相當有名的其中翹楚,只要提到虐機就絕對不能沒有看過這頻道,近日該頻道評選出 2020 年的各種智慧型手機耐用性獎項,分享給大家一看。

知名虐機頻道評選 2020 年智慧型手機耐用獎,誰是最堅固的贏家?

要說專業拆機,大家會想到的 iFixit,如果講到專業虐機,那當然非 JerryRigEverything 莫屬。在2020 年裡面,該頻道虐盡市面上的主流機型,並且在豐富的經驗累積之下評選出 2020 年的各得獎者,接下來就來為大家列出到底有哪些獎項,又有哪些機型獲選為該獎項的得獎者吧!

(點選後面機型可前往查看虐機影片)

可維修性最高:Google Pixel 5
可維修性最低:黑鯊 3
最具創新性機型:ZTE Axon 20
榮譽獎:LG Wing
內部結構最好看的機型:iPhone 12 Pro Max
耐用性最差手機:OnePlus Nord
最讓人迷惑的手機:Google Pixel 5
耐用性最佳手機:Google Pixel 4a

從 2016 年開始,該頻道每年都會將虐過的手機整理起來,在看似無目的的破壞同時了解各手機的耐用度,並且在隔年初進行最終評分,讓大家都能了解過去這一年裡面哪些手機最是頭好壯壯。下面就與大家分享完整版的影片(前半段大概講了投入各種公益,還有自家買了什麼東西…)。

※回頭車貨運收費標準

宇安交通關係企業,自成立迄今,即秉持著「以誠待人」、「以實處事」的企業信念

當然這裡被列入的機型都是比較大眾化、一般消費型手機,所以那些本來就是特定職業人士或專門設計在嚴峻環境中所使用的三防手機自然不在其中。

您也許會喜歡:

【推爆】終身$0月租 打電話只要1元/分

立達合法徵信社-讓您安心的選擇

※評比南投搬家公司費用收費行情懶人包大公開

搬家價格與搬家費用透明合理,不亂收費。本公司提供下列三種搬家計費方案,由資深專業組長到府估價,替客戶量身規劃選擇最經濟節省的計費方式

Redis詳解(十二)—— 緩存穿透、緩存擊穿、緩存雪崩_貨運

※評比南投搬家公司費用收費行情懶人包大公開

搬家價格與搬家費用透明合理,不亂收費。本公司提供下列三種搬家計費方案,由資深專業組長到府估價,替客戶量身規劃選擇最經濟節省的計費方式

  本篇博客我們來介紹Redis使用過程中需要注意的三種問題:緩存穿透、緩存擊穿、緩存雪崩。

1、緩存穿透

一、概念

  緩存穿透:緩存和數據庫中都沒有的數據,可用戶還是源源不斷的發起請求,導致每次請求都會到數據庫,從而壓垮數據庫。

  如下圖紅色的流程:

  

 

   比如客戶查詢一個根本不存在的東西,首先從Redis中查不到,然後會去數據庫中查詢,數據庫中也查詢不到,那麼就不會將數據放入到緩存中,後面如果還有類似源源不斷的請求,最後都會壓到數據庫來處理,從而給數據庫造成巨大的壓力。

二、解決辦法

  ①、業務層校驗

  用戶發過來的請求,根據請求參數進行校驗,對於明顯錯誤的參數,直接攔截返回。

  比如,請求參數為主鍵自增id,那麼對於請求小於0的id參數,明顯不符合,可以直接返回錯誤請求。

  ②、不存在數據設置短過期時間

  對於某個查詢為空的數據,可以將這個空結果進行Redis緩存,但是設置很短的過期時間,比如30s,可以根據實際業務設定。注意一定不要影響正常業務。

  ③、布隆過濾器

  關於布隆過濾器,後面會詳細介紹。布隆過濾器是一種數據結構,利用極小的內存,可以判斷大量的數據“一定不存在或者可能存在”。

  對於緩存擊穿,我們可以將查詢的數據條件都哈希到一個足夠大的布隆過濾器中,用戶發送的請求會先被布隆過濾器攔截,一定不存在的數據就直接攔截返回了,從而避免下一步對數據庫的壓力。

2、緩存擊穿

一、概念

  緩存擊穿:Redis中一個熱點key在失效的同時,大量的請求過來,從而會全部到達數據庫,壓垮數據庫。

  

   這裏要注意的是這是某一個熱點key過期失效,和後面介紹緩存雪崩是有區別的。比如淘寶雙十一,對於某個特價熱門的商品信息,緩存在Redis中,剛好0點,這個商品信息在Redis中過期查不到了,這時候大量的用戶又同時正好訪問這個商品,就會造成大量的請求同時到達數據庫。

二、解決辦法

  ①、設置熱點數據永不過期

※智慧手機時代的來臨,RWD網頁設計為架站首選

網動結合了許多網際網路業界的菁英共同研發簡單易操作的架站工具,及時性的更新,為客戶創造出更多的網路商機。

  對於某個需要頻繁獲取的信息,緩存在Redis中,並設置其永不過期。當然這種方式比較粗暴,對於某些業務場景是不適合的。

  ②、定時更新

  比如這個熱點數據的過期時間是1h,那麼每到59minutes時,通過定時任務去更新這個熱點key,並重新設置其過期時間。

  ③、互斥鎖

  這是解決緩存穿透比較常用的方法。

  互斥鎖簡單來說就是在Redis中根據key獲得的value值為空時,先鎖上,然後從數據庫加載,加載完畢,釋放鎖。若其他線程也在請求該key時,發現獲取鎖失敗,則睡眠一段時間(比如100ms)后重試。

3、緩存雪崩

一、概念

  緩存雪崩:Redis中緩存的數據大面積同時失效,或者Redis宕機,從而會導致大量請求直接到數據庫,壓垮數據庫。

  

   對於一個業務系統,如果Redis宕機或大面積的key同時過期,會導致大量請求同時打到數據庫,這是災難性的問題。

二、解決辦法

  ①、設置有效期均勻分佈

  避免緩存設置相近的有效期,我們可以在設置有效期時增加隨機值;

  或者統一規劃有效期,使得過期時間均勻分佈。

  ②、數據預熱

  對於即將來臨的大量請求,我們可以提前走一遍系統,將數據提前緩存在Redis中,並設置不同的過期時間。

  ③、保證Redis服務高可用

  前面我們介紹過Redis的哨兵模式和集群模式,為防止Redis集群單節點故障,可以通過這兩種模式實現高可用。

  

 

本站聲明:網站內容來源於博客園,如有侵權,請聯繫我們,我們將及時處理

※回頭車貨運收費標準

宇安交通關係企業,自成立迄今,即秉持著「以誠待人」、「以實處事」的企業信念

一反常態:疫情關店潮下,6000億美業市場為何堅挺?_貨運

※評比南投搬家公司費用收費行情懶人包大公開

搬家價格與搬家費用透明合理,不亂收費。本公司提供下列三種搬家計費方案,由資深專業組長到府估價,替客戶量身規劃選擇最經濟節省的計費方式

不可否認,2020新冠疫情市場衝擊還在蔓延。

餐飲行業閉店潮未能平息,業內人稱“比2003年SARS期間還嚴重”;服裝行業每天都能看到閉店消息,專家預測整個行業全年可能蒸發掉4000億。

這是一場全球性全行業的覆蓋式衝擊。在美國,今年零售業閉店數量或超過2萬家,是去年兩倍多;在日本,最為熱門的拉麵館接連閉店,倒閉數量或將創近20年來之最。

但唯獨一個行業倖免於難——美業。

根據美團平台大數據統計,2020年美團平台美業店閉店率達到17.5%。但相較於2019年,這個数字居然下降了2.2個百分點。

可謂一反常態。

01

曾靠閉店賺錢的美業灰產

為什麼說美業的韌性存續一反常態?這源於兩點:

首先,疫情期間全行業式微,橫向比較來看,美業的堅挺令人匪夷所思。

其次,縱向來看,美業閉店率常年接近於20%,今年不增反降引人深思。

按照劃分,我們所提及的美業(生活美容服務業)包括生活美容、美甲、美髮、紋綉服務等細分行業。經美團研究院測算,這個行業在2020年的市場規模約為6373億元。

其中,美容美髮行業佔了半壁江山。中商產業研究院分析,預計到2022年中國美容美髮行業市場規模將突破4000億元。

可以說,美容美髮行業的發展,直接影響到整個美業的數據樣本。但從過往表現來看,這個行業卻是一個“賽博朋克”般的存在。

2019年,中國美容美髮行業參与者超過34萬。如此龐大的基數下,行業里沒有一家上市公司,反倒是渾水摸魚者眾。

他們最為外界所熟知的商業模式,就是“閉店割韭菜”。

模式一:割會員的韭菜

《廈門晚報》就曾報道,當地一家名為“造星計劃”的美容美髮機構,選址在商場角落,儘管生意蕭條,髮型師卻每天忙於拉消費者充值VIP卡。

短短5個月之後,該店人去樓空,商家捲走了近90萬元會員費。后經律師事務所判斷,這可能本就是一場早有預謀的圈錢跑路行為。

這不是孤例。大連一家剛開不久的美髮機構突然停業倒閉,老闆不知所蹤。而門店裡,張女士投放了2.4萬元的化妝品才上架4天就消失了。

而與張女士一同去報警的,還有200多名充值VIP卡的消費者。

類似的事情,2019年2月江西發生一例、4月石家莊發生一例、5月福州發生一例、8月濟南發生一例……

整合網絡各路消息,當年倒閉的大小理髮門店,特別是一二線城市的中低價位大店,至少達到了10000家。

模式二:割加盟商的韭菜

加盟被割韭菜,成為了近兩年的熱門關鍵詞。

特別是喜茶、奈雪の茶推動起來的奶茶加盟熱潮。在最終一年新增奶茶店2萬多家,90%都虧損的現實下,加盟韭菜逐漸被大眾所看清。

但在美容美髮領域,這已經成為了公認的套路。

據一位投資人朋友介紹,目前國內知名的某養發品牌,老闆賺到的第一桶金就來自於割韭菜。

20年前,這位老闆建立連鎖品牌搞生髮、療發、養發等各種業務,通過平面媒體大肆傳播后,收割了一波又一波加盟商。

平均下來,這位老闆每隔2年換一個品牌洗一遍加盟連鎖,翻了幾輪才有現在這個全國化品牌。

到底是哪家品牌?留言討論。

02

割韭菜背後的行業苦情

傳統美業鏈條上,其實各級經銷商都寄生在實體美業商家身上。加之實體門店租金、人力、水電等成本高企,部分商家為了自身存續,基本以賣貨為主要動力,最終忽略了產品質量、效果、品牌、口碑等因素。

虛假宣傳、強制消費、辦卡跑路……在那個“銷售即服務”的時代,他們在消費者心智中慢慢烙下了暴利者、商業騙子、割韭菜的形象。

但儘管如此,關於“割韭菜”的論述,業內人士其實是不承認的。他們給到的回應大多是:一顆老鼠屎壞了一鍋粥、圈錢跑路的都是極少數。

確也如此。從社會八卦回歸到商業本質,一切灰產、套路都不可能成為行業主流。只不過是負面內容易於傳播,遮掩掉了這個行業最本質的問題。

美業市場的本質問題是什麼?

美團研究院發布的《中國生活美容行業發展報告(2020)》显示:經營成本高、客流量低和人才不足,仍是生活美容服務業商戶面臨的主要問題。

報告數據甚至显示,超過50%的受訪商戶表示其經營成本占其門店收入的40%-50%;還有約30%的受訪商戶經營成本佔到了營收的70%以上。

難以節流的固定成本佔比過半,這意味着商戶用於開源的經營效率過低。要知道,商業的本質就是效率,低效增長相當於慢性自殺。

展開美業“拉新-留存-裂變”的經營閉環,不難發現其中的問題。

一、拉新環節:玩法傳統,獲客成本高企

就目前而言,市面上主流的拉新手段有兩種:

①通過爆款產品口碑傳播,多次曝光在微博、微信、小紅書等平台,吸引種子用戶。

②通過與當地擁有潛在用戶群的品牌進行異業合作,再通過線上營銷放大品牌聲量,圈攏第一批種子用戶。

作為線下實體門店,美業潛在用戶覆蓋範圍最多是周邊三公里,甚至單個社區。這樣說來,第二種玩法似乎靠譜。

但我們看到的美業拉新,不過是“姐妹同行一人免單”“只要你來,就打五折”“充值會員卡半價優惠”……

拉新轉化低,獲客成本高。

二、留存環節:忽略服務細節,顧客體驗感較差

用戶留存與否,在於他對整個消費流程的體驗評判。如果在你的門店消費體驗不好,就沒有留存可談。

傳統美業門店,進店就讓等座,等座就有人在打聽需求並推銷VIP,就連是服務過程中Tony、Anne等工作人員沒話找話聊會員卡。

專業美容中心艾維庭,服務細節把控比較精細。比如客人進店倒水,要求一定要有托盤,不能直接用手。

美髮品牌美聯社則更為乾脆。全國門店堅持不做銷售,13年來不賣一張卡,不賣任何產品。

進店環節的空間體驗、等待環節的時間體驗、消費環節的產品體驗,每一環都是影響用戶留存的關鍵。

三、裂變環節:傳統美業口碑不再

傳統大型美業,其實是靠信息不對稱來賺錢,靠推銷、類金融等手段快速擴張。但互聯網時代下,消費驅動難走,口碑驅動的時代到來。

但在忽略服務細節,顧客體驗感較差的情況下,口碑往往會變成差評。

“拉新-留存-裂變”的經營閉環難以打通,美業經營效率難以提升,高閉店率理所當然。

從滲透率和市場體量來看,6000億美業市場與咖啡茶飲略微相似,就連加盟割韭菜的橋段都曾一致地出現過。

但飲品行業新媒體《咖門》,在統計美團、大眾點評實時數據后發現:疫情期間咖啡館閉店率約為3.7%,茶飲店約為4%。

※智慧手機時代的來臨,RWD網頁設計為架站首選

網動結合了許多網際網路業界的菁英共同研發簡單易操作的架站工具,及時性的更新,為客戶創造出更多的網路商機。

相較之下,美業17.5%的閉店率已然處在高位。

03

高閉店率下的行業轉型

從商業角度而言,行業有痛點就有需求,有需求就有市場。

2016年前後,一撥提供美業細分領域解決方案的創業者湧現。當時,一位從騰訊離職的朋友就打算在重慶市場免費幫助美業商家管理會員、產品分銷、營銷裂變等。

這套解決方案里,商家還可以在線採購物料,比如洗髮水、護髮素、吹風機等日常耗材。公司則靠這些產品的銷售,賺取上下游的差價。

沒想到的是,這些商家原本就有穩定的供貨商。他們在朝天門的批發市場里,可以用9元每桶的價格拿到高仿洗髮水。

這桶洗髮水,足夠洗100次頭。

這位朋友最終轉型了做了外包業務,但行業里其他的生活服務电子商務平台不斷出現,這些服務商正在重構傳統美業。

美團可謂其中代表。

美業領域,美團第一個推出了團購業務、第一個推出了基於LBS的本地生活營銷解決方案,第一個探索動態定價策略。

為我們熟知的營銷手段,是美團主導的多次行業聯動大促。比如,龍抬頭美髮大促、七夕大促、雙12大促等本地生活服務大促活動。

今年疫情期間,考慮到用戶宅家裡一兩個月沒有理髮,美團就在“龍抬頭”之際聯合本地生活服務商家推出安心理發活動,提供“3+N”項安心消費服務保障。

1個月下來,美髮服務訂單量暴漲898%,美甲訂單量上漲635%,美容服務訂單量上漲579%,美睫訂單量上漲301%。

而在後來的七夕聯動大促中,Tony老師亦然成為了七夕最忙碌的群體。

數據显示,七夕前3天,美髮、醫療整形、化妝品、美睫紋綉、養發等訂單量增長最快,其中,美髮訂單數量增長50.06%。

而現在打開美團的麗人頻道,也可以發現商家直播、達人探店、UGC點評等內容。美業在用戶拉新方面,玩出了線上線下聯動的新套路。

南京東路金牌精品店Nice Salon的美髮手藝人Justin就坦言,自己是藉助美團平台做起來的一個設計師,較沒上線美團時門店客人增加了至少50%。

Justin是學徒出身。通過每天工作11個小時,和不定期進修之後,他才自己出來創業開了一家美髮店。

美業市場和Justin一樣的人很多。他們幾乎沒有經管知識,店長的能力直接決定了門店的經營狀況。

就像疫情期間,各行業數據都顯現出一個市場洞察:用戶對價格的敏感度更高了,他們更願意選擇低價商品了。

可惜的是,大多數美業商家店長不清楚。

這時,美團只能為商家增加一項“任務”——上線一個低價的團購,比如19.9元洗吹、9.9元剪劉海,或者9.9元修眉。如果完成這條任務,美團給予相應商家的評分將提升。

儘管任務下達,還會有很多商家不理解為什麼要這麼做。但按要求完成任務的商家就會發現,其店鋪瀏覽量和轉化率得到了明顯提升。

這其實是美團上線的一套經營評分體系。針對那些不太懂“why”和“how”的商家,這個體系正“傻瓜式”地告訴他們怎麼去經營。

數據显示,該體系自2019年12月上線以來,美業商戶優質達標率從4%提升至21%,優質商戶訪問量提升33.4%。

訪問量的提升,能夠直接提升門店客流量的規模。但如此低價的引流,如果不搞點二次消費引導、提前鎖客等玩法,商家資金難以回籠。

辦張會員卡的老套路又回來了?

明顯行不通。“會員卡”三個,字早已透支了用戶對行業的信任度。另外,實體卡折扣計算邏輯複雜、會員管理程序繁瑣,反而會降低門店的運營成本。

美團則為商戶上線了数字會員卡。5次剪髮卡、3次美容卡,其試圖通過一次購買多次服務解決美業商家提前鎖客、回籠資金的需求。

從用戶角度而言,在美團為未來服務預付費,就像先團購后核銷一樣平常。整個交易過程中,最影響消費決策的信任問題得以解決。

從經營角度上看,第三方服務商更多是通過一系列的標準化工具去引導商家。這個行業大多是手藝人從商,真正會做生意的還是少數。

這估計才是傳統美業最大的癥結。當手藝人只會打磨產品,無法將產品巧妙地轉變為商品,這個行業的商業化必然走向畸形發展。

人,才是你的最佳商業模式。

為此,美團也在2017年推出了國內第一家“互聯網+美業”學習培訓平台——美團大學美業學院。

據悉,該平台上線1年就有66萬學員學習了1700多個課程。“怎麼玩轉美團”“怎麼玩轉互聯網+美業”,這個培訓平台就像一個商學院,為美業領域不斷輸出經營人才。

除了經營人才培訓,這裏還是行業人力資源交流中心。平台上,擁有超過35萬認證的手藝人信息,商家招聘、培訓學習等都能在這個集中地實現。

營銷、經營、人才,美團正在全方位保姆式助力傳統美業轉型升級。當然在這期間,有贊、博卡、美克拉等新入局者,都在用SaaS、培訓等方面賦能傳統美業。

但也有不少遺憾。

美團數據显示,就經營規模而言,接入平台的商戶中有64.0%的商戶為連鎖經營,有27.8%的商戶連鎖店鋪數量多於 5 家,有0.6%的商戶擁有50家以上的連鎖店鋪;未接入平台的商戶中有 75.6%的商戶為單店經營。

這意味着,藉助互聯網工具轉型的,雖然是行業腰部力量,但依舊是小部分。在這個頭部品牌市場份額不足2%的行業里,單店經營的螞蟻雄兵才是主流。

這是一群難以打動的人。在重慶南岸,40多歲的章磊就是一家美髮店老闆。他曾在新店階段試過美團,效果是:低價引流還有10多個點被提走,用戶卻沒有來過第二次。

從此,章磊也沒有再用過美團。

包括美團在內的諸多服務商也很苦惱。他們的業務員一再指導章磊這種單店小老闆經營,但後者從一開始認定的就是,只要上線美團就能引流。

在他們的字典里,只有打遊戲刷抖音,未曾想過空不下來學習怎麼經營。

服務商們對於美業数字化的探索還在初期階段。一種模式是否能夠通用於大品牌、中小連鎖、單店等全業態?目前並沒有可靠的數據回答這一點。

服務本來就需要一把活動扳手,去扭動行業里不同大小的螺絲。而真正要打造出這樣一把扳手,美團和它的同行還需要更多的時間。

04

美業迎來蓬勃新機遇

率先轉型的美業商業,在疫情中的韌性已得到了驗證。

武漢的MG美貫造型,歇業3-4個月後恢復營業。由於積壓需求得到報復性消費,其業績較去年還有所增長。

容顏管理中心Wake me,2-3月份沒有營業通過直播贈送洗手洗、酒精等維繫客情。4月初開業之後,1個月時間就恢復到了疫情前水平。

美聯社亦然。疫情之後,其營業收入就環比增長30%,4月恢復正常並反超2019年同期。

這些都是借力美團轉型的商家。也正是這些商家的韌性存續,疫情期間美團平台美業店閉店率較2019年下降了2.2個百分點。

當然,我們這不只歸功於美團数字化賦能,關鍵還在整個美業市場的增長。

比如后疫情時代,消費升級全面加速,人們更願意為提升生活品質而埋單。這聚焦到美業市場的表現,就是客單價提升、復購頻次增加,次線城市市場增長加速。

數據可以佐證一切。美團平台大數據显示,與2018年相比,2020年養發客單價提升了 26.4%,美甲、美髮客單價分別提升了 4.4%、2.9%。

城市市場的發展亦如所料。美團平台中 2019年一線城市活躍商戶數量同比增長率為 41.0%,新一線城市增長率為53.2%,二線城市增長率為58.1%,而三線城市和其他城市的增長率則分別達到了66.3%和81.3%。

就在增速達到66.3%的三線城市,我們曾遇到一個真實的小場景:

幾個女孩在逛商場,要為一個正要結婚的閨蜜參謀新衣服。到中午飯點時,衣服沒有選好,閨蜜則打算請大家一起吃飯。

這其中,一個女孩第一時間拒絕參加這場飯局。她給出的理由是:要去另一個商場找小姐姐做美甲,午飯就隨便吃點。

這是一個直男理解不到的理由,也是大多數經營者沒有看清的新女性商業趨勢。

在美業客單價中,女性較男性高出了30.6%。而在這群女性的消費鄙視鏈中,服裝、餐飲已經讓位於了美業。

美團研究所預計,到2025 年,中國生活美容服務業的市場規模將達到8375億元,線上化率將提升6.4倍。

美業蓬勃發展的新機遇正撲面而來。

【本文作者快刀財經編輯部,由合作夥伴微信公眾號:快刀財經授權發布,文章版權歸原作者及原出處所有,轉載請聯繫原出處。文章系作者個人觀點,不代表立場。如內容、圖片有任何版權問題,請聯繫(editor@zero2ipo.com.cn)處理。】

※回頭車貨運收費標準

宇安交通關係企業,自成立迄今,即秉持著「以誠待人」、「以實處事」的企業信念

Intel 第 11 代「Rocket Lake」與第 12 代「Alder Lake」搶先看_貨運

※評比南投搬家公司費用收費行情懶人包大公開

搬家價格與搬家費用透明合理,不亂收費。本公司提供下列三種搬家計費方案,由資深專業組長到府估價,替客戶量身規劃選擇最經濟節省的計費方式

在本次 CES 發表會中,Intel 除發表系列第 11 代行動處理器外,還花了一些時間來預告即將問世的第 11 代桌上處理器「Rocket Lake」與命名為「Alder Lake」的第 12 代Core 處理器,雖然並沒有講得太多新細節,但已經夠讓人流口水了。

Intel 第 11 代「Rocket Lake」與第 12 代「Alder Lake」搶先看

「Alder Lake」與其前身 Lakefield 一樣將會採用與 Arm 的 BIG.little 相似的方式,將高效能核心與高速率核心封裝在一起,以實現功率與效率兩方面的最大化,但不同之處是 Lakefield 主要用在筆電上,而下一世代的 Alder Lake 將可用於桌上電腦與筆電,而首批搭載這種可擴展功率系統的產品將會在下半年出現。第 12 代 Alder Lake 處理器將採用在第 11 代 Tiger Lake 中已經存在的 10nm SuperFin 設計強化版本,並結合了新的大功率核心 Golden Lake 和新的 Gracemont 核心來提高效率。在發表會中更直接展示了搭載 Alder Lake 的電腦開啟狀態(上圖),讓大家先睹為快。

桌上型電腦用戶敲碗許久的第 11 代「Rocket Lake」即將問世,正式名稱 Intel Core S 系列處理器以旗艦 i9-11900K 為首,IPC 提高 19%,內顯效能提高 50%,另外也首度將 AI 運算能力導入主流 PC 平台中。雖說已預計在 3 月份推出,但此次並沒有透漏太多新的細節,也並未完全展示整個第 11 代 Rocket Lake-S 陣容,僅簡單講述全新核心架構、14nm 製程,以及處理器可提供 20 條 PCIe 4.0 通道,可容納 x16 顯卡與 x4 SSD。 

在實力展示方面,以第 11 代 Intel Core i7 8 核心處理器與 AMD R9 12 核心處理器對比,在配備相同 GPU 的情況下執行 Metro Exodus,可以看到 Intel 在 FPS 上的平均表現優於對手。

※智慧手機時代的來臨,RWD網頁設計為架站首選

網動結合了許多網際網路業界的菁英共同研發簡單易操作的架站工具,及時性的更新,為客戶創造出更多的網路商機。

您也許會喜歡:

【推爆】終身$0月租 打電話只要1元/分

立達合法徵信社-讓您安心的選擇

※回頭車貨運收費標準

宇安交通關係企業,自成立迄今,即秉持著「以誠待人」、「以實處事」的企業信念

設計模式之單例模式_貨運

※評比南投搬家公司費用收費行情懶人包大公開

搬家價格與搬家費用透明合理,不亂收費。本公司提供下列三種搬家計費方案,由資深專業組長到府估價,替客戶量身規劃選擇最經濟節省的計費方式

目錄:

  • 什麼是單例模式
  • 單例模式的應用場景
  • 單例模式的優缺點
  • 單例模式的實現
  • 總借

一、什麼是單例模式

  單例模式顧名思義就是只存在一個實例,也就是系統代碼中只需要一個對象的實例應用到全局代碼中,有點類似全局變量。例如,在系統運行時,系統需要讀取配置文件中的參數,在設計系統的時候讀取配置文件的類往往設計成單例類。因為系統從啟動運行到結束,只需要讀取一次配置文件,這個讀取配置文件全部由該類負責讀取,在全局代碼中只需要使用該類即可。這樣不僅簡化了配置文件的管理,也避免了代碼讀取配置文件數據的不一致性。

 

 單例模式的特點:

  1、該類的構造方法聲明為private,這樣其他類無法初始花該類,只能通過該類的public方法獲取該類的對象。

  2、裏面有個私有的對象成員,該成員對象是類本身,用於public方法返回該類的實例。

  3、該類中提供一個public的靜態方法,返回該類的私有成員對象。

 

二、單例的應用場景

 

  舉一個小例子,在我們的windows桌面上,我們打開了一個回收站,當我們試圖再次打開一個新的回收站時,Windows系統並不會為你彈出一個新的回收站窗口。,也就是說在整個系統運行的過程中,系統只維護一個回收站的實例。這就是一個典型的單例模式運用。

 

  繼續說回收站,我們在實際使用中並不存在需要同時打開兩個回收站窗口的必要性。假如我每次創建回收站時都需要消耗大量的資源,而每個回收站之間資源是共享的,那麼在沒有必要多次重複創建該實例的情況下,創建了多個實例,這樣做就會給系統造成不必要的負擔,造成資源浪費。

 

  再舉一個例子,網站的計數器,一般也是採用單例模式實現,如果你存在多個計數器,每一個用戶的訪問都刷新計數器的值,這樣的話你的實計數的值是難以同步的。但是如果採用單例模式實現就不會存在這樣的問題,而且還可以避免線程安全問題。同樣多線程的線程池的設計一般也是採用單例模式,這是由於線程池需要方便對池中的線程進行控制

 

  同樣,對於一些應用程序的日誌應用,或者web開發中讀取配置文件都適合使用單例模式,如HttpApplication 就是單例的典型應用。

 

  從上述的例子中我們可以總結出適合使用單例模式的場景和優缺點:  

 

   適用場景:

  1.需要生成唯一序列的環境

  2.需要頻繁實例化然後銷毀的對象。

  3.創建對象時耗時過多或者耗資源過多,但又經常用到的對象。 

  4.方便資源相互通信的環境

 

 

三、單例模式的優缺點

  優點

    1、在內存中只有一個對象,節省內存空間;

※智慧手機時代的來臨,RWD網頁設計為架站首選

網動結合了許多網際網路業界的菁英共同研發簡單易操作的架站工具,及時性的更新,為客戶創造出更多的網路商機。

    2、避免頻繁的創建銷毀對象,可以提高性能;

    3、避免對共享資源的多重佔用,簡化訪問;

    4、為整個系統提供一個全局訪問點。

  缺點

    1、不適用於變化頻繁的對象;

    2、濫用單例將帶來一些負面問題,如為了節省資源將數據庫連接池對象設計為的單例類,可能會導致共享連接池對象的程序過多而出現連接池溢出;

    3、如果實例化的對象長時間不被利用,系統會認為該對象是垃圾而被回收,這可能會導致對象狀態的丟失;

 

四、單例模式的實現

  1、餓漢式

public class Mgr{
    //創建自己的實例,並初始化私有靜態final成員
    private static final Mgr mgr = new Mgr();
    //私有構造方法
    private Mgr() {}; 
    //公共方法,返回自己的實例化成員
    public static Mgr getMgr() { 
        return  mgr;
    }
}

  備註:該單例實現方法簡單明了,推薦使用。該類被JVM加到內存的時候,只會加載一次,並且只實例化一個單例,優點是具有線程安全性,缺點是:不用他也在內存中實例化,浪費內存。所以提出了懶散式實現方式。

  2、懶漢式

public class Mgr{
   //聲明私有靜態對象成員,作為返回值
    private static Mgr mgr;
   //私有構造函數
    private Mgr() {}; 
   //懶漢的特點,提供公共靜態方法,如果該成員對象為空,實例化並返回
    public static Mgr getMgr() {
        if(mgr == null){
            mgr =  = new Mgr();
        }
         return  mgr;
     }
}

  備註:(不推薦用)這種實現方法只有程序在調用該類的getMgr方法才實例話對象並返回,特點就是調用的時候再實例化並返回,延遲加載的被動形式。但是該實現方法不是線程安全的,因為當同時有有兩個線程執行到if(mgr==null)語句的時候,由於某些原因其中一個線程先一步執行下一句,實例化了對象並返回;兩一個線程再實例化對象在返回,這兩個線程返回的對象不是同一個對象(這難道還是單例嗎!),所以該實現方法的缺點也很明顯。那為了避免線程不安全問題,在懶漢寫法上提出加鎖的實現方式。

  3、給公共方法加鎖

public class Mgr{
    //聲明私有靜態對象成員,作為返回值
    private static Mgr mgr;
    //私有構造函數
    private Mgr() {}; 
    //給公共方法加鎖,只有一個線程第一次獲得鎖實例化對象並返回
    public static syncnronized Mgr getMgr() {
        if(mgr == null){
            mgr = new Mgr();
        }
        return  mgr;
   }
}

  備註:(推薦使用)這種實現方式比較完善,既保證了懶散式的延遲加載方式,也保證了線程安全。缺點是在整個方法上加鎖,導致性能下降。因為只有第一次獲得鎖的線程實例化對象並返回,以後的線程獲得鎖的時候執行 if(mgr == null)語句的時候,由於mgr已經實例化了不為空,直接跳過返回實例。整個過程要競爭鎖,不能併發執行導致性能下降。那為優化性能下降問題,那我只在mgr = new Mgr()上加鎖,保證鎖粒度最小化的同時保證單例實例化。

  4、給實例化加鎖

public class Mgr{
    //私有靜態成員對象
    private static Mgr mgr;
    //私有構造函數
    private Mgr() {}; 
    //公共方法,在實例化語句塊加鎖,保證單例
    public static  Mgr getMgr() {
        if(mgr == null){
            syncnronized(Mgr.class){
                mgr = new Mgr();
            }
        }
         return  mgr;
  }
}

  備註:(不推薦使用)該實現方法雖然相較方法3性能有所提升,但並不能保證線程安全。因為當兩個線程同時執行if(mgr == null)語句時,其中線程1獲取鎖,實例化對象並返回,線程2在獲得鎖又在實例化對象並返回。線程1和線程2獲取的對象並不是同一個。所以在此基礎上提出了雙重判斷方式。

5、雙重判斷加鎖

public class Mgr{
    //私有靜態成員對象
    private static  Mgr mgr;
    //私有構造函數
    private Mgr() {}; 
    //公共方法提供雙重判斷並在實例化代碼塊加鎖
    public static  Mgr getMgr() {
        if(mgr == null){ //第一次判斷
            syncnronized(Mgr.class){
                if(mgr == null){ //第二次判斷
                    mgr =  = new Mgr();
                }      
            }
        }
         return  mgr;
  }
}

  備註:(推薦使用)相較於方法4,該方法雙重判定,如果多線程同時執行到第一次判斷語句位置,其中一個線程獲得鎖,由於是第一次該對象成員為空,實例化后並返回。其後其它線程調用公共方法的時候,由於實例化了,在第一次判斷自接返回實例,不在產生鎖競爭。大大提高了效率,保證了線程的安全性,也保證了延遲加載的特性。

 6、靜態內部類

public class Mgr{
    private Mgr() {};
    //定義靜態內部類
    private static class MgrHolder{
        private final static Mgr mgr = new Mgr();
    } 
    //公共方法直接返回靜態內部類的實例對象
    public static  Mgr getMgr() {
        return  MgrHolder.mgr;
  }
}

  備註:(可使用)該實現方法通過JVM來保證線程安全性,靜態內部類MgrHolder來New一個Mgr對象,JVM只會加載一次Mgr類(靜態內部類不會加載),當類調用getMgr方法的時候,也只會調用一次,公共方法調用靜態內部類,獲取一個對象(也是實現懶加載)。所以也是線程安全的。

7、枚舉類單例模式

public enum Mgr{
    mgr;
    public void m(){} //業務方法
}

  備註:(推薦使用)jdk1.5之後才能正常達到單例效果,參考來自《Effective Java》。注意枚舉類的枚舉變量必須寫在第一行,後面實現業務代碼。調用方式是:Mgr.mgr.Function_Name();具備枚舉類型的特點,有點是:線程同步,防止反序列化。

五、總結

  通過上面幾種單例模式的實現方式的列舉,但是在實際應用中其中的2,3,4三種方式並不適用,列出來只是讓讀者更好的理解方式5的由來,起到拋磚引玉的作用,更好的理解單例模式。總之常用的四種,懶漢,雙重校驗鎖,靜態內部類,枚舉單例。

  餓漢:類加載的時候就創建實例,所以是線程安全的,但不能延遲加載。

  雙重校驗鎖:線程安全,效率較高,延遲加載。

  靜態內部類:實現起來比較麻煩,在不同的編譯器上會出現不可預知的錯誤。

  枚舉單例:很好,不僅避免了多線程同步問題,而且能反正反序列化重新創建對象,但是不能延遲加載,用的人少。

 

  • 讀者發現有什麼有問題的地方謝謝留言指正。部分參考自:https://www.cnblogs.com/xuwendong/p/9633985.html#_label0

 

 

本站聲明:網站內容來源於博客園,如有侵權,請聯繫我們,我們將及時處理

※回頭車貨運收費標準

宇安交通關係企業,自成立迄今,即秉持著「以誠待人」、「以實處事」的企業信念

這些“消失”的經典汽車設計 你有錢都買不到!_貨運

※智慧手機時代的來臨,RWD網頁設計為架站首選

網動結合了許多網際網路業界的菁英共同研發簡單易操作的架站工具,及時性的更新,為客戶創造出更多的網路商機。

而到了現在就是常見手握式把手了。車身防擦條當年因為汽車還不算普及,開車技巧也沒有那麼好,所以會在車身周圍和保險杠的位置安置軟朔膠的防擦條,從而發生輕微碰撞和摩擦的時候損壞到漆面。而現在,幾乎看到不到咯,保險杠還在就算良心了。

隨着時代的進步,科技也在慢慢發展,人們的審美也隨着變化,當然,這也包括了汽車產業,在以前經常看到汽車上的一些設計,現在慢慢的也“消失”不見了。

自動伸縮天線

想當年,汽車身上那根細細的天線成為了當時汽車的一種“時髦”,不管是不是真假的,幾乎有車的人都加裝了這一根“天線”,就好像現在加裝包圍一樣流行。在當年,原配有天線的車可都是豪車。到了現在,為了美觀和空氣動力學,就設計成了“鯊魚鰭”的形狀。

上翻式門把手

也許,在一些很老的車型上還能找到這種設計的把手,捨棄這種設計的原因是把手位置容易給指甲刮花,

※回頭車貨運收費標準

宇安交通關係企業,自成立迄今,即秉持著「以誠待人」、「以實處事」的企業信念

發生碰撞時,上翻式把手的設計原理容易導致門打不開。而到了現在就是常見手握式把手了。

車身防擦條

當年因為汽車還不算普及,開車技巧也沒有那麼好,所以會在車身周圍和保險杠的位置安置軟朔膠的防擦條,從而發生輕微碰撞和摩擦的時候損壞到漆面。而現在,幾乎看到不到咯,保險杠還在就算良心了。

跳燈

說起跳燈,相信很多人會先想起《頭文字D》裏面的AE86,在當年,跳燈也是一種潮流的設計,到後來,設計師們發現,跳燈會增加車輛的風阻,故障率也高,慢慢的就“消失了”。不過我依然覺得,跳燈很帥。

尾語:考慮到實用性,安全性,美觀性等問題,一些兒時的經典已經慢慢“消失”,當然,這些“消失”的設計並不是完全的消失,而是進化了,新舊交替是必然的事。本站聲明:網站內容來源於http://www.auto6s.com/,如有侵權,請聯繫我們,我們將及時處理

※評比南投搬家公司費用收費行情懶人包大公開

搬家價格與搬家費用透明合理,不亂收費。本公司提供下列三種搬家計費方案,由資深專業組長到府估價,替客戶量身規劃選擇最經濟節省的計費方式